/* --- DOWNLOADS MODULE (VERTICAL LAYOUT) --- */

:root {
    --dl-bg: #131519;
    --dl-border: #2a2e35;
    --dl-title: #ffffff;
    --dl-text: #a0a0a0;
    --dl-accent-orange: #e67e22;
    --dl-accent-purple: #9b59b6;
}

#downloads-page-balduneta {
    padding-bottom: 20px;
}

/* --- HEADER --- */
.rank-header {
    text-align: center;
    margin-bottom: 30px;
    border-bottom: 1px solid var(--dl-border);
    padding-bottom: 20px;
}

.rank-title {
    font-family: 'Cinzel', serif;
    font-size: 28px;
    color: var(--dl-title);
    margin-bottom: 5px;
    text-transform: uppercase;
}

.rank-subtitle {
    color: var(--dl-text);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* --- CAJAS PRINCIPALES (Descargas, Requisitos, etc) --- */
.dl-box-standalone {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--dl-border);
    border-radius: 8px;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
    height: 100%; /* Asegura altura igual en filas */
}

.dl-box-standalone:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

/* Bordes Brillantes */
.border-purple-glow {
    border-top: 3px solid var(--dl-accent-purple);
    box-shadow: 0 0 15px rgba(155, 89, 182, 0.1) inset;
}

.border-orange-glow {
    border-top: 3px solid var(--dl-accent-orange);
    box-shadow: 0 0 15px rgba(230, 126, 34, 0.1) inset;
}

/* Badges y Header de Tarjeta */
.badge-new-yellow {
    position: absolute;
    top: 10px;
    right: 10px;
    background: #f1c40f;
    color: #000;
    font-size: 9px;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
}

.icon-square {
    width: 45px;
    height: 45px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    border-radius: 6px;
    color: #fff;
}

.bg-purple-soft { background: linear-gradient(135deg, #8e44ad, #9b59b6); }
.bg-orange-soft { background: linear-gradient(135deg, #d35400, #e67e22); }

.text-orange-title {
    color: var(--dl-accent-orange);
    font-family: 'Cinzel', serif;
    font-size: 20px;
    letter-spacing: 1px;
}

/* BOTONES DE DESCARGA */
.download-links-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.btn-dl-gradient {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    border-radius: 4px;
    color: #fff;
    text-decoration: none !important;
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    transition: 0.2s;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.btn-dl-gradient span i { margin-right: 8px; }
.btn-dl-gradient small { opacity: 0.6; font-weight: 400; }

.btn-dl-gradient.purple {
    background: linear-gradient(90deg, rgba(142, 68, 173, 0.2), rgba(155, 89, 182, 0.4));
    border-left: 3px solid var(--dl-accent-purple);
}

.btn-dl-gradient.orange {
    background: linear-gradient(90deg, rgba(211, 84, 0, 0.2), rgba(230, 126, 34, 0.4));
    border-left: 3px solid var(--dl-accent-orange);
}

.btn-dl-gradient:hover {
    filter: brightness(1.3);
    padding-left: 20px;
}

/* REQUISITOS Y FEATURES */
.text-orange { color: var(--dl-accent-orange) !important; }

.border-secondary { border-color: rgba(255, 255, 255, 0.1) !important; }

/* REESTRUCTURACIÓN DE COLUMNAS (OVERRIDE DE BOOTSTRAP) */
/* Forzamos que las columnas de abajo ocupen el 100% para lograr el orden vertical */

/* Fila de abajo (Requisitos y Features) */
.row.d-flex.align-items-stretch {
    flex-direction: column; /* Apilar verticalmente */
}

.row.d-flex.align-items-stretch > .col-md-6 {
    width: 100%; /* Ocupar todo el ancho */
    flex: 0 0 100%;
    max-width: 100%;
}

/* Ajustes visuales para cuando están en ancho completo */
.dl-box-standalone {
    margin-bottom: 0; /* El margen lo maneja el gap del row */
}

/* RESPONSIVE */
@media (max-width: 768px) {
    .btn-dl-gradient {
        flex-direction: column;
        align-items: flex-start;
        gap: 5px;
    }
    .btn-dl-gradient small {
        align-self: flex-end;
    }
}