/* ==========================================================
   CCVida Music — Stylesheet v6
   Paleta Base: Blanco Puro · Azul Real · Azul Marino
   ========================================================== */

:root {
    --bg:             #ffffff;
    --bg-soft:        #f0f5ff;
    --surface:        #ffffff;
    --surface-2:      #f7faff;
    --line:           rgba(26, 79, 163, 0.14);
    --line-soft:      rgba(26, 79, 163, 0.07);
    --text:           #0d1b3e;
    --muted:          #5a6d8c;
    --primary:        #1a4fa3;
    --primary-strong: #103680;
    --primary-glow:   rgba(26, 79, 163, 0.10);
    --amber:          #2080e0;
    --amber-strong:   #1460b8;
    --amber-glow:     rgba(32, 128, 224, 0.14);
    --royal:          #0e3572;
    --royal-strong:   #091f4a;
    --royal-glow:     rgba(14, 53, 114, 0.16);
    --wine:           #1a4fa3;
    --wine-strong:    #103680;
    --success:        #1a7a4f;
    --danger:         #c0392b;
    --shadow:         0 4px 28px rgba(26, 79, 163, 0.10), 0 1px 4px rgba(0,0,0,0.04);
    --shadow-sm:      0 2px 12px rgba(26, 79, 163, 0.10);
    --glow:           0 0 48px rgba(26, 79, 163, 0.14);
    --radius:         18px;
    --radius-sm:      11px;
    --font-serif:     'Playfair Display', Georgia, serif;
    --font-sans:      'Inter', system-ui, sans-serif;
}






*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font-sans);
    color: var(--text);
    background: var(--bg);
    min-height: 100vh;
}

body::before { display: none; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }

.container {
    width: min(1240px, calc(100% - 32px));
    margin: 0 auto;
}

/* ─── Header ─── */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(22px);
    box-shadow: 0 2px 24px rgba(26,79,163,0.08);
}

.nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    min-height: 84px;
}

.brand { display: inline-flex; align-items: center; gap: 14px; }
.brand.compact { margin-bottom: 28px; }

.brand-logo {
    width: 66px; height: 66px;
    object-fit: contain;
    background: var(--bg-soft);
    border-radius: 18px;
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
}

.brand strong, h1, h2, h3, h4 { letter-spacing: -0.03em; }

.brand-title { color: var(--primary); letter-spacing: .01em; }

.footer-title, .tag, .handle, .song-meta, .text-link,
.schedule-time, .event-date, .muted-line { color: var(--primary); }

.status-pill { color: var(--amber); }

.brand small {
    display: block;
    color: var(--muted);
    margin-top: 3px;
    font-size: 0.8rem;
}

/* ─── Menu ─── */
.menu { display: flex; align-items: center; gap: 16px; }
.menu a {
    color: var(--muted);
    font-weight: 500;
    transition: color .18s;
    position: relative;
    padding-bottom: 2px;
}
.menu a::after {
    content: '';
    position: absolute;
    left: 0; bottom: -2px;
    width: 0; height: 2px;
    background: var(--primary);
    border-radius: 2px;
    transition: width .22s ease;
}
.menu a:hover { color: var(--primary); }
.menu a:hover::after { width: 100%; }

.menu-toggle {
    display: none;
    border: 0;
    background: transparent;
    color: var(--primary);
    font-size: 26px;
    cursor: pointer;
}

/* ─── Botones ─── */
.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 20px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-weight: 700;
    font-size: .9rem;
    transition: transform .18s, box-shadow .18s, background .18s, border-color .18s;
    cursor: pointer;
    text-decoration: none;
}
.button:hover { transform: translateY(-2px); }

.button.primary {
    color: #fff;
    background: linear-gradient(135deg, var(--primary) 0%, var(--royal) 100%);
    box-shadow: 0 4px 20px rgba(26,79,163,0.35);
}
.button.primary:hover {
    background: linear-gradient(135deg, var(--primary-strong) 0%, var(--royal-strong) 100%);
    box-shadow: 0 8px 32px rgba(26,79,163,0.45);
}

.button.royal {
    color: #fff;
    background: linear-gradient(135deg, #2b7bde 0%, var(--royal) 100%);
    box-shadow: 0 6px 28px rgba(14,53,114,0.38);
}

.button.amber {
    color: #fff;
    background: linear-gradient(135deg, var(--amber) 0%, var(--amber-strong) 100%);
    box-shadow: 0 6px 28px rgba(32,128,224,0.38);
}

.button.secondary, .button.ghost {
    color: var(--primary);
    background: transparent;
    border-color: var(--line);
}
.button.secondary:hover, .button.ghost:hover {
    border-color: var(--primary);
    background: var(--primary-glow);
    color: var(--primary-strong);
}

.button.danger {
    color: #fff;
    background: rgba(244, 63, 94, 0.12);
    border-color: rgba(244, 63, 94, 0.3);
}
.button.danger:hover { background: rgba(244, 63, 94, 0.22); }

.button.small { min-height: 36px; padding: 0 14px; font-size: .82rem; }

/* ─── Secciones ─── */
.section { padding: 56px 0; }

.section.section-compact {
    padding-top: 18px;
    padding-bottom: 18px;
}

.section.alt {
    background: var(--bg-soft);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.eyebrow {
    display: inline-block;
    margin-bottom: 14px;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: .2em;
    font-size: 11px;
    font-weight: 800;
    background: var(--primary-glow);
    border: 1px solid rgba(26,79,163,0.18);
    padding: 4px 12px;
    border-radius: 999px;
}

h1, h2 {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    line-height: .96;
    margin: 0 0 14px;
    color: var(--text);
}
h1 { font-size: clamp(2.8rem, 7vw, 5.4rem); }
h2 { font-size: clamp(2rem, 4.5vw, 3.6rem); }
h3 { font-size: 1.2rem; margin-top: 0; margin-bottom: 8px; }

.lead, .section-heading p, .card p, .site-footer p,
.admin-top p, .auth-copy, .lyrics-block {
    color: var(--muted);
    line-height: 1.8;
}

/* ─── Cards ─── */
.card, .hero-stats li, .assignment-card, .auth-helper, .admin-shell .card {
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: var(--shadow);
    border-radius: var(--radius);
}
.card { padding: 24px; }

/* ─── Hero ─── */
.hero { padding: 72px 0 36px; }

.hero-grid, .two-col, .app-banner, .footer-grid, .song-columns {
    display: grid;
    gap: 28px;
}

.hero-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(400px, 0.95fr);
    align-items: center;
}

.hero-elegant { position: relative; }

/* Hero simplificado para la nueva home */
.hero-simple {
    padding: 80px 0 60px;
    text-align: center;
    background: linear-gradient(160deg, #f0f4ff 0%, #fff 60%);
    border-bottom: 1px solid var(--line);
}
.hero-simple-inner { max-width: 640px; margin: 0 auto; }
.hero-simple h1 { font-size: clamp(2rem, 6vw, 3.2rem); margin: 10px 0 16px; }
.hero-simple .lead { font-size: 1.05rem; color: var(--muted); margin-bottom: 28px; line-height: 1.65; }

/* ── Hero carrusel de portada completa ── */
.hero-cover {
    position: relative;
    width: 100%;
    height: min(520px, 60vw);
    min-height: 260px;
    overflow: hidden;
    background: #111;
}
.cover-track { width: 100%; height: 100%; }
.cover-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity .6s ease;
}
.cover-slide.is-active { opacity: 1; }
.cover-slide img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.cover-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.65) 0%, transparent 55%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 32px 40px;
    color: #fff;
}
.cover-overlay h2 { margin: 0 0 6px; font-size: clamp(1.2rem,3vw,2rem); text-shadow: 0 2px 8px rgba(0,0,0,.4); }
.cover-overlay p  { margin: 0 0 14px; font-size: .95rem; opacity: .9; }
.cover-dots {
    position: absolute;
    bottom: 14px; left: 50%;
    transform: translateX(-50%);
    display: flex; gap: 7px;
}
.cover-dot {
    width: 9px; height: 9px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.5);
    cursor: pointer;
    padding: 0;
    transition: background .2s, transform .2s;
}
.cover-dot.is-active { background: #fff; transform: scale(1.25); }
.cover-arrow {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    background: rgba(0,0,0,.35);
    border: none;
    color: #fff;
    font-size: 2rem;
    line-height: 1;
    padding: 8px 14px;
    cursor: pointer;
    border-radius: 6px;
    transition: background .2s;
}
.cover-arrow:hover { background: rgba(0,0,0,.6); }
.cover-prev { left: 12px; }
.cover-next { right: 12px; }

/* ── Buscador en nav ── */
.nav-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.nav-search-input {
    width: 220px;
    padding: 7px 14px 7px 36px;
    border: 1.5px solid var(--line);
    border-radius: 999px;
    background: var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.868-3.834zm-5.242 1.156a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") no-repeat 11px center;
    font-size: .875rem;
    color: var(--text);
    transition: border-color .2s, width .25s;
    outline: none;
}
.nav-search-input:focus { border-color: var(--primary); width: 280px; }
.nav-search-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1.5px solid var(--line);
    border-radius: 12px;
    box-shadow: 0 8px 28px rgba(0,0,0,.13);
    list-style: none;
    padding: 6px 0;
    margin: 0;
    z-index: 1100;
    max-height: 320px;
    overflow-y: auto;
}
.nav-search-dropdown li {
    padding: 10px 18px;
    cursor: pointer;
    font-size: .92rem;
    color: var(--text);
    transition: background .12s;
    border-radius: 8px;
    margin: 2px 6px;
}
.nav-search-dropdown li:hover { background: var(--primary-glow); color: var(--primary); font-weight: 600; }

/* ── Modal canción (home) ── */
.home-song-modal-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 2000;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.home-song-modal-overlay.is-open { display: flex; }
.home-song-modal-overlay[hidden] { display: none !important; }
.home-song-modal {
    background: #fff;
    border-radius: 18px;
    width: 100%;
    max-width: 680px;
    max-height: 88vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0,0,0,.25);
    overflow: hidden;
}
.home-song-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 22px 24px 16px;
    border-bottom: 1px solid var(--line);
}
.home-song-modal-head h3 { margin: 0; font-size: 1.25rem; color: var(--text); }
.home-song-meta { font-size: .83rem; color: var(--muted); display: block; margin-top: 3px; }
.home-song-close {
    background: none; border: none; cursor: pointer;
    color: var(--muted); font-size: 1.3rem; line-height: 1;
    padding: 4px; border-radius: 6px; flex-shrink: 0;
    transition: color .15s;
}
.home-song-close:hover { color: var(--primary); }
.home-song-modal-body { overflow-y: auto; padding: 20px 24px; flex: 1; }
.home-song-chords {
    font-family: 'Courier New', monospace;
    font-size: .9rem;
    line-height: 1.8;
    white-space: pre-wrap;
    color: var(--text);
    margin: 0;
}

/* Highlight de canción enlazada */
@keyframes songHighlight {
    0%   { box-shadow: 0 0 0 4px var(--primary); }
    70%  { box-shadow: 0 0 0 4px var(--primary); }
    100% { box-shadow: none; }
}
.song-card-highlight {
    animation: songHighlight 2.5s ease forwards;
}
.song-title-btn {
    display: block;
    width: 100%;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    padding: 13px 18px;
    font-size: .97rem;
    font-weight: 600;
    color: var(--text);
    transition: color .15s;
}
.song-title-btn:hover { color: var(--primary); }
.song-list-search-wrap {
    margin-bottom: 16px;
}
.song-list {
    list-style: none;
    padding: 0; margin: 0;
    border: 1px solid var(--line);
    border-radius: 12px;
    overflow: hidden;
}
.song-list-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 18px;
    border-bottom: 1px solid var(--line);
    transition: background .12s;
}
.song-list-item:last-child { border-bottom: none; }
.song-list-item:hover { background: #f5f7ff; }
.song-list-link {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    text-decoration: none;
    color: inherit;
}
.song-list-title { font-weight: 700; font-size: .97rem; color: #1b1b1b; }
.song-list-artist { font-size: .82rem; color: var(--muted); }
.song-list-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}
.song-list-tag { margin-left: 8px; margin-bottom: 0; flex-shrink: 0; }
.song-list-empty { text-align: center; padding: 28px; color: var(--muted); font-size: .92rem; }

.song-view-toggle {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin: -12px auto 22px;
    flex-wrap: wrap;
}

.song-view-toggle .button {
    min-width: 110px;
}

.song-view-toggle .button.active {
    background: var(--primary-glow);
    border-color: rgba(124,45,62,.35);
    color: var(--primary);
}

.cal-event-btn {
    width: 100%;
    border: 0;
    background: transparent;
    padding: 0;
    text-align: left;
    cursor: pointer;
    font: inherit;
}

.cal-event-btn:hover {
    text-decoration: underline;
}

.modal-box-pdf {
    width: min(950px, 95vw);
    max-height: 95vh;
}

.pdf-modal-body {
    max-height: calc(95vh - 140px);
    overflow-y: auto;
    padding: 0;
}

.pdf-header {
    padding: 18px 20px;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
    position: sticky;
    top: 0;
    z-index: 10;
}

.pdf-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 18px;
}

.pdf-summary-item {
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fff;
    padding: 14px;
    display: grid;
    gap: 4px;
    text-align: center;
}

.pdf-summary-item strong {
    font-size: 1.35rem;
    color: var(--primary);
}

.pdf-summary-item span {
    color: var(--muted);
    font-size: .88rem;
}

.pdf-song-list {
    display: grid;
    gap: 0;
}

/* ≈≈≈ Página tipo CARTA ≈≈≈ */
.pdf-song-page {
    /* Tamaño letra US: 8.5" x 11" = 816px × 1056px @ 96dpi */
    width: 816px;
    height: 1056px;
    margin: 0 auto 20px;
    padding: 48px 40px;
    border: 1px solid var(--line);
    border-radius: 0;
    background: #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    font-size: 14px;
    line-height: 1.6;
}

/* Marca de agua (watermark) */
.pdf-song-page::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
    width: 900px;
    height: 700px;
    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 300 300"><defs><linearGradient id="grad" x1="0%" y1="0%" x2="100%" y2="100%"><stop offset="0%25" style="stop-color:rgba(26,79,163,0.04)"/><stop offset="100%25" style="stop-color:rgba(26,79,163,0.08)"/></linearGradient></defs><circle cx="150" cy="150" r="100" fill="none" stroke="url(%23grad)" stroke-width="1.5" stroke-dasharray="5,5" opacity="0.6"/><rect x="40" y="40" width="220" height="220" fill="none" stroke="rgba(26,79,163,0.05)" stroke-width="1"/><text x="150" y="145" text-anchor="middle" font-size="48" font-weight="700" fill="rgba(26,79,163,0.08)" font-family="Arial,sans-serif" letter-spacing="2">CENTRO</text><text x="150" y="200" text-anchor="middle" font-size="48" font-weight="700" fill="rgba(26,79,163,0.08)" font-family="Arial,sans-serif" letter-spacing="2">VIDA</text></svg>') center/contain no-repeat;
    opacity: 0.3;
    pointer-events: none;
    z-index: 0;
}

.pdf-song-page > * {
    position: relative;
    z-index: 1;
}

.pdf-song-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--primary);
}

.pdf-song-head > div:first-child {
    flex: 1;
}

.pdf-song-head h4 {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--text);
    line-height: 1.3;
}

.pdf-song-head p {
    margin: 4px 0 0;
    font-size: 0.9rem;
    color: var(--muted);
}

.pdf-song-head .badge {
    white-space: nowrap;
    font-size: 0.8rem;
}

.pdf-song-columns {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    flex: 1;
    overflow: hidden;
}

.pdf-label {
    display: inline-block;
    margin-bottom: 6px;
    font-size: .7rem;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--primary);
    font-weight: 600;
}

.pdf-song-text {
    margin: 0;
    padding: 16px 18px;
    border-radius: 8px;
    background: #f8fbff;
    border: 1px solid var(--line);
    white-space: pre-wrap;
    word-wrap: break-word;
    line-height: 2;
    font-family: 'Georgia', 'Times New Roman', serif;
    font-size: 13.5px;
    flex: 1;
    overflow: auto;
    max-height: 600px;
}
/* Acordes en negrita azul dentro del pdf-song-text */
.pdf-song-text .song-chord-line {
    color: var(--primary);
    font-weight: 900;
    font-family: 'Inter', 'Arial', sans-serif;
    font-size: .84rem;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.pdf-song-text .song-section-line {
    color: #7c3aed;
    font-weight: 900;
    font-family: 'Inter', 'Arial', sans-serif;
    font-size: .72rem;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.pdf-song-text .song-lyric-line {
    color: var(--text);
    font-weight: 400;
}

.pdf-song-lyrics {
    background: #fbfbfb;
}

.pdf-notes {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    background: rgba(124,45,62,.04);
    border: 1px solid rgba(124,45,62,.12);
    font-size: 0.85rem;
}

.pdf-notes p {
    margin: 4px 0 0;
    color: var(--muted);
    line-height: 1.5;
}

/* Adaptativo para pantallas */
@media (max-width: 900px) {
    .pdf-song-page {
        width: 100%;
        height: auto;
        max-width: 600px;
        margin: 0 auto 16px;
    }
    
    .pdf-summary, .pdf-song-columns {
        grid-template-columns: 1fr;
    }

    .pdf-song-head {
        flex-direction: column;
    }
}

/* Impresión: Optimizar para PDF */
@media print {
    .pdf-song-page {
        width: 100%;
        height: auto;
        margin: 0;
        padding: 40px;
        page-break-after: always;
        box-shadow: none;
        border: none;
        border-radius: 0;
    }
    
    .pdf-header, .form-actions {
        display: none !important;
    }
    
    .pdf-modal-body {
        max-height: none;
        overflow: visible;
    }
    
    .modal-box-pdf {
        width: 100%;
        max-width: none;
    }
}

.songs-mobile-list {
    display: none;
}

.songs-reading-list {
    margin-top: 18px;
    display: grid;
    gap: 18px;
}

.public-song-reading-card {
    padding: 26px;
    border-radius: 22px;
}

.public-song-reading-card .song-head {
    align-items: center;
    margin-bottom: 16px;
}

.song-reading-body {
    margin-top: 16px;
}

.song-reading-sheet {
    min-height: 180px;
    font-size: 1rem;
    line-height: 2;
    background: linear-gradient(180deg, #f4f8ff 0%, #eef4ff 100%);
}

#songs-library.songs-view-list .public-song-card {
    display: none;
}

#songs-library.songs-view-list .songs-mobile-list {
    display: block;
}

#songs-library.songs-view-reading .public-song-card,
#songs-library.songs-view-reading .songs-mobile-list {
    display: none;
}

#songs-library.songs-view-reading .songs-reading-list {
    display: grid;
}

/* Grid de canciones en home (legacy) */
.home-songs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
}

.hero-elegant::after {
    content: '';
    position: absolute;
    right: 6%; top: 60px;
    width: 180px; height: 260px;
    border: 1px solid var(--line);
    border-radius: 90px;
    transform: rotate(12deg);
    pointer-events: none;
}

.hero-elegant::before {
    content: '';
    position: absolute;
    left: 0; top: -30px;
    width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(26,79,163,0.09), transparent 70%);
    pointer-events: none;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 26px 0 32px; }

.hero-stats {
    list-style: none;
    padding: 0; margin: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.hero-stats li { padding: 16px; }
.hero-stats strong {
    display: block; margin-bottom: 4px;
    font-size: 1.8rem;
    background: linear-gradient(135deg, var(--primary), var(--royal));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.hero-stats span { color: var(--muted); font-size: .88rem; }

/* ─── Hero Slider ─── */
.hero-slider {
    position: relative;
    min-height: 540px;
    overflow: hidden;
    padding: 0;
    border-radius: var(--radius);
    box-shadow: 0 20px 60px rgba(26,79,163,0.20);
}
.slide {
    position: absolute; inset: 0;
    opacity: 0; transform: scale(1.03);
    transition: opacity .5s ease, transform .5s ease;
}
.slide.is-active { opacity: 1; transform: scale(1); }
.slide img { width: 100%; height: 100%; object-fit: cover; }

.slide-overlay {
    position: absolute;
    left: 22px; right: 22px; bottom: 22px;
    padding: 22px;
    background: linear-gradient(to bottom, rgba(14,53,114,0.08), rgba(14,53,114,0.82));
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 16px;
    backdrop-filter: blur(8px);
}

.slider-dots {
    position: absolute;
    left: 22px; bottom: 16px;
    display: flex; gap: 8px;
    z-index: 2;
}
.slider-dot {
    width: 10px; height: 10px;
    padding: 0; border-radius: 999px; border: 0;
    background: rgba(255,255,255,.22);
    cursor: pointer;
    transition: background .2s, width .2s;
}
.slider-dot.is-active { background: #fff; width: 28px; }

/* ─── Section heading ─── */
.section-heading { max-width: 700px; margin-bottom: 28px; }

/* ─── Content grids ─── */
.schedule-grid, .channel-grid, .event-grid, .gallery-grid,
.songs-preview-list, .stats-grid, .admin-grid, .songs-library {
    display: grid; gap: 18px;
}
.schedule-grid, .gallery-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.channel-grid, .event-grid, .songs-preview-list,
.admin-grid, .stats-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.songs-library { grid-template-columns: 1fr; }

/* ─── Tag/Badge ─── */
.tag {
    display: inline-flex; align-items: center; gap: 6px;
    margin-bottom: 12px; padding: 4px 12px;
    border-radius: 999px;
    background: var(--primary-glow);
    border: 1px solid rgba(124,45,62,.22);
    font-size: .78rem; font-weight: 700;
    color: var(--primary);
    letter-spacing: .04em;
}

.schedule-card, .channel-card, .event-card, .song-preview-card,
.gallery-card, .public-song-card, .songs-hero-card { height: 100%; }

.muted-line { margin-top: 10px; }
.channel-action { margin-top: 14px; }
.spotify-embed { margin-top: 20px; display: grid; gap: 18px; }
.two-col { grid-template-columns: 1.05fr 0.95fr; align-items: start; }
.songs-preview-grid { align-items: stretch; }

/* ─── Gallery ─── */
.gallery-card { overflow: hidden; padding: 0; }
.gallery-card img {
    width: 100%; height: 230px; object-fit: cover;
    transition: transform .4s ease;
}
.gallery-card:hover img { transform: scale(1.04); }
.gallery-copy { padding: 20px; }

.private-banner { grid-template-columns: 1fr auto; align-items: center; }

/* ─── Footer ─── */
.site-footer {
    padding: 40px 0 56px;
    border-top: 2px solid var(--line);
    background: linear-gradient(180deg, #f7faff 0%, #eef3fc 100%);
}
.footer-grid { grid-template-columns: 1.1fr 0.8fr 1fr; align-items: start; }
.footer-logo {
    width: 110px; margin-bottom: 14px;
    border-radius: 26px; background: var(--bg-soft);
    border: 1px solid var(--line);
}
.site-footer a { display: block; color: var(--muted); margin-top: 8px; transition: color .18s; }
.site-footer a:hover { color: var(--primary); }

/* ─── Canciones ─── */
.song-head, .panel-heading, .admin-top {
    display: flex; align-items: flex-start;
    justify-content: space-between; gap: 18px;
}
.song-columns { grid-template-columns: 1fr 1fr; margin-top: 22px; }
.public-song-card .song-columns { grid-template-columns: 1fr; }
.lyrics-block { white-space: normal; }

.chord-sheet {
    margin: 0; min-height: 220px;
    padding: 22px 24px; overflow: auto;
    border-radius: 14px;
    background: #f8fbff;
    border: 1px solid var(--line);
    color: var(--text);
    line-height: 1.4;
    font-family: 'Georgia', 'Times New Roman', serif;
    font-size: 1rem;
    white-space: normal;
}
.chord-sheet .song-line {
    display: block;
    white-space: pre-wrap;
    line-height: 1.4;
}
.chord-sheet .song-line-empty {
    display: none;
}
.chord-sheet .song-chord-line {
    color: var(--primary);
    font-weight: 900;
    font-family: 'Inter', 'Arial', sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0;
}
.chord-sheet .song-section-line {
    color: #7c3aed;
    font-weight: 900;
    font-family: 'Inter', 'Arial', sans-serif;
    font-size: .8rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(124,58,237,.18);
    padding-bottom: 2px;
    margin-top: 24px;
    margin-bottom: 6px;
    display: block;
}
.chord-sheet .song-lyric-line {
    color: var(--text);
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1.5;
}
.transpose-controls { display: flex; flex-wrap: wrap; gap: 10px; }

.chord-quick-tools {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.structure-tools .button {
    border-style: dashed;
}

.variant-tools .button {
    border-color: rgba(244,63,94,.35);
}

.modal-song-box {
    width: min(820px, 100%);
    background: #fff;
    border-color: rgba(0,0,0,.08);
}

.modal-song-box .modal-head {
    background: #fff;
    border-bottom-color: rgba(0,0,0,.08);
}

.modal-song-box .modal-head h3,
.modal-song-box .song-modal-section h4,
.modal-song-box label {
    color: #1b1b1b;
}

.modal-song-box .module-hint {
    color: #5f5f5f;
}

.modal-song-box input,
.modal-song-box textarea,
.modal-song-box select {
    background: #fff;
    color: #1b1b1b;
    border-color: rgba(0,0,0,.18);
}

.modal-song-box input:focus,
.modal-song-box textarea:focus,
.modal-song-box select:focus {
    border-color: var(--danger);
    box-shadow: 0 0 0 3px rgba(244,63,94,.18);
}

.song-modal-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,.02);
    margin-bottom: 14px;
    border-left: 4px solid var(--danger);
}

.song-modal-logo {
    width: 44px;
    height: 44px;
    object-fit: contain;
    border-radius: 12px;
    background: #fff;
    border: 1px solid var(--line);
    padding: 4px;
}

.song-modal-brand strong { display: block; font-size: .92rem; }
.song-modal-brand p {
    margin: 3px 0 0;
    color: var(--muted);
    font-size: .8rem;
}

.song-modal-section {
    border: 1px solid rgba(0,0,0,.12);
    border-radius: 14px;
    padding: 14px;
    background: #fff;
    display: grid;
    gap: 10px;
}

.song-modal-section h4 {
    margin: 0;
    font-size: .9rem;
    color: var(--text);
}

.chord-preview-wrap {
    margin-top: 10px;
    display: grid;
    gap: 8px;
}

.chord-sheet-preview {
    min-height: 140px;
    max-height: 240px;
    line-height: 1.6;
    font-size: clamp(.76rem, 2.9vw, .92rem);
}

.song-layout-preview {
    border: 1px solid rgba(0,0,0,.12);
    border-radius: 14px;
    background: #f7f8fa;
    padding: 14px;
    display: grid;
    gap: 12px;
    max-height: 460px;
    overflow: auto;
    max-width: 420px;
    margin: 0 auto;
}

.layout-head {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 8px;
    align-items: flex-start;
}

.layout-head h4 {
    margin: 0;
    color: #1b1b1b;
    font-size: 1.08rem;
}

.layout-head p {
    margin: 2px 0 0;
    color: #6d6d6d;
    font-size: .85rem;
}

.layout-meta {
    color: #5f5f5f;
    font-size: .78rem;
    white-space: nowrap;
}

.section-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.section-chip {
    font-size: .72rem;
    border: 1px solid rgba(0,0,0,.16);
    border-radius: 999px;
    padding: 5px 9px;
    color: #333;
    background: #fff;
}

.sections-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    max-width: 420px;
    margin: 0 auto;
}

.section-card {
    border-radius: 12px;
    padding: 10px 12px;
    box-shadow: 0 2px 6px rgba(0,0,0,.06);
    border: 1px solid rgba(0,0,0,.08);
}

.section-card header {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
}

.section-label {
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: #1a4fa3;
    padding: 2px 10px;
    border-radius: 20px;
    background: rgba(26,79,163,.1);
}

.section-bullet {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: inline-grid;
    place-items: center;
    color: #d82f39;
    border: 1px solid rgba(216,47,57,.35);
    font-size: .78rem;
}

.section-body {
    display: grid;
    gap: 4px;
}

.song-line {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    align-items: flex-start;
}

.measure-block {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: flex-start;
    padding: 3px 6px;
    border-radius: 8px;
    background: rgba(0,0,0,.02);
    border: 1px solid rgba(0,0,0,.06);
}

.measure-divider {
    display: inline-grid;
    place-items: center;
    color: #7b7b7b;
    font-weight: 700;
    padding: 0 4px;
}

.measure-plain {
    display: inline-flex;
    flex-direction: column;
    gap: 2px;
    min-width: 70px;
    line-height: 1.55;
    white-space: pre-wrap;
}

.song-line.plain {
    color: #232323;
    font-size: .92rem;
    line-height: 1.55;
}

.measure-chords-text {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    color: #1a4fa3;
    font-size: 12px;
    font-weight: 900;
    white-space: pre;
    line-height: 1.2;
    letter-spacing: .03em;
}

.measure-lyrics-text {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    color: #1b1b1b;
    font-size: 12px;
    white-space: pre;
    line-height: 1.2;
}

/* Header de vista previa de canción */
.layout-song-title { margin: 0; font-size: 1.05rem; color: #1b1b1b; font-weight: 800; }
.layout-artist { margin: 2px 0 0; font-size: .82rem; color: #5f5f5f; }
.layout-meta-chips { display: flex; flex-wrap: wrap; gap: 5px; align-items: flex-start; }
.prev-meta-chip {
    font-size: .72rem; font-weight: 700; padding: 2px 9px; border-radius: 20px; white-space: nowrap;
}
.prev-meta-chip.key  { background: #dbeafe; color: #1a4fa3; }
.prev-meta-chip.bpm  { background: #dcfce7; color: #166534; }

.measure-cell {
    display: inline-grid;
    grid-template-rows: auto auto;
    min-width: 8px;
}

.pair-chord {
    color: #0f4ea1;
    font-weight: 700;
    font-size: .78rem;
    line-height: 1.1;
}

.pair-lyric {
    color: #202020;
    font-size: .9rem;
    line-height: 1.35;
    white-space: pre;
}

/* ─── Admin Shell ─── */
.admin-body { min-height: 100vh; }

.admin-shell {
    width: min(1360px, calc(100% - 32px));
    margin: 32px auto;
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 22px;
}
.admin-sidebar { position: sticky; top: 24px; align-self: start; }
.admin-nav { display: grid; gap: 6px; }
.admin-nav a {
    padding: 11px 14px;
    border-radius: var(--radius-sm);
    color: var(--muted); font-weight: 500;
    transition: color .18s, background .18s;
}
.admin-nav a:hover, .admin-nav a.active {
    color: var(--text);
    background: var(--primary-glow);
}
.admin-content { display: grid; gap: 22px; }
.admin-user-box { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line); }
.admin-user-box strong { display: block; margin-bottom: 4px; }
.admin-user-box p { color: var(--muted); margin: 0 0 14px; line-height: 1.6; font-size: .9rem; }
.admin-logout { width: 100%; }
.admin-actions { display: flex; flex-wrap: wrap; gap: 10px; }

/* ─── Stats ─── */
.stat-card strong {
    display: block;
    margin: 8px 0 4px;
    font-size: 2.4rem;
    background: linear-gradient(135deg, var(--primary), var(--royal));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ─── Assignments ─── */
.assignment-list, .mini-list, .mini-gallery { display: grid; gap: 12px; }

.assignment-card {
    display: grid;
    grid-template-columns: 1.2fr 1fr auto;
    gap: 16px; padding: 16px 20px;
    align-items: center;
}
.assignment-card p { margin: 5px 0 0; color: var(--muted); font-size: .9rem; }

.status-pill {
    display: inline-flex;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--primary-glow);
    border: 1px solid rgba(26, 79, 163, 0.22);
    font-size: .82rem; font-weight: 700; color: var(--primary);
    white-space: nowrap;
}
.status-pill.confirmado { background: rgba(74,222,128,.12); border-color: rgba(74,222,128,.22); color: var(--success); }

.mini-list div, .mini-gallery div {
    padding: 13px 16px; border-radius: 14px;
    border: 1px solid var(--line);
    background: var(--bg-soft);
    transition: border-color .18s;
}
.mini-list div:hover, .mini-gallery div:hover { border-color: var(--primary); }
.mini-list strong, .mini-gallery span { display: block; }
.mini-list span { color: var(--muted); font-size: .9rem; }

.mini-gallery { grid-template-columns: repeat(3, minmax(0,1fr)); }
.mini-gallery img { width: 100%; height: 90px; object-fit: cover; margin-bottom: 8px; border-radius: 10px; }

/* ─── Auth ─── */
.auth-page { min-height: 100vh; display: grid; place-items: center; padding: 32px 16px; background: linear-gradient(160deg, #eef3fc 0%, #fff 60%); }
.auth-shell { width: min(520px, 100%); }
.auth-card { padding: 34px; }
.auth-brand { margin-bottom: 22px; }
.auth-form { display: grid; gap: 16px; }
.auth-form label { display: grid; gap: 7px; font-weight: 600; }
.auth-form span { color: var(--text); }
.auth-form input {
    width: 100%; min-height: 50px; padding: 0 16px;
    border-radius: 14px; border: 1.5px solid var(--line);
    background: #f7faff; color: var(--text);
    outline: none; transition: border-color .2s, box-shadow .2s;
}
.auth-form input:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(26,79,163,0.12);
}
.auth-submit { width: 100%; margin-top: 6px; }
.auth-helper { margin-top: 18px; padding: 18px; }

/* ─── Alerts ─── */
.alert { padding: 13px 16px; border-radius: 14px; margin-bottom: 16px; font-weight: 600; }
.alert.error   { color: #c0392b; background: rgba(192,57,43,0.08);  border: 1px solid rgba(192,57,43,0.22); }
.alert.success { color: #1a7a4f; background: rgba(26,122,79,0.08); border: 1px solid rgba(26,122,79,0.22); }

/* ===================================================
   CALENDARIO VISUAL MENSUAL
   =================================================== */
.cal-nav {
    display: flex; align-items: center;
    justify-content: space-between; gap: 12px;
    margin-bottom: 20px;
}
.cal-nav h3 {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-size: 1.6rem; margin: 0;
    color: var(--text); letter-spacing: -.02em;
}

.cal-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0,1fr));
    gap: 1px;
    background: var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--line);
}

.cal-day-name {
    padding: 10px 6px; text-align: center;
    font-size: .72rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: .12em;
    color: var(--primary);
    background: var(--bg-soft);
}

.cal-cell {
    min-height: 90px; padding: 8px;
    background: var(--surface);
    transition: background .15s;
}
.cal-cell:hover { background: var(--primary-glow); }
.cal-cell.empty { background: var(--bg-soft); opacity: .5; }
.cal-cell.today {
    background: rgba(26,79,163,0.07);
    outline: 2px solid var(--primary);
    outline-offset: -2px;
}

.cal-date {
    display: inline-flex;
    width: 26px; height: 26px;
    align-items: center; justify-content: center;
    border-radius: 999px;
    font-size: .82rem; font-weight: 700;
    color: var(--muted); margin-bottom: 4px;
}
.cal-cell.today .cal-date { background: var(--primary); color: #fff; }

.cal-events { display: flex; flex-direction: column; gap: 4px; }

.cal-event {
    font-size: .68rem; font-weight: 600;
    padding: 2px 7px; border-radius: 6px;
    background: var(--primary-glow);
    border-left: 2px solid var(--primary);
    color: var(--text);
    white-space: normal;
    overflow: hidden;
    display: grid;
    gap: 1px;
    line-height: 1.2;
}
.cal-event-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cal-event-meta {
    font-size: .61rem;
    color: var(--muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cal-event:nth-child(2) { background: rgba(44,82,130,.18); border-left-color: var(--royal); }
.cal-event:nth-child(3) { background: rgba(124,45,62,.14); border-left-color: var(--wine); }
.cal-event-more { font-size: .65rem; color: var(--muted); padding: 1px 4px; }

/* ── Tarjeta de evento en el calendario ── */
.cal-event-card {
    background: var(--primary-glow);
    border-left: 2px solid var(--primary);
    border-radius: 6px;
    padding: 3px 7px;
    display: flex; flex-direction: row; align-items: center; gap: 4px;
    width: 100%; text-align: left; border-top: 0; border-right: 0; border-bottom: 0;
    cursor: pointer; transition: background .15s;
}
.cal-event-card:hover { background: rgba(26,79,163,.18); }
.cal-event-card:nth-child(2) { background: rgba(44,82,130,.15); border-left-color: var(--royal); }
.cal-event-card:nth-child(2):hover { background: rgba(44,82,130,.25); }
.cal-event-card:nth-child(3) { background: rgba(124,45,62,.12); border-left-color: var(--wine); }
.cal-event-card:nth-child(3):hover { background: rgba(124,45,62,.2); }
.cal-ev-time {
    font-size: .6rem; font-weight: 700; color: var(--primary);
    white-space: nowrap; flex-shrink: 0; opacity: .8;
}
.cal-event-title {
    font-size: .68rem; font-weight: 700; color: var(--text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ── Modal preview ── */
.modal-preview-box { max-width: 560px; }

/* Botones de icono para tablas */
.icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 1px solid transparent;
    background: transparent;
    cursor: pointer;
    font-size: 1rem;
    transition: background .15s, border-color .15s;
    padding: 0;
    line-height: 1;
}
.icon-btn.preview { color: #1a4fa3; }
.icon-btn.preview:hover { background: #dbeafe; border-color: #93c5fd; }
.icon-btn.edit    { color: #b45309; }
.icon-btn.edit:hover    { background: #fef3c7; border-color: #fcd34d; }
.icon-btn.delete  { color: #dc2626; }
.icon-btn.delete:hover  { background: #fee2e2; border-color: #fca5a5; }
.modal-song-preview-box {
    max-width: 600px;
    width: min(600px, 100%);
}
.modal-song-preview-box .song-layout-preview {
    max-height: 62vh;
    overflow-y: auto;
    max-width: none;
    margin: 0;
    background: #f7f8fa;
    border-radius: 12px;
    padding: 16px;
}
.transpose-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    background: #f0f4ff;
    border: 1px solid #dbeafe;
    border-radius: 10px;
    padding: 8px 12px;
    margin-bottom: 14px;
}
.transpose-label {
    flex: 1;
    text-align: center;
    font-size: .85rem;
    color: #1b1b1b;
    white-space: nowrap;
}
.preview-meta-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.preview-meta-item { display: flex; flex-direction: column; gap: 2px; }
.preview-assign-chip { display: flex; align-items: center; gap: 6px; background: var(--bg-soft); border-radius: 8px; padding: 6px 10px; }

/* ===================================================
   CRUD DE CANCIONES (tabla + formulario)
   =================================================== */
.songs-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius);
    border: 1px solid var(--line);
}
.songs-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.songs-table th {
    padding: 13px 16px; text-align: left;
    background: var(--bg-soft);
    color: var(--primary);
    font-size: .76rem; text-transform: uppercase;
    letter-spacing: .1em; font-weight: 800;
    border-bottom: 1px solid var(--line);
}
.songs-table td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--line-soft);
    vertical-align: middle; color: var(--text);
}
.songs-table tr:last-child td { border-bottom: 0; }
.songs-table tr:hover td { background: var(--bg-soft); }
.songs-table .actions { display: flex; gap: 8px; justify-content: flex-end; }

.badge { display: inline-flex; padding: 3px 10px; border-radius: 999px; font-size: .74rem; font-weight: 700; }
.badge.active  { background: rgba(26,122,79,.12); color: var(--success); border: 1px solid rgba(26,122,79,.22); }
.badge.inactive{ background: rgba(192,57,43,.08); color: var(--danger);  border: 1px solid rgba(192,57,43,.18); }
.badge.public  { background: var(--primary-glow); color: var(--primary); border: 1px solid rgba(26,79,163,.22); }
/* Roles musicales — azul */
.badge.role-music { background: rgba(26,79,163,.10); color: #1a4fa3; border: 1px solid rgba(26,79,163,.25); }
/* Roles técnicos — violeta/morado */
.badge.role-tech  { background: rgba(124,58,237,.12); color: #7c3aed; border: 1px solid rgba(124,58,237,.28); }

.song-form { display: grid; gap: 18px; }
.song-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.song-form-grid.cols3 { grid-template-columns: 1fr 1fr 1fr; }

.form-field { display: grid; gap: 7px; }
.form-field label {
    font-size: .82rem; font-weight: 700;
    color: var(--muted); text-transform: uppercase; letter-spacing: .08em;
}
.form-field input,
.form-field textarea,
.form-field select {
    width: 100%; padding: 10px 14px;
    border-radius: var(--radius-sm);
    border: 1.5px solid var(--line);
    background: #f7faff;
    color: var(--text); outline: none;
    transition: border-color .2s, box-shadow .2s;
    resize: vertical;
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(26,79,163,0.12);
}
.form-field textarea { min-height: 140px; }
.form-field.full { grid-column: 1 / -1; }

.checkboxes { display: flex; flex-wrap: wrap; gap: 20px; }
.checkboxes label { display: flex; align-items: center; gap: 8px; font-weight: 600; cursor: pointer; }
.checkboxes input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--primary); cursor: pointer; padding: 0; }

.form-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ─── Facebook embed ─── */
.fb-section {
    width: 100%; max-width: 900px; margin: 0 auto;
    border-radius: var(--radius); overflow: hidden;
    border: 1px solid var(--line);
    background: var(--surface); box-shadow: var(--shadow);
}
.fb-section iframe {
    display: block; width: 100%; min-height: 600px;
    border: none; border-radius: var(--radius);
}

/* ─── Responsive 1080 ─── */
@media (max-width: 1080px) {
    .hero-grid, .footer-grid, .two-col, .private-banner,
    .schedule-grid, .channel-grid, .event-grid, .gallery-grid,
    .songs-preview-list, .stats-grid, .admin-grid, .mini-gallery,
    .song-columns, .song-form-grid, .song-form-grid.cols3 {
        grid-template-columns: 1fr 1fr;
    }
    .admin-shell { grid-template-columns: 1fr; }
    .admin-sidebar { position: static; }
    .assignment-card { grid-template-columns: 1fr; }
    .cal-cell { min-height: 70px; }
}

/* ─── Responsive 760 ─── */
@media (max-width: 760px) {
    .menu {
        position: fixed;
        inset: 80px 14px auto 14px;
        display: none; flex-direction: column; align-items: stretch;
        padding: 16px;
        background: rgba(255,255,255,.98);
        border: 1px solid var(--line); border-radius: 18px;
        box-shadow: var(--shadow); backdrop-filter: blur(14px);
    }
    .menu.is-open { display: flex; }
    .menu-toggle { display: inline-block; }

    .hero-grid, .hero-stats, .schedule-grid, .channel-grid,
    .event-grid, .gallery-grid, .songs-preview-list, .footer-grid,
    .two-col, .song-columns, .private-banner, .stats-grid,
    .admin-grid, .mini-gallery, .song-form-grid, .song-form-grid.cols3 {
        grid-template-columns: 1fr;
    }

    .hero-slider { min-height: 400px; }
    .song-head, .admin-top, .panel-heading, .cal-nav { flex-direction: column; gap: 10px; }
    .brand-logo { width: 56px; height: 56px; }
    .cal-cell { min-height: 56px; }
    .cal-day-name { font-size: .62rem; padding: 8px 2px; }

    .songs-table td:nth-child(3), .songs-table th:nth-child(3),
    .songs-table td:nth-child(4), .songs-table th:nth-child(4) { display: none; }

    .song-view-toggle { display: flex; }

    .public-song-card .chord-sheet,
    .public-song-reading-card .chord-sheet,
    .song-reading-sheet {
        font-size: 1.08rem;
        line-height: 2.05;
        padding: 16px 14px;
    }

    .chord-sheet .song-chord-line {
        font-size: .95rem;
        letter-spacing: .06em;
    }

    .chord-sheet .song-section-line {
        font-size: .78rem;
    }

    #modal-song .modal-box {
        width: calc(100vw - 12px);
        max-width: calc(100vw - 12px);
        margin: 0 auto;
        border-radius: 14px;
    }

    #modal-song .modal-body {
        padding: 14px;
    }

    #modal-song .song-form-grid,
    #modal-song .song-form-grid.cols3 {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    #modal-song .form-field.full {
        grid-column: 1;
    }

    #modal-song .form-field input,
    #modal-song .form-field textarea,
    #modal-song .form-field select {
        max-width: 100%;
        box-sizing: border-box;
    }

    #modal-song .form-actions {
        flex-direction: column;
    }

    #modal-song .form-actions .button {
        width: 100%;
        justify-content: center;
    }
}

/* Editor de canciones: nunca permitir scroll horizontal */
#modal-song {
    overflow-x: hidden;
}

#modal-song .modal-box,
#modal-song .modal-body,
#modal-song .song-form,
#modal-song .song-form-grid,
#modal-song .form-field {
    min-width: 0;
    overflow-x: hidden;
}

#modal-song .form-field input,
#modal-song .form-field textarea,
#modal-song .form-field select {
    max-width: 100%;
    box-sizing: border-box;
}

#modal-song #song-chords {
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
    overflow-x: hidden;
    font-size: 17px !important;
    line-height: 1.9 !important;
}

.chord-editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
    padding: 8px 10px;
    background: var(--surface-alt, #f0f4fa);
    border: 1px solid var(--line, #d5dce8);
    border-radius: 8px 8px 0 0;
}
.chord-editor-toolbar + textarea {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-top: none;
}
.chord-editor-toolbar-label {
    font-size: .75rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-right: 4px;
}
.chord-section-btn {
    padding: 3px 10px;
    font-size: .78rem;
    font-weight: 700;
    font-family: Inter, system-ui, sans-serif;
    background: var(--primary-light, #e8eeff);
    color: var(--primary, #2563eb);
    border: 1.5px solid var(--primary, #2563eb);
    border-radius: 20px;
    cursor: pointer;
    transition: background .15s, color .15s;
    line-height: 1.6;
}
.chord-section-btn:hover {
    background: var(--primary, #2563eb);
    color: #fff;
}

.receipt-ticket {
    border: 1px dashed var(--line);
    border-radius: 14px;
    padding: 14px;
    background: #fff;
    display: grid;
    gap: 8px;
}

.receipt-ticket .ticket-head {
    text-align: center;
    font-weight: 800;
    color: var(--primary);
    letter-spacing: .04em;
    padding-bottom: 8px;
    border-bottom: 1px dashed var(--line);
}

.receipt-ticket .ticket-row {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    font-size: .9rem;
}

.receipt-ticket .ticket-row span {
    color: var(--muted);
}

.receipt-ticket .ticket-row strong {
    text-align: right;
}

.receipt-ticket .ticket-note {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed var(--line);
    color: var(--text);
    white-space: pre-wrap;
}


/* ===================================================
   MODALES — v3
   =================================================== */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(8px);
  display: grid;
  place-items: center;
  padding: 20px;
  overflow-y: auto;
}
.modal-overlay[hidden] { display: none !important; }

.modal-box {
  width: min(700px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface);
  box-shadow: 0 32px 80px rgba(0,0,0,.75);
  animation: slideUp .22s cubic-bezier(.22,1,.36,1);
}
.modal-box-sm { width: min(420px, 100%); }

@keyframes slideUp {
  from { opacity: 0; transform: translateY(24px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}

.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 2;
}
.modal-head h3 { margin: 0; font-size: 1.05rem; }

.modal-close {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.1rem;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  transition: background .15s, color .15s;
}
.modal-close:hover { background: rgba(255,255,255,.07); color: var(--text); }

.modal-body { padding: 24px; }

.modal-alert {
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  font-size: .9rem;
  margin-bottom: 16px;
}
.modal-alert.error   { background: rgba(244,63,94,.12);  color: #f43f5e; border: 1px solid rgba(244,63,94,.25); }
.modal-alert.success { background: rgba(52,211,153,.12); color: #34d399; border: 1px solid rgba(52,211,153,.25); }

/* ===================================================
   ADMIN PANEL LAYOUT
   =================================================== */
.admin-body { background: var(--bg); min-height: 100vh; }

.admin-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 20px;
  border-radius: 0;
  border-right: 1px solid var(--line);
  border-top: none;
  border-bottom: none;
  border-left: none;
}

.brand.compact { display: flex; align-items: center; gap: 12px; padding: 10px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 8px; text-decoration: none; }
.brand-logo    { width: 36px; height: 36px; object-fit: contain; }
.brand-title   { display: block; font-size: 1rem; color: var(--text); }
.brand.compact small { display: block; color: var(--muted); font-size: .73rem; }

.admin-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.admin-nav a {
  display: block;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  color: var(--muted);
  text-decoration: none;
  font-size: .88rem;
  transition: background .15s, color .15s;
}
.admin-nav a:hover { background: var(--primary-glow); color: var(--primary); }

.admin-user-box {
  border-top: 1px solid var(--line);
  padding-top: 16px;
  font-size: .82rem;
  display: grid;
  gap: 4px;
}
.admin-user-box strong { font-size: .92rem; color: var(--text); }
.admin-user-box p { color: var(--muted); margin: 0; }
.admin-logout { margin-top: 8px; font-size: .8rem; padding: 7px 14px; }

.admin-content {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  max-width: 1100px;
}

.admin-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.admin-top h1 { margin: 4px 0 8px; font-size: 1.7rem; }
.admin-top p  { color: var(--muted); margin: 0; max-width: 480px; }
.admin-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.stat-card        { padding: 22px; }
.stat-card strong { display: block; font-size: 2.4rem; font-weight: 800; color: var(--primary); margin: 6px 0 4px; }
.stat-card p      { color: var(--muted); font-size: .82rem; margin: 0; }

.panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.panel-heading h3 { margin: 2px 0 0; }

.actions { display: flex; gap: 8px; justify-content: flex-end; }

.assign-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  font-size: .88rem;
}
.assign-row > span:first-child { flex: 1; }

.badge.confirmado { background: rgba(52,211,153,.15);  color: #34d399; }
.badge.pendiente  { background: rgba(240,168,40,.15);   color: var(--amber); }
.badge.rechazado  { background: rgba(244,63,94,.12);   color: #f43f5e; }

@media (max-width: 900px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar {
    position: static;
    height: auto;
    flex-direction: row;
    flex-wrap: wrap;
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 12px 16px;
  }
  .brand.compact { display: none; }
    .admin-nav { flex-direction: column; gap: 8px; flex: none; width: 100%; }
    .admin-nav a { width: 100%; }
  .admin-user-box { display: none; }
  .admin-content { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .admin-top  { flex-direction: column; }
}

/* ===================================================
   MÓDULO IMÁGENES / HERO SLIDES
   =================================================== */
.slides-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 18px;
}
.slide-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
}
.slide-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  background: var(--bg-soft);
  overflow: hidden;
}
.slide-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.slide-card:hover .slide-thumb img { transform: scale(1.04); }
.slide-thumb-empty {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  font-size: 2.5rem;
  color: var(--muted);
}
.slide-order-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--primary);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  border-radius: 50%;
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.slide-info {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
}
@media (max-width: 600px) {
  .slides-grid { grid-template-columns: 1fr; }
}
.module-card {
    --module-accent: var(--primary);
    position: relative;
    border: 1px solid var(--line);
    border-radius: calc(var(--radius) + 2px);
    box-shadow: 0 16px 34px rgba(0,0,0,.24);
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}

.module-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--module-accent);
    opacity: .95;
}

.module-card + .module-card {
    margin-top: 8px;
}

.module-calendar { --module-accent: #638edc; }
.module-dashboard { --module-accent: #7c2d3e; }
.module-songs    { --module-accent: #7c2d3e; }
.module-users    { --module-accent: #7c2d3e; }

.dashboard-stats-grid {
    margin-top: 18px;
}

.app-module-strip {
    display: grid;
    gap: 16px;
    position: sticky;
    top: 20px;
    z-index: 40;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(14px);
}

/* Solo visible en móvil — en escritorio la sidebar ya navega */
@media (min-width: 901px) {
    .app-module-strip { display: none !important; }
}

.app-module-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.app-module-grid.is-limited {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.app-module-button {
    display: grid;
    gap: 6px;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
    transition: transform .18s, border-color .18s, background .18s;
}

.app-module-button:hover {
    transform: translateY(-2px);
    border-color: rgba(124,45,62,.35);
    background: linear-gradient(180deg, var(--primary-glow), rgba(255,255,255,.03));
}

.app-module-button.is-active {
    border-color: rgba(124,45,62,.48);
    background: linear-gradient(180deg, rgba(124,45,62,.22), rgba(255,255,255,.04));
    box-shadow: 0 0 0 1px rgba(124,45,62,.36) inset;
}

.app-module-button strong,
.app-chip-button strong {
    font-size: .92rem;
}

.app-module-button small {
    color: var(--muted);
    font-size: .76rem;
}

.app-module-icon,
.app-chip-button span {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    font-size: 1.15rem;
    background: var(--primary-glow);
    border: 1px solid rgba(124,45,62,.26);
}

.app-module-button.is-calendar .app-module-icon { background: rgba(99,142,220,.16); border-color: rgba(99,142,220,.28); }
.app-module-button.is-songs .app-module-icon { background: var(--primary-glow); border-color: rgba(124,45,62,.28); }
.app-module-button.is-users .app-module-icon { background: rgba(124,45,62,.16); border-color: rgba(124,45,62,.28); }

.cal-cell.is-dimmed {
    opacity: .35;
}

.cal-cell.is-highlighted {
    opacity: 1;
    box-shadow: inset 0 0 0 1px rgba(124,45,62,.45);
}

.cal-event.is-hidden {
    display: none;
}

.module-card .panel-heading {
    padding-bottom: 10px;
    border-bottom: 1px dashed rgba(255,255,255,.12);
}

.module-icon {
    display: inline-grid;
    place-items: center;
    width: 30px;
    height: 30px;
    margin-right: 8px;
    border-radius: 10px;
    background: var(--primary-glow);
    font-size: .95rem;
}

.module-hint {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: .8rem;
}

.panel-tools {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.song-search {
    min-width: 250px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.02);
    color: var(--text);
    outline: none;
}
.song-search:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-glow);
}

.cal-event-btn {
    border: 0;
    text-align: left;
    width: 100%;
    cursor: pointer;
}

.mobile-tabbar {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 210;
    padding: 4px 4px calc(4px + env(safe-area-inset-bottom));
    background: rgba(255,255,255,.97);
    backdrop-filter: blur(12px);
    border-top: 1px solid var(--line);
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    align-items: center;
}

.mobile-tabbar a {
    text-decoration: none;
    color: var(--muted);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px 2px;
    border-radius: 8px;
    font-size: 0; /* oculta texto */
    line-height: 1;
}

.mobile-tabbar a span {
    width: auto;
    height: auto;
    display: block;
    background: none !important;
    border-radius: 0;
    font-size: 22px;
    line-height: 1;
    flex-shrink: 0;
}

.mobile-tabbar a:active,
.mobile-tabbar a:hover {
    background: var(--primary-glow);
}

.mobile-tabbar a.is-active {
    background: var(--primary-glow);
    border: 1px solid rgba(124,45,62,.2);
}

.mobile-tabbar a.is-active span {
    background: none !important;
}

.songs-toolbar-card {
    display: grid;
    gap: 18px;
}

.app-chip-nav {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.app-chip-button {
    display: grid;
    justify-items: center;
    gap: 8px;
    text-align: center;
    padding: 16px 12px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}

.app-chip-button:hover {
    border-color: var(--primary);
    background: var(--primary-glow);
}

.songs-toolbar-search {
    display: grid;
}

.public-song-search {
    width: 100%;
    min-height: 50px;
    font-size: .96rem;
}

.search-empty-state {
    text-align: center;
}

.search-empty-state strong {
    display: block;
    margin-bottom: 8px;
}



@media (max-width: 1024px) {
    .admin-shell {
        width: min(100%, calc(100% - 16px));
        margin: 12px auto 0;
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .admin-sidebar {
        position: static;
        height: auto;
        overflow: visible;
        padding: 12px 12px 10px;
        border-right: none;
        border-bottom: 1px solid var(--line);
        border-radius: var(--radius);
    }

    .admin-nav {
        flex-direction: column;
        flex-wrap: nowrap;
        gap: 8px;
        overflow: visible;
        padding-bottom: 0;
    }

    .admin-nav a {
        width: 100%;
        flex: 0 0 auto;
        display: flex;
        align-items: center;
        min-height: 42px;
    }

    .admin-content {
        max-width: none;
        padding: 16px 12px 96px;
        gap: 18px;
    }

    .app-module-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .panel-tools,
    .song-search {
        width: 100%;
        min-width: 0;
    }

    .mobile-tabbar {
        display: grid;
    }
}

@media (max-width: 768px) {
    .admin-sidebar {
        padding: 10px;
    }

    .admin-nav a {
        min-height: 44px;
        font-size: .86rem;
    }

    .songs-table .actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .form-actions {
        width: 100%;
    }
}

@media (max-width: 900px) {
    .app-module-strip {
        top: 12px;
    }
    .app-module-grid,
    .app-chip-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .panel-tools { width: 100%; }
    .song-search { min-width: 0; width: 100%; }
    .mobile-tabbar { display: grid; }
    .admin-content { padding-bottom: 60px; }
    .module-card + .module-card { margin-top: 12px; }
}

.event-plan-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.event-plan-col {
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: 14px;
    background: rgba(255,255,255,.02);
}

.event-plan-col h4 {
    margin: 0 0 10px;
    font-size: .95rem;
}

.stack-list {
    display: grid;
    gap: 8px;
    margin-bottom: 8px;
}

.repertoire-view {
    margin-top: 14px;
    border-top: 1px solid var(--line);
    padding-top: 12px;
}

.repertoire-view-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.view-toggle {
    display: flex;
    gap: 6px;
}

.view-toggle .button.active {
    background: var(--primary-glow);
    border-color: rgba(124,45,62,.35);
    color: var(--primary);
}

.view-toggle .button.is-disabled {
    opacity: .45;
    cursor: not-allowed;
}

.repertoire-preview {
    display: grid;
    gap: 10px;
    max-height: 280px;
    overflow: auto;
    padding-right: 4px;
}

.rep-song-block {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-soft);
    overflow: hidden;
}

.rep-song-block h5 {
    margin: 0;
    padding: 10px 12px;
    font-size: .86rem;
    border-bottom: 1px solid var(--line);
    background: rgba(255,255,255,.02);
}

.rep-song-block pre {
    margin: 0;
    padding: 10px 12px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
    font-size: .78rem;
    line-height: 1.45;
    white-space: pre-wrap;
    word-break: break-word;
    color: #efe8d7;
}

.repertoire-preview.lyrics-only .rep-song-block pre {
    font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    font-size: .95rem;
    line-height: 1.72;
    color: #f6f7ff;
}

@media (max-width: 900px) {
    .event-plan-grid { grid-template-columns: 1fr; }
    .repertoire-preview { max-height: 220px; }
    .repertoire-preview.lyrics-only .rep-song-block pre {
        font-size: 1rem;
        line-height: 1.8;
    }
    .chord-sheet-preview {
        max-height: 200px;
        font-size: clamp(.82rem, 3.4vw, .98rem);
    }
    .modal-song-box {
        width: 100%;
    }
    .song-modal-brand {
        align-items: flex-start;
    }
    .song-modal-logo {
        width: 38px;
        height: 38px;
    }
    .sections-grid {
        grid-template-columns: 1fr;
    }
    .layout-head {
        flex-direction: column;
        gap: 4px;
    }
    .layout-meta {
        white-space: normal;
        font-size: .75rem;
    }
    .pair-lyric {
        font-size: .95rem;
    }
}

@media (max-width: 600px) {
    .app-module-button,
    .app-chip-button {
        padding: 14px 10px;
    }

    .mobile-tabbar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* ════════════════════════════════════════════════════
   NUEVAS SECCIONES — index.php rediseño congregacional
   ════════════════════════════════════════════════════ */

/* Banda de versículo bajo el header */
.verse-banner {
    background: linear-gradient(90deg, var(--primary) 0%, var(--royal) 100%);
    border-bottom: 1px solid rgba(255,255,255,.15);
    padding: 11px 0;
    text-align: center;
}
.verse-banner .container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}
.verse-banner blockquote {
    margin: 0;
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-size: .95rem;
    font-style: italic;
    color: rgba(255,255,255,0.93);
    letter-spacing: .01em;
}
.verse-banner cite {
    font-style: normal;
    font-weight: 600;
    color: rgba(180,210,255,0.95);
    margin-left: 6px;
}
.verse-cross {
    color: rgba(255,255,255,.85);
    font-size: 1.1rem;
}

/* Sección alternativa (fondo ligeramente distinto) */
.section-alt {
    background: rgba(255,255,255,.022);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

/* Subtítulo versículo en secciones */
.verse-subtitle {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    color: var(--primary);
    font-style: italic;
    margin-bottom: 1rem;
}

/* Hero copy mejorado */
.hero-copy em {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-style: italic;
    color: var(--primary);
}

/* ── Pilares de visión ── */
.pillars-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 2rem;
}
.pillar-card {
    text-align: center;
    padding: 2rem 1.25rem;
}
.pillar-icon {
    font-size: 2rem;
    color: var(--primary);
    margin-bottom: .75rem;
    display: block;
    line-height: 1;
}
.pillar-card h3 {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    margin-bottom: .5rem;
    color: var(--text);
}

/* ── Event meta ── */
.event-type-tag { margin-bottom: .5rem; }
.event-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: .75rem;
    padding-top: .75rem;
    border-top: 1px solid var(--line);
}
.event-meta-item {
    font-size: .82rem;
    color: var(--muted);
}

/* ── Verso callout central ── */
.verse-callout-section { padding: 2.5rem 0; }
.verse-callout-box {
    background: linear-gradient(135deg, var(--primary-glow) 0%, rgba(14,53,114,0.08) 100%);
    border: 1px solid rgba(26,79,163,0.22);
    border-radius: 24px;
    padding: 3.5rem 2.5rem;
    text-align: center;
    position: relative;
    max-width: 740px;
    margin: 0 auto;
    box-shadow: 0 16px 48px rgba(26,79,163,0.10);
}
.verse-cross-lg {
    display: block;
    font-size: 2.5rem;
    color: var(--primary);
    margin-bottom: 1rem;
    opacity: .7;
}
.verse-callout-text {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-size: 1.45rem;
    font-weight: 600;
    font-style: italic;
    color: var(--text);
    line-height: 1.55;
    margin: 0 0 1rem;
}
.verse-callout-ref {
    font-size: .9rem;
    color: var(--primary);
    font-style: normal;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}

/* ── Footer mejorado ── */
.footer-grid { grid-template-columns: 1.4fr 0.7fr 0.7fr 0.9fr; }
.footer-church-name {
    display: block;
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    color: var(--primary);
    margin: .4rem 0 .5rem;
    font-weight: 700;
}
.footer-verse {
    font-family: 'Playfair Display', 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: .85rem;
    color: var(--primary);
    opacity: .75;
    margin-top: .75rem;
}
.footer-bottom {
    border-top: 1px solid var(--line);
    padding: 16px 0 0;
    margin-top: 32px;
    text-align: center;
}
.footer-bottom p {
    font-size: .78rem;
    color: var(--muted);
}

/* ── Upload zone (admin) ── */
.upload-zone {
    border: 2px dashed var(--line);
    border-radius: 12px;
    padding: 1.5rem;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    color: var(--muted);
    font-size: .875rem;
    min-height: 90px;
    justify-content: center;
}
.upload-zone:hover {
    border-color: var(--primary);
    background: var(--primary-glow);
    color: var(--text);
}
.upload-zone.upload-done {
    border-color: var(--primary);
    background: rgba(124,45,62,.08);
}
.upload-zone.uploading {
    border-color: var(--royal);
    background: rgba(44,82,130,.06);
    cursor: wait;
    pointer-events: none;
}
.upload-zone-large {
    min-height: 240px;
    border-radius: 16px;
    font-size: 1rem;
    gap: 1rem;
}

/* ── Responsive nuevas secciones ── */
@media (max-width: 960px) {
    .pillars-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .pillars-grid { grid-template-columns: 1fr; }
    .verse-callout-text { font-size: 1.15rem; }
    .footer-grid { grid-template-columns: 1fr; }
    .verse-banner blockquote { font-size: .82rem; }
}



/* ===================================================
   MODALES — v3
   =================================================== */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(4, 6, 20, .82);
  backdrop-filter: blur(8px);
  display: grid;
  place-items: center;
  padding: 20px;
  overflow-y: auto;
}
.modal-overlay[hidden] { display: none !important; }

.modal-box {
  width: min(700px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface);
  box-shadow: 0 32px 80px rgba(0,0,0,.75);
  animation: slideUp .22s cubic-bezier(.22,1,.36,1);
}
.modal-box-sm { width: min(420px, 100%); }

@keyframes slideUp {
  from { opacity: 0; transform: translateY(24px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}

.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 2;
}
.modal-head h3 { margin: 0; font-size: 1.05rem; }

.modal-close {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.1rem;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  transition: background .15s, color .15s;
}
.modal-close:hover { background: rgba(255,255,255,.07); color: var(--text); }

.modal-body { padding: 24px; }

.modal-alert {
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  font-size: .9rem;
  margin-bottom: 16px;
}
.modal-alert.error   { background: rgba(244,63,94,.12);  color: #f43f5e; border: 1px solid rgba(244,63,94,.25); }
.modal-alert.success { background: rgba(52,211,153,.12); color: #34d399; border: 1px solid rgba(52,211,153,.25); }

/* ===================================================
   ADMIN PANEL LAYOUT
   =================================================== */
.admin-body { background: var(--bg); min-height: 100vh; }

.admin-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 20px;
  border-radius: 0;
  border-right: 1px solid var(--line);
  border-top: none;
  border-bottom: none;
  border-left: none;
}

.brand.compact { display: flex; align-items: center; gap: 12px; padding: 10px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 8px; text-decoration: none; }
.brand-logo    { width: 36px; height: 36px; object-fit: contain; }
.brand-title   { display: block; font-size: 1rem; color: var(--text); }
.brand.compact small { display: block; color: var(--muted); font-size: .73rem; }

.admin-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.admin-nav a {
  display: block;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  color: var(--muted);
  text-decoration: none;
  font-size: .88rem;
  transition: background .15s, color .15s;
}
.admin-nav a:hover { background: rgba(139,108,240,.12); color: var(--primary); }

.admin-user-box {
  border-top: 1px solid var(--line);
  padding-top: 16px;
  font-size: .82rem;
  display: grid;
  gap: 4px;
}
.admin-user-box strong { font-size: .92rem; color: var(--text); }
.admin-user-box p { color: var(--muted); margin: 0; }
.admin-logout { margin-top: 8px; font-size: .8rem; padding: 7px 14px; }

.admin-content {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  max-width: 1100px;
}

.admin-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.admin-top h1 { margin: 4px 0 8px; font-size: 1.7rem; }
.admin-top p  { color: var(--muted); margin: 0; max-width: 480px; }
.admin-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.stat-card        { padding: 22px; }
.stat-card strong { display: block; font-size: 2.4rem; font-weight: 800; color: var(--primary); margin: 6px 0 4px; }
.stat-card p      { color: var(--muted); font-size: .82rem; margin: 0; }

.panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.panel-heading h3 { margin: 2px 0 0; }

.actions { display: flex; gap: 8px; justify-content: flex-end; }

.assign-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  font-size: .88rem;
}
.assign-row > span:first-child { flex: 1; }

.badge.confirmado { background: rgba(52,211,153,.15);  color: #34d399; }
.badge.pendiente  { background: rgba(240,168,40,.15);   color: var(--amber); }
.badge.rechazado  { background: rgba(244,63,94,.12);   color: #f43f5e; }

@media (max-width: 900px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar {
    position: static;
    height: auto;
        flex-direction: column;
    flex-wrap: wrap;
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 12px 16px;
  }
    .brand.compact { display: flex; }
    .admin-nav { flex-direction: column; gap: 8px; flex: none; width: 100%; }
    .admin-nav a { width: 100%; }
    .admin-user-box { display: block; }
  .admin-content { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .admin-top  { flex-direction: column; }
}


/* ===================================================
   MODALES — v3
   =================================================== */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(13, 27, 62, .85);
  backdrop-filter: blur(8px);
  display: grid;
  place-items: center;
  padding: 20px;
  overflow-y: auto;
}
.modal-overlay[hidden] { display: none !important; }

.modal-box {
  width: min(700px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface);
  box-shadow: 0 32px 80px rgba(0,0,0,.75);
  animation: slideUp .22s cubic-bezier(.22,1,.36,1);
}
.modal-box-sm { width: min(420px, 100%); }

@keyframes slideUp {
  from { opacity: 0; transform: translateY(24px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}

.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 2;
}
.modal-head h3 { margin: 0; font-size: 1.05rem; }

.modal-close {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.1rem;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  transition: background .15s, color .15s;
}
.modal-close:hover { background: rgba(255,255,255,.07); color: var(--text); }

.modal-body { padding: 24px; }

.modal-alert {
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  font-size: .9rem;
  margin-bottom: 16px;
}
.modal-alert.error   { background: rgba(244,63,94,.12);  color: #f43f5e; border: 1px solid rgba(244,63,94,.25); }
.modal-alert.success { background: rgba(52,211,153,.12); color: #34d399; border: 1px solid rgba(52,211,153,.25); }

/* ===================================================
   ADMIN PANEL LAYOUT
   =================================================== */
.admin-body { background: var(--bg); min-height: 100vh; }

.admin-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 20px;
  border-radius: 0;
  border-right: 1px solid var(--line);
  border-top: none;
  border-bottom: none;
  border-left: none;
}

.brand.compact { display: flex; align-items: center; gap: 12px; padding: 10px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 8px; text-decoration: none; }
.brand-logo    { width: 36px; height: 36px; object-fit: contain; }
.brand-title   { display: block; font-size: 1rem; color: var(--text); }
.brand.compact small { display: block; color: var(--muted); font-size: .73rem; }

.admin-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.admin-nav a {
  display: block;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  color: var(--muted);
  text-decoration: none;
  font-size: .88rem;
  transition: background .15s, color .15s;
}
.admin-nav a:hover { background: rgba(26,79,163,.12); color: var(--primary); }

.admin-user-box {
  border-top: 1px solid var(--line);
  padding-top: 16px;
  font-size: .82rem;
  display: grid;
  gap: 4px;
}
.admin-user-box strong { font-size: .92rem; color: var(--text); }
.admin-user-box p { color: var(--muted); margin: 0; }
.admin-logout { margin-top: 8px; font-size: .8rem; padding: 7px 14px; }

.admin-content {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  max-width: 1100px;
}

.admin-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.admin-top h1 { margin: 4px 0 8px; font-size: 1.7rem; }
.admin-top p  { color: var(--muted); margin: 0; max-width: 480px; }
.admin-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.stat-card        { padding: 22px; }
.stat-card strong { display: block; font-size: 2.4rem; font-weight: 800; color: var(--primary); margin: 6px 0 4px; }
.stat-card p      { color: var(--muted); font-size: .82rem; margin: 0; }

.panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.panel-heading h3 { margin: 2px 0 0; }

.actions { display: flex; gap: 8px; justify-content: flex-end; }

.assign-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  font-size: .88rem;
}
.assign-row > span:first-child { flex: 1; }

.badge.confirmado { background: rgba(52,211,153,.15);  color: #34d399; }
.badge.pendiente  { background: rgba(240,168,40,.15);   color: var(--amber); }
.badge.rechazado  { background: rgba(244,63,94,.12);   color: #f43f5e; }

@media (max-width: 900px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar {
    position: static;
    height: auto;
        flex-direction: column;
    flex-wrap: wrap;
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 12px 16px;
  }
    .brand.compact { display: flex; }
    .admin-nav { flex-direction: column; gap: 8px; flex: none; width: 100%; }
    .admin-nav a { width: 100%; }
    .admin-user-box { display: block; }
  .admin-content { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .admin-top  { flex-direction: column; }
}

/* ===================================================
   MODULO FINANZAS - Ofrendas y Gastos
   =================================================== */
:root { --finance-income: #16a34a; --finance-expense: #dc2626; }
.finance-summary-bar { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 18px; }
.finance-summary-card { padding: 16px 20px; border-radius: var(--radius-sm); border: 1px solid var(--line); }
.finance-summary-card .eyebrow { display: block; font-size: .72rem; letter-spacing: .08em; color: var(--muted); margin-bottom: 6px; }
.finance-summary-card strong { display: block; font-size: 1.6rem; font-weight: 800; }
.finance-summary-card.income { background: #f0fdf4; border-color: #86efac; }
.finance-summary-card.income strong { color: var(--finance-income); }
.finance-summary-card.expense { background: #fef2f2; border-color: #fca5a5; }
.finance-summary-card.expense strong { color: var(--finance-expense); }
.finance-summary-card.balance-pos { background: #eff6ff; border-color: #93c5fd; }
.finance-summary-card.balance-pos strong { color: var(--primary); }
.finance-summary-card.balance-neg { background: #fef2f2; border-color: #fca5a5; }
.finance-summary-card.balance-neg strong { color: var(--finance-expense); }
.finance-filter-bar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 22px; padding: 14px 18px; background: var(--bg-soft); border-radius: var(--radius-sm); border: 1px solid var(--line); }
.finance-filter-inputs { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.finance-filter-inputs label { display: flex; align-items: center; gap: 6px; font-size: .85rem; color: var(--muted); font-weight: 500; }
.finance-date-input { border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 6px 10px; font-size: .85rem; background: var(--surface); color: var(--text); }
.finance-report-label { margin-top: 10px; padding: 8px 14px; background: rgba(26,79,163,.07); border-left: 3px solid var(--primary); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-size: .85rem; font-weight: 600; color: var(--primary); }
.finance-tfoot td { background: var(--bg-soft); border-top: 2px solid var(--line); padding: 10px; font-size: .9rem; }
.stat-card.stat-income strong  { color: var(--finance-income)  !important; }
.stat-card.stat-expense strong { color: var(--finance-expense) !important; }
@media (max-width: 700px) {
  .finance-summary-bar { grid-template-columns: 1fr; }
  .finance-filter-bar  { flex-direction: column; align-items: flex-start; }
}

/* ════════════════════════════════════════════════════
   MODO APP MÓVIL — sidebar oculto, tabbar visible
   ════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    /* Sidebar colapsado en móvil: ocultar totalmente y dejar solo tabbar */
    .admin-sidebar {
        display: none !important;
    }
    .admin-shell {
        grid-template-columns: 1fr !important;
        width: 100% !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }
    .admin-content {
        padding: 16px 14px 60px !important;
        border-radius: 0 !important;
    }
    /* Tabbar visible — 6 ítems base (Inicio, Canciones, Eventos, Ofrendas, Gastos, Salir) */
    .mobile-tabbar {
        display: grid !important;
        grid-template-columns: repeat(6, 1fr);
    }
}

/* Admin: 7 ítems (+ Equipo) */
@media (max-width: 1024px) {
    .mobile-tabbar:has(a[href="servidores.php"]) {
        grid-template-columns: repeat(7, 1fr);
    }
}

/* Estilos extra de la tabbar para mejor UX */
.mobile-tabbar a.nav-logout-link {
    color: #f87171;
}
.mobile-tabbar a.nav-logout-link span {
    background: rgba(248,113,113,.12);
}
.mobile-tabbar a.nav-logout-link:hover,
.mobile-tabbar a.nav-logout-link:active {
    color: #ef4444;
    background: rgba(248,113,113,.10);
}

/* Viewport seguro en iPhone con notch */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
    .mobile-tabbar {
        padding-bottom: calc(6px + env(safe-area-inset-bottom));
    }
    .admin-content {
        padding-bottom: calc(56px + env(safe-area-inset-bottom)) !important;
    }
}

/* Toque activo visual */
.mobile-tabbar a {
    -webkit-tap-highlight-color: transparent;
    transition: background .12s, color .12s, transform .1s;
}
.mobile-tabbar a:active {
    transform: scale(.92);
}

/* Header pegado arriba en móvil */
@media (max-width: 1024px) {
    .admin-top.card {
        position: sticky;
        top: 0;
        z-index: 100;
        border-radius: 0;
        margin: -14px -14px 0;
        padding: 14px 16px 12px;
        border-left: none;
        border-right: none;
        border-top: none;
    }
    .admin-top h1 { font-size: 1.25rem; margin: 2px 0 4px; }
    .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
