*   {
        margin:0;
        padding:0;
        box-sizing:border-box;
    }

html
    {
        scroll-behavior:smooth;
    }

body
    {
        font-family:system-ui,sans-serif;
        background:var(--bg);
        color:var(--text);
        line-height:1.5;
        overflow-x:hidden;
    }

.header, main, footer
    {
        position:relative;
        z-index:2;
    }

img
    {
        display:block;
        max-width:100%;
    }

a
    {
        text-decoration:none;
        color:inherit;
    }

.wrap
    {
        width:min(1180px,92%);
        margin:auto;
    }

.narrow
    {
        max-width:760px;
    }

.hero
    {
        position:relative;
        min-height:100vh;
        display:flex;
        align-items:center;
        overflow:hidden;
        padding:10rem 0 7rem;
    }

.hero-video
    {
        position:absolute;
        inset:0;
        overflow:hidden;
        z-index:0;
        background: var(--bg);
    }

.hero-video iframe
    {
        position:absolute;
        top:50%;
        left:50%;
        width:177.77777778vh;
        height:56.25vw;
        min-width:100%;
        min-height:100%;
        transform:translate(-50%,-50%);
        border:0;
        pointer-events:none;
        opacity:.55;
        filter:brightness(1);
    }

.hero-overlay
    {
        position:absolute;
        inset:0;
        background:linear-gradient(to bottom,rgba(6,11,17,.45),rgba(6,11,17,.78));
        z-index:1;
    }

.hero-content
    {
        position:relative;
        z-index:2;
        max-width:900px;
        text-align:center;
    }

.header
    {
        position:sticky;
        top:0;
        z-index:9999;
        background: var(--bg);
        backdrop-filter:blur(6px);
        border-bottom:1px solid var(--line);
        overflow:visible;
    }

.header-light
    {
        position:absolute;
        top:0;
        left:-30%;
        width:30%;
        height:100%;
        background:linear-gradient(90deg,transparent, var(--header-light),transparent);
        animation:light 8s linear infinite;
    }

@keyframes light
    {
        0%{transform:translateX(0)}
        100%{transform:translateX(500%)}
    }

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

.logo
    {
        font-weight:800;
        letter-spacing:.08em;
    }

.menu
    {
        display: flex;
        gap: 1rem;
    }

.menu a
    {
        padding: .7rem .9rem;
        border-radius: .75rem;
        display: block;
    }

.menu a:hover
    {
        background:var(--bannery);
    }

.menu-btn
    {
        display: none;
        background: none;
        border: 0;
        color: var(--text);
        font-size: 1.5rem;
        cursor: pointer;
    }

.menu-item
    {
        position: relative;
    }

.menu-item > a::after
    {
        content: " ▼";
        font-size: 0.7em;
    }

.submenu
    {
        position: absolute;
        top: 100%;
        left: 0;
        min-width: 180px;
        background: var(--card);
        border: 1px solid var(--line);
        border-radius: .75rem;
        box-shadow: 0 6px 18px rgba(0,0,0,.08);
        overflow: hidden;
        display: none;
        z-index: 1000;
    }

.submenu a
    {
        display: block;
        padding: 10px 15px;
        border-radius: 0;
        white-space: nowrap;
    }

.submenu a:hover
    {
        background:var(--bannery);
    }

.menu-item:hover .submenu
    {
        display: block;
    }

.hero
    {
        padding:10rem 0 7rem;
    }

.hero-content
    {
        max-width:900px;
        text-align:center;
    }

.badge
    {
        display:inline-block;
        padding:.45rem .85rem;
        border-radius:999px;
        background: var(--card);
        border:1px solid var(--line);
        margin-bottom:1rem;
        font-size:.82rem;
    }

.hero h1
    {
        font-size:clamp(2.7rem,6vw,5rem);
        line-height:1.03;
        margin-bottom:1rem;
        color:var(--white);
    }

.hero p
    {
        max-width:760px;
        margin:auto;
        color:var(--white);
    }

.hero-actions
    {
        display:flex;
        justify-content:center;
        gap:1rem;
        margin-top:2rem;
        flex-wrap:wrap;
    }

.btn-primary, .btn-secondary
    {
        padding:1rem 1.3rem;
        border-radius:0.75rem;
        font-weight:600;
    }

.btn-primary
    {
        background:var(--accent);
        color: var(--line);
        border:1px solid var(--btn-primary);
}

.btn-secondary
    {
        background:var(--btn-primary);
        color: var(--accent);
        border:1px solid var(--line);
    }

.section
    {
        padding:5rem 0;
    }

.alt
    {
        background:var(--alt);
    }

.alt-audio
    {
        background:var(--accent);
    }

.section-head
    {
        margin-bottom:2rem;
    }

.section-head p
    {
        margin-top:.5rem;
        color:var(--muted);
    }

.event-banner
    {
        display:grid;
        grid-template-columns:1.1fr .9fr;
        gap:2rem;
        background:linear-gradient(135deg,var(--bannerx),var(--bannery));
        border:1px solid var(--line);
        border-radius:0.75rem;
        overflow:hidden;
    }

.event-content
    {
        padding:3rem;
        display:flex;
        flex-direction:column;
        justify-content:center;
    }

.event-badge
    {
        display:inline-block;
        padding:.45rem .85rem;
        background:var(--event-badge);
        border-radius:999px;
        width:max-content;
        margin-bottom:1rem;
        font-size:.82rem;
    }

.event-content h2
    {
        font-size:clamp(2rem,5vw,4rem);
        line-height:1.05;
        margin-bottom:1rem;
    }

.event-content p
    {
        color:var(--muted);
        max-width:600px;
    }

.countdown-title
    {
        margin-top:2rem;
        margin-bottom:1rem;
        font-weight:700;
    }

.countdown
    {
        display:flex;
        gap:1rem;
        flex-wrap:wrap;
    }

.time-box
    {
        min-width:100px;
        padding:1rem;
        border-radius:0.75rem;
        background:var(--timebox);
        border:1px solid var(--line);
        text-align:center;
    }

.time-box strong
    {
        display:block;
        font-size:2rem;
        margin-bottom:.2rem;
    }

.time-box span
    {
        color:var(--muted);
        font-size:.84rem;
    }

.event-image img
    {
        width:100%;
        height:100%;
        object-fit:cover;
        object-position:center;
    }

.grid,
.feature-grid,
.staff-grid,
.gallery-grid,
.stats-grid
    {
        display:grid;
        gap:1rem;
    }

.grid
    {
        grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    }

.feature-grid
    {
        grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    }

.feature-card,
.card,
.staff-card,
.stat-card
    {
        background:var(--card);
        border:1px solid var(--line);
        border-radius:0.75rem;
    }

.feature-card
    {
        padding:2rem;
    }

.card
    {
        overflow:hidden;
        cursor:pointer;
    }

.video-thumb
    {
        position:relative;
    }

.video-thumb img
    {
        aspect-ratio:16/9;
        object-fit:cover;
    }

.play
    {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 54px;
        height: 54px;
        display: grid;
        place-items: center;
        border-radius: 50%;
        background: var(--accent);
    }

.card-body
    {
        padding:1rem;
    }

.date
    {
        margin:.6rem 0;
        font-size:.84rem;
        color:var(--muted);
    }

.staff-grid
    {
        grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    }

.staff-card
    {
        position: relative;
        overflow: hidden;
        padding:1rem;
        text-align:center;
    }

.staff-card img
    {
        width:100%;
        aspect-ratio:1/1;
        object-fit:cover;
        object-position:center;
        border-radius:0.75rem;
        margin-bottom:1rem;
    }

.staff-card span
    {
        display:block;
        margin-top:.3rem;
        color:var(--muted);
    }

.staff-ribbon
    {
        position: absolute;
        top: 20px;
        left: -55px;
        padding: .5rem 5rem;
        background: var(--accent);
        color: var(--white);
        transform: rotate(-40deg);
        font-size: .8rem;
        font-weight: 700;
        z-index: 2;
    }

.gallery-grid
    {
        grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    }

.gallery-grid img
    {
        aspect-ratio:16/10;
        object-fit:cover;
        border-radius:0.75rem;
        border:1px solid var(--line);
    }

.stats-grid
    {
        grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    }

.stat-card
    {
        padding:2rem 1rem;
        text-align:center;
    }

.stat-card strong
    {
        display:block;
        font-size:2rem;
        margin-bottom:.5rem;
    }

.stat-card span
    {
        color:var(--muted);
    }

.socials
    {
        display:flex;
        gap:1rem;
        flex-wrap:wrap;
    }

.socials a
    {
        padding:1rem 1.2rem;
        background:var(--card);
        border:1px solid var(--line);
        border-radius:0.75rem;
    }

.footer
    {
        padding:0;
        
    }

.footer-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
        gap:2rem;
    }

.footer a,
.footer p
    {
        display:block;
        margin-top:.5rem;
        color:var(--muted);
    }

.footer-bottom
    {
        margin:0;
        padding:1.5rem 0;
        background:linear-gradient(180deg, #2a3749 0%, var(--btn-primary) 100%);
        border-top:2px solid var(--accent2);
        text-align:center;
        color:rgba(255,255,255,.75);
        font-size:.9rem;
    }

.footer-grid img
    {
        width:100%;
        height:120px;
        object-fit:cover;
        border-radius:0.75rem;
        margin-bottom:1rem;
        border:1px solid var(--line);
    }

.loading
    {
        padding:2rem;
        text-align:center;
        border:1px dashed var(--line);
        border-radius:0.75rem;
        color:var(--muted);
    }

.modal
    {
        position:fixed;
        inset:0;
        display:none;
        align-items:center;
        justify-content:center;
        background:var(--black);
        backdrop-filter:blur(6px);
        z-index:100;
        padding:1rem;
    }

.modal.active
    {
        display:flex;
    }

.modal-content
    {
        width:min(1000px,100%);
        position:relative;
    }

.close-modal
    {
        position:absolute;
        right:0;
        top:-3rem;
        width:44px;
        height:44px;
        border:0;
        border-radius:50%;
        background:var(--card);
        color:var(--white);
        cursor:pointer;
    }

.modal-video
    {
        position:relative;
        padding-top:56.25%;
        overflow:hidden;
        border-radius:0.75rem;
        border:1px solid var(--line);
    }

.modal-video iframe
    {
        position:absolute;
        inset:0;
        width:100%;
        height:100%;
        border:0;
    }

@media(max-width:860px)
    {
        .event-banner{grid-template-columns:1fr;}
    }

@media(max-width:760px)
    {
        .menu-btn
        {
            display:block;
        }
        
        .menu
        {
            position:absolute;
            top:70px;
            left:0;
            right:0;
            display:none;
            flex-direction:column;
            padding:1rem;
            background:var(--bg);
            backdrop-filter:blur(12px);
            border-bottom:1px solid var(--line);
            z-index:99999;
        }
        
        .menu.active
        {
            display:flex;
        }
        
        .hero
        {
            padding:8rem 0 5rem;
        }
        
        .hero-actions
        {
            flex-direction:column;
        }
        
        .btn-primary,
        .btn-secondary
        {
            width:100%;
        }
        
        .close-modal
        {
            top:-2.8rem;
        }
    }

@keyframes menuFade
    {
        from
        {
            opacity:0;
            transform:translateY(-8px);
        }
        
        to
        {
            opacity:1;
            transform:translateY(0);
        }
    }

.pricing-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
        gap:1.5rem;
        align-items:stretch;
    }

.pricing-card
    {
        position:relative;
        background:linear-gradient(180deg,var(--card),var(--card2));
        border:1px solid var(--line);
        border-radius:0.75rem;
        padding:2rem;
        display:flex;
        flex-direction:column;
        transition:.25s ease;
        overflow:hidden;
    }

.pricing-card:hover
    {
        transform:translateY(-2px);
        border-color: var(--pricing-border);
        box-shadow:0 20px 40px var(--black);
    }

.pricing-card.featured
    {
        border-color: var(--pricing-featured);
        transform:scale(1.03);
        box-shadow:0 0 40px var(--pricing-box-shadow);
    }

.pricing-card.pro
    {
        background: linear-gradient(180deg, var(--pricing-card-pro1), var(--pricing-card-pro2));
        border-color: var(--pricing-border-color);
    }

.pricing-top
    {
        margin-bottom:2rem;
    }

.pricing-badge
    {
        display:inline-block;
        padding:.45rem .85rem;
        border-radius:999px;
        background:var(--pricing-badge);
        border:1px solid var(--line);
        font-size:.78rem;
        margin-bottom:1rem;
    }

.pricing-note
    {
        margin:0.5rem 0 1rem;
        font-size:0.85rem;
        color:var(--muted);
        text-align:center;
        line-height:1.4;
    }

.glow
    {
        background: var(--event-badge);
        border-color: var(--pricing-border);
        color: var(--accent2);
    }

.pro-badge
    {
        background: var(--accent);
        color: var(--btn-primary);
        font-weight:700;
    }

.pricing-card h3
    {
        font-size:1.8rem;
        margin-bottom:1rem;
    }

.price
    {
        display:flex;
        align-items:flex-end;
        gap:.4rem;
    }

.price strong
    {
        font-size:3rem;
        line-height:1;
    }

.price span
    {
        color:var(--muted);
        margin-bottom:.35rem;
    }

.pricing-features
    {
        list-style:none;
        display:flex;
        flex-direction:column;
        gap:1rem;
        margin-bottom:2rem;
        color:var(--muted);
    }

.pricing-features li
    {
        padding-bottom:1rem;
        border-bottom:1px solid var(--pricing-li);
    }

.pricing-btn
    {
        margin-top:auto;
        text-align:center;
        display:block;
    }

.contact-layout
    {
        display:grid;
        grid-template-columns:1.4fr .6fr;
        gap:3rem;
        align-items:center;
    }

.contact-layout .section-head
    {
        margin-bottom:0;
    }

.contact-layout .section-head h2
    {
        margin-bottom:1rem;
    }

.contact-layout .section-head p
    {
        max-width:700px;
    }

.contact-layout .socials
    {
        display:grid;
        grid-template-columns:repeat(2,1fr);
        gap:1rem;
    }

.contact-layout .socials a
    {
        display:flex;
        justify-content:center;
        align-items:center;
        min-height:90px;
        background:var(--card);
        border:1px solid var(--line);
        border-radius:0.75rem;
        font-size:1.8rem;
        transition:.25s ease;
    }

.contact-layout .socials a:hover
    {
        transform:translateY(-2px);
        border-color:var(--accent);
    }

@media(max-width:860px)
    {
        .contact-layout
        {
            grid-template-columns:1fr;
            text-align:center;
        }

        .contact-layout .section-head p
        {
            margin:auto;
        }
    }

.historia-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
        gap:1rem;
    }

.historia-card
    {
        background:var(--card);
        border:1px solid var(--line);
        border-radius:0.75rem;
        overflow:hidden;
    }

.historia-card img
    {
        width:100%;
        aspect-ratio:16/10;
        object-fit:cover;
        object-position:center;
    }

.historia-content
    {
        padding:1.5rem;
    }

.historia-etapa
    {
        display:inline-block;
        margin-bottom:1rem;
        padding:.45rem .85rem;
        border-radius:999px;
        background:var(--event-badge);
        font-size:.82rem;
    }

.historia-content h3
    {
        margin-bottom:1rem;
    }

.historia-content p
    {
        color:var(--muted);
        line-height:1.7;
    }

@media(max-width:760px)
    {
        .historia-grid
        {
            grid-template-columns:1fr;
        }
    }

.mision-layout
    {
        display:grid;
        grid-template-columns:1fr .9fr;
        gap:3rem;
        align-items:center;
    }

.mision-content .section-head
    {
        margin-bottom:2rem;
    }

.mision-content .section-head p
    {
        max-width:700px;
    }

.mision-image img
    {
        width:100%;
        height:100%;
        min-height:500px;
        object-fit:cover;
        object-position:center;
        border-radius:0.75rem;
        border:1px solid var(--line);
    }

@media(max-width:860px)
    {
        .mision-layout
        {
            grid-template-columns:1fr;
        }

        .mision-image
        {
            order:-1;
        }

        .mision-image img
        {
            min-height:350px;
        }
    }

.ministerio-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
        gap:1rem;
    }

.ministerio-card
    {
        background:var(--card);
        border:1px solid var(--line);
        border-radius:.75rem;
        overflow:hidden;
    }

.ministerio-card img
    {
        width:100%;
        aspect-ratio:1/1;
        object-fit:cover;
    }

.ministerio-card-body
    {
        padding:1rem;
        text-align:center;
    }

.ministerio-card span
    {
        display:block;
        margin-top:.4rem;
        color:var(--muted);
    }

.jovenes-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
        gap:1.5rem;
    }

.joven-card
    {
        position:relative;
        overflow:hidden;
        background:linear-gradient(180deg,var(--card),var(--card2));
        border:1px solid var(--line);
        border-radius:.75rem;
    }

.joven-card img
    {
        width:100%;
        aspect-ratio:16/10;
        object-fit:cover;
    }

.joven-ribbon
    {
        position:absolute;
        top:20px;
        left:-65px;
        padding:.5rem 5rem;
        background:var(--accent);
        color:var(--white);
        transform:rotate(-40deg);
        font-size:.8rem;
        font-weight:700;
    }

.joven-content
    {
        padding:1.5rem;
    }

.joven-content p
    {
        color:var(--muted);
        line-height:1.8;
    }

.adultos-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
        gap:1rem;
    }

.adulto-card
    {
        background:var(--card);
        border:1px solid var(--line);
        border-radius:.75rem;
        overflow:hidden;
    }

.adulto-card img
    {
        width:100%;
        aspect-ratio:16/10;
        object-fit:cover;
    }

.adulto-content
    {
        padding:1rem;
    }

.adulto-content span
    {
        color:var(--muted);
        display:block;
        margin-top:.5rem;
    }

.ninos-grid
    {
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
        gap:1.75rem;
    }

.nino-card
    {
        position:relative;
        overflow:hidden;
        background:linear-gradient(180deg,var(--card),var(--card2));
        border:2px solid color-mix(in srgb, var(--accent) 20%, var(--line));
        border-radius:1.5rem;
        transition:.3s ease;
        box-shadow:0 10px 25px rgba(0,0,0,.08);
    }

.nino-card:hover
    {
        transform:translateY(-2px);
        box-shadow:0 18px 40px rgba(0,0,0,.12);
    }

.nino-card img
    {
        width:100%;
        aspect-ratio:16/10;
        object-fit:cover;
    }

.nino-badge
    {
        position:absolute;
        top:1rem;
        right:1rem;
        width:70px;
        height:70px;
        display:flex;
        align-items:center;
        justify-content:center;
        background:var(--accent);
        color:var(--btn-primary);
        border-radius:50%;
        font-size:.75rem;
        font-weight:700;
        text-align:center;
        box-shadow:0 5px 15px rgba(0,0,0,.15);
    }

.nino-content
    {
        padding:1.5rem;
        text-align:center;
    }

.nino-content h3
    {
        margin-bottom:.75rem;
        font-size:1.3rem;
    }

.nino-content p
    {
        color:var(--muted);
        line-height:1.8;
        font-size:.95rem;
    }

.documents-grid
    {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
        gap: 1.75rem;
        margin-top: 2.2rem;
    }

.document-card
    {
        position: relative;
        height: 100%;
        background: linear-gradient(180deg, var(--card), var(--alt));
        border: 1px solid var(--line);
        border-radius: 14px;
        overflow: hidden;
        cursor: pointer;
        box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
        transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
        will-change: transform;
    }

.document-card:hover
    {
        transform: translateY(-2px);
        border-color: var(--pricing-border-color);
        box-shadow: 0 12px 28px rgba(216, 177, 95, 0.10);
    }

.document-card-content
    {
        display: flex;
        flex-direction: column;
        height: 100%;
        padding: 1.1rem 1.1rem 1.2rem;
        gap: 0.6rem;
    }

.document-card-header
    {
        display: flex;
        align-items: center;
        gap: 0.75rem;
    }

.document-icon
    {
        width: 38px;
        height: 38px;
        border-radius: 10px;
        display: grid;
        place-items: center;
        background: var(--pricing-badge);
        border: 1px solid var(--pricing-border);
        color: var(--accent);
        font-size: 1.1rem;
        flex-shrink: 0;
    }

.document-title
    {
        font-size: 0.98rem;
        font-weight: 600;
        color: var(--text);
        line-height: 1.2;
    }

.document-meta
    {
        font-size: 0.78rem;
        color: var(--muted);
    }

.document-description
    {
        font-size: 0.85rem;
        color: var(--muted);
        line-height: 1.5;
        min-height: 70px;
    }

.document-footer
    {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: auto;
        gap: 0.75rem;
    }

.document-tag
    {
        font-size: 0.72rem;
        padding: 0.25rem 0.55rem;
        border-radius: 999px;
        background: var(--pricing-li);
        border: 1px solid var(--line);
        color: var(--muted);
    }

.document-btn
    {
        font-size: 0.78rem;
        font-weight: 500;
        padding: 0.45rem 0.9rem;
        border-radius: 8px;
        border: 1px solid var(--line);
        background: var(--accent);
        color: var(--white);
        cursor: pointer;
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        transition: all 0.2s ease;
    }

.document-btn:hover
    {
        border-color: var(--accent);
        background: var(--accent2);
        color: var(--white);
    }

.resources-toolbar
    {
        display: flex;
        gap: 1rem;
        margin: 2rem 0;
    }

.resources-toolbar input
    {
        flex: 1;
        padding: 0.9rem 1rem;
        border-radius: 10px;
        border: 1px solid var(--line);
        background: var(--white);
        color: var(--text);
        outline: none;
    }

.resources-toolbar input:focus
    {
        border-color: var(--accent);
    }

.resource-search-btn
    {
        padding: 0.9rem 1.2rem;
        border-radius: 10px;
        border: 1px solid var(--line);
        background: var(--accent);
        color: var(--white);
        font-weight: 600;
        cursor: pointer;
        transition: all 0.2s ease;
        white-space: nowrap;
    }

.resource-search-btn:hover
    {
        background: var(--accent2);
        border-color: var(--accent2);
        transform: translateY(-1px);
    }

.documents-pagination
    {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 1rem;
        margin-top: 2rem;
    }

.documents-pagination button
    {
        padding: 0.7rem 1rem;
        border-radius: 10px;
        border: 1px solid var(--line);
        background: var(--accent);
        color: var(--white);
        cursor: pointer;
        transition: background 0.2s ease;
    }

.documents-pagination button:hover
    {
        background: var(--accent2);
    }

.documents-pagination button:disabled
    {
        opacity: 0.9;
        cursor: not-allowed;
    }








.grupos-grid
{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap:1.5rem;
}


.grupos-card
{
    position:relative;
    overflow:hidden;

    background:var(--card);
    border-radius:1.5rem;

    box-shadow:0 10px 30px rgba(0,0,0,.12);

    transition:transform .35s ease, box-shadow .35s ease;
}

.grupos-card
{
    display:flex;
    flex-direction:column;
}











.grupos-card:hover
{
    transform:translateY(-2px);
    box-shadow:0 20px 50px rgba(0,0,0,.22);
}

/* Imagen */
.grupos-card img
{
    width:100%;
    height:180px;
    object-fit:cover;
    display:block;
}

/* Oscurecido superior */
.grupos-card::after
{
    content:"";
    position:absolute;
    top:0;
    left:0;
    right:0;
    height:180px;

    background:linear-gradient(to top, rgba(0,0,0,.65), transparent);
}

/* Ribbon */
.grupos-ribbon
{
    position:absolute;
    top:14px;
    left:14px;
    z-index:2;

    padding:.4rem .8rem;

    background:var(--accent);
    color:#fff;

    font-size:.75rem;
    font-weight:700;

    border-radius:999px;

    box-shadow:0 8px 20px rgba(0,0,0,.25);
}












.grupos-ribbon--curricula
{
    background: var(--accent);
}

.grupos-ribbon--interes
{
    background: var(--text);
}












/* Título */
.grupos-card h3
{
    margin:1rem 1.2rem .3rem;
    font-size:1.3rem;
    font-weight:800;
}

/* Línea decorativa */
.grupos-card h3::after
{
    content:"";
    display:block;
    width:50px;
    height:3px;
    margin-top:.5rem;

    border-radius:999px;

    background:linear-gradient(90deg, var(--accent), #ffb347);
}

/* Descripción */
.grupos-card span
{
    display:block;
    padding:0 1.2rem 1rem;

    color:var(--muted);
    font-size:.92rem;
    line-height:1.6;
}

/* Botón */
.grupos-btn
{
    display:inline-block;
    margin:0 1.2rem 1.2rem;
    padding:.75rem 1.3rem;

    background:linear-gradient(135deg, var(--accent), #ffb347);
    color:#fff;

    text-decoration:none;
    font-weight:700;

    border-radius:999px;

    box-shadow:0 10px 25px rgba(255,179,71,.35);

    transition:transform .25s ease, box-shadow .25s ease;
}

.grupos-btn
{
    margin-top:auto;
}

.grupos-btn:hover
{
    transform:translateY(-2px);
    box-shadow:0 15px 35px rgba(255,179,71,.55);
}


/* =========================
   MODAL (GRUPOS - AISLADO)
========================= */

.modal-overlay
{
    position:fixed;
    inset:0;

    display:none;
    align-items:center;
    justify-content:center;

    background:rgba(0,0,0,.6);
    backdrop-filter:blur(8px);

    z-index:200;
    padding:1rem;
}

.modal-overlay.active
{
    display:flex;
}

/* caja interna (IMPORTANTE: NO .modal) */
.modal-box
{
    width:min(700px, 100%);

    background:var(--card);
    border-radius:1.5rem;

    padding:1.5rem;

    position:relative;

    box-shadow:0 25px 60px rgba(0,0,0,.35);
}

/* cerrar */
.modal-close
{
    position:absolute;
    top:12px;
    right:12px;

    width:38px;
    height:38px;

    border:0;
    border-radius:50%;

    background:var(--line);
    color:var(--white);

    cursor:pointer;
}

/* iframe */
.modal-body iframe
{
    width:100%;
    height:70vh;

    border:0;
    border-radius:1rem;
}