/*
 * COES v3 — "Arquitectura Educativa"
 * Inspired by Mexican modernist architecture
 * Bold geometry · Warm copper/amber · Editorial typography
 */

/* ═══════════════════════ TOKENS ═══════════════════════ */
:root {
    /* Palette */
    --navy:      #0c1d2e;
    --navy-mid:  #142d44;
    --navy-soft: #1a3a5c;
    --copper:    #c67a3c;
    --amber:     #e8882b;
    --amber-hot: #f4a23a;
    --terra:     #a85c2a;
    --cream:     #faf6f1;
    --surface:   #ffffff;
    --surface-2: #f5f0eb;
    --ink:       #1a1a2e;
    --ink-soft:  #3d3d56;
    --ink-muted: #6b6b82;
    --border:    #e4ddd5;
    --success:   #2a9d5c;
    --danger:    #d04040;

    /* Type */
    --font-display: 'DM Serif Display', Georgia, 'Times New Roman', serif;
    --font-body:    'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Sizing */
    --space-xs: 4px;  --space-sm: 8px;  --space-md: 16px;
    --space-lg: 24px; --space-xl: 40px; --space-2xl: 64px;
    --space-3xl: 100px;

    /* Radii */
    --r-sm: 6px;  --r-md: 12px;  --r-lg: 20px;  --r-xl: 28px;

    /* Shadows */
    --sh-sm:  0 2px 8px rgba(12,29,46,.06);
    --sh-md:  0 8px 30px rgba(12,29,46,.1);
    --sh-lg:  0 16px 50px rgba(12,29,46,.14);
    --sh-glow: 0 0 40px rgba(232,136,43,.25);

    /* Motion */
    --ease-out: cubic-bezier(.22,1,.36,1);
    --ease-spring: cubic-bezier(.34,1.56,.64,1);
    --dur: .4s;
}

/* ═══════════════════════ RESET ═══════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--ink-soft);background:var(--surface);overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.menu-open{overflow:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--dur) var(--ease-out)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--ink);line-height:1.2;font-weight:400}
ul,ol{list-style:none}
input,select,textarea,button{font-family:inherit;font-size:inherit;border:none;outline:none}
::selection{background:var(--amber);color:#fff}

/* ═══════════════════════ LAYOUT ═══════════════════════ */
.container{max-width:1180px;margin:0 auto;padding:0 24px}
section{padding:var(--space-3xl) 0}

/* ═══════════════════════ TYPOGRAPHY ═══════════════════════ */
.kicker{
    display:inline-block;font-family:var(--font-body);font-size:12px;font-weight:700;
    text-transform:uppercase;letter-spacing:3px;color:var(--copper);margin-bottom:12px;
    position:relative;padding-left:28px;
}
.kicker::before{
    content:'';position:absolute;left:0;top:50%;width:18px;height:2px;
    background:var(--amber);transform:translateY(-50%);
}
.kicker--light{color:var(--amber-hot)}
.kicker--light::before{background:rgba(255,255,255,.4)}

.section-head{margin-bottom:var(--space-xl)}
.section-head--center{text-align:center}
.section-head--center .kicker{padding-left:0}
.section-head--center .kicker::before{display:none}
.section-head__title{font-size:clamp(28px,4vw,44px);margin-bottom:12px}
.section-head__sub{max-width:600px;margin:0 auto;color:var(--ink-muted);font-size:17px}

/* ═══════════════════════ BUTTONS ═══════════════════════ */
.btn{
    display:inline-flex;align-items:center;gap:10px;padding:14px 32px;
    border-radius:var(--r-sm);font-weight:700;font-size:15px;cursor:pointer;
    transition:all var(--dur) var(--ease-out);border:2px solid transparent;
    position:relative;overflow:hidden;
}
.btn i{font-size:13px;transition:transform .3s var(--ease-spring)}
.btn:hover i{transform:translateX(3px)}
.btn--primary{background:var(--navy-soft);color:#fff;border-color:var(--navy-soft)}
.btn--primary:hover{background:var(--navy-mid);border-color:var(--navy-mid);color:#fff;box-shadow:var(--sh-md)}
.btn--accent{background:var(--amber);color:#fff;border-color:var(--amber)}
.btn--accent:hover{background:var(--copper);border-color:var(--copper);color:#fff;transform:translateY(-2px);box-shadow:var(--sh-glow)}
.btn--outline{background:transparent;border-color:var(--navy-soft);color:var(--navy-soft)}
.btn--outline:hover{background:var(--navy-soft);color:#fff}
.btn--outline-light{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.btn--outline-light:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.btn--outline-dark{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn--outline-dark:hover{background:var(--ink);color:#fff}
.btn--dark{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn--dark:hover{background:var(--navy-mid);border-color:var(--navy-mid);color:#fff}
.btn--glass{background:rgba(255,255,255,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;border-color:rgba(255,255,255,.25)}
.btn--glass:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.5);color:#fff}
.btn--lg{padding:17px 40px;font-size:16px}

.play-ring{
    width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.5);
    display:flex;align-items:center;justify-content:center;font-size:12px;
    transition:all .3s var(--ease-spring);
}
.btn:hover .play-ring{border-color:#fff;background:rgba(255,255,255,.15)}

/* ═══════════════════════ ALERTS ═══════════════════════ */
.alert{padding:14px 20px;border-radius:var(--r-sm);font-size:14px;font-weight:500}
.alert--success{background:#dff5e5;color:#155724}
.alert--danger{background:#fde8e8;color:#721c24}

/* ═══════════════════════ FADE-IN ═══════════════════════ */
.fade-in{opacity:0;transform:translateY(36px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════ TOPBAR ═══════════════════════ */
.topbar{background:var(--navy);color:rgba(255,255,255,.85);font-size:13px;padding:7px 0;transition:margin var(--dur) var(--ease-out)}
.topbar.hidden{margin-top:-40px}
.topbar__inner{display:flex;justify-content:space-between;align-items:center}
.topbar__credentials{display:flex;gap:18px}
.topbar__tag{display:inline-flex;align-items:center;gap:5px;font-weight:600;letter-spacing:.5px}
.topbar__tag i{color:var(--amber);font-size:12px}
.topbar__actions{display:flex;align-items:center;gap:16px}
.topbar__phone{color:rgba(255,255,255,.9);font-weight:600;display:flex;align-items:center;gap:6px;transition:color .3s}
.topbar__phone:hover{color:var(--amber)}
.topbar__social{display:flex;gap:6px}
.topbar__social a{
    width:26px;height:26px;display:flex;align-items:center;justify-content:center;
    border-radius:50%;color:rgba(255,255,255,.6);font-size:12px;transition:all .3s;
}
.topbar__social a:hover{color:#fff;background:rgba(255,255,255,.12)}

/* ═══════════════════════ HEADER ═══════════════════════ */
.site-header{
    background:var(--surface);padding:14px 0;position:sticky;top:0;z-index:1000;
    transition:all var(--dur) var(--ease-out);border-bottom:1px solid transparent;
}
.site-header.scrolled{box-shadow:var(--sh-md);padding:10px 0;border-bottom-color:var(--border)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between}
.site-header__logo img{height:42px;width:auto}
.site-header__nav{display:flex;gap:2px}
.nav-link{
    padding:8px 16px;font-size:14px;font-weight:600;color:var(--ink-soft);
    border-radius:var(--r-sm);transition:all .3s;position:relative;
}
.nav-link:hover,.nav-link.active{color:var(--copper);background:rgba(198,122,60,.06)}
.site-header__cta{font-size:14px;padding:10px 26px}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1100}
.hamburger__line{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s var(--ease-out)}
.hamburger.active .hamburger__line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active .hamburger__line:nth-child(2){opacity:0}
.hamburger.active .hamburger__line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ═══════════════════════ MOBILE MENU ═══════════════════════ */
.mobile-overlay{position:fixed;inset:0;background:rgba(12,29,46,.6);z-index:1040;opacity:0;visibility:hidden;transition:all .3s;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.mobile-overlay.active{opacity:1;visibility:visible}
.mobile-menu{
    position:fixed;top:0;right:-320px;width:300px;height:100%;background:var(--surface);z-index:1050;
    padding:24px 28px;transition:right .4s var(--ease-out);display:flex;flex-direction:column;
    gap:4px;overflow-y:auto;box-shadow:var(--sh-lg);
}
.mobile-menu.active{right:0}
.mobile-menu__head{display:flex;align-items:center;gap:12px;padding-bottom:20px;margin-bottom:12px;border-bottom:1px solid var(--border)}
.mobile-menu__head img{border-radius:50%}
.mobile-menu__head span{font-family:var(--font-display);font-size:18px;color:var(--ink)}
.mobile-link{display:block;padding:14px 12px;font-size:15px;font-weight:600;color:var(--ink-soft);border-radius:var(--r-sm);transition:all .3s}
.mobile-link:hover{color:var(--copper);background:rgba(198,122,60,.06);padding-left:18px}
.mobile-menu__cta{margin-top:auto;text-align:center;width:100%}

/* ═══════════════════════ VIDEO MODAL ═══════════════════════ */
.video-modal{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s}
.video-modal.active{opacity:1;visibility:visible}
.video-modal__frame{width:90%;max-width:900px;aspect-ratio:16/9}
.video-modal__frame iframe{width:100%;height:100%;border-radius:var(--r-md)}
.video-modal__close{position:absolute;top:20px;right:30px;background:none;border:none;color:#fff;font-size:42px;cursor:pointer;z-index:10000;line-height:1;opacity:.7;transition:opacity .3s}
.video-modal__close:hover{opacity:1}

/* ═══════════════════════ HERO ═══════════════════════ */
.hero{
    position:relative;background:var(--navy);color:#fff;
    padding:100px 0 160px;overflow:hidden;
}
.hero__noise{
    position:absolute;inset:0;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
    background-size:200px;opacity:.5;pointer-events:none;
}
.hero__gradient{
    position:absolute;inset:0;
    background:
        radial-gradient(ellipse 70% 60% at 10% 90%, rgba(198,122,60,.18) 0%, transparent 60%),
        radial-gradient(ellipse 50% 50% at 80% 20%, rgba(42,90,140,.2) 0%, transparent 60%),
        linear-gradient(160deg, var(--navy) 0%, var(--navy-mid) 50%, #0f2438 100%);
    pointer-events:none;
}
.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}

/* Hero text */
.hero__text{opacity:0;transform:translateY(40px);transition:all .8s var(--ease-out)}
.hero__text.entered{opacity:1;transform:translateY(0)}
.hero__kicker{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);padding:8px 20px;border-radius:50px;font-size:14px;font-weight:600;margin-bottom:24px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.08)}
.hero__kicker img{border-radius:4px}
.hero__title{font-size:clamp(34px,5vw,56px);margin-bottom:22px;line-height:1.1}
.hero__title em{font-style:normal;color:var(--amber-hot);display:block}
.hero__desc{font-size:18px;opacity:.8;margin-bottom:34px;max-width:480px;line-height:1.7}
.hero__ctas{display:flex;gap:16px;flex-wrap:wrap}

/* Hero visual */
.hero__visual{position:relative;opacity:0;transform:translateX(40px);transition:all .9s var(--ease-out) .2s}
.hero__visual.entered{opacity:1;transform:translateX(0)}
.hero__card{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg)}
.hero__card img{width:100%;height:100%;object-fit:cover}
.hero__card--main{height:340px;border:3px solid rgba(255,255,255,.1)}
.hero__card--secondary{
    position:absolute;bottom:-30px;right:-20px;width:55%;height:200px;
    border:3px solid rgba(255,255,255,.12);
}
.hero__float-badge{
    position:absolute;top:20px;left:-20px;width:70px;height:70px;
    background:var(--amber);border-radius:50%;display:flex;flex-direction:column;
    align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:800;
    letter-spacing:1px;box-shadow:var(--sh-glow);animation:float 3s ease-in-out infinite;
    text-align:center;line-height:1.2;
}
.hero__float-badge i{font-size:16px;margin-bottom:2px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* Marquee */
.marquee{position:relative;z-index:2;margin-top:50px;overflow:hidden;padding:14px 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.marquee__track{display:flex;gap:50px;animation:scroll 35s linear infinite;white-space:nowrap}
.marquee__item{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:rgba(255,255,255,.5);flex-shrink:0;letter-spacing:.5px;text-transform:uppercase}
.marquee__item i{color:var(--amber);font-size:14px}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.hero__divider{position:absolute;bottom:-1px;left:0;width:100%;z-index:3}
.hero__divider svg{display:block;width:100%;height:auto}

/* ═══════════════════════ PILLARS ═══════════════════════ */
.pillars{padding:60px 0 80px;background:var(--surface)}
.pillars__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.pillar{padding:32px 24px;border-radius:var(--r-md);transition:all var(--dur) var(--ease-out);position:relative;text-align:center}
.pillar::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:3px;background:var(--amber);transition:all .4s var(--ease-out);transform:translateX(-50%);border-radius:2px}
.pillar:hover::after{width:40px}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.pillar__icon{
    width:56px;height:56px;border-radius:var(--r-md);
    background:linear-gradient(135deg,var(--navy-soft),var(--navy-mid));
    color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:20px;margin:0 auto 16px;
}
.pillar__title{font-family:var(--font-body);font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px}
.pillar__text{font-size:14px;color:var(--ink-muted);line-height:1.6}

/* ═══════════════════════ TRANSFORM ═══════════════════════ */
.transform{padding:var(--space-3xl) 0;background:var(--surface-2)}
.transform__grid{display:grid;grid-template-columns:1fr auto 1fr;gap:28px;max-width:860px;margin:0 auto}
.transform__col{background:var(--surface);border-radius:var(--r-md);padding:28px;box-shadow:var(--sh-sm)}
.transform__label{display:flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:16px;font-weight:700;margin-bottom:18px;padding-bottom:14px;border-bottom:2px solid var(--border)}
.transform__col--before .transform__label i{color:var(--danger)}
.transform__col--after .transform__label i{color:var(--success)}
.transform__col ul li{padding:7px 0;font-size:14px;display:flex;align-items:flex-start;gap:8px}
.transform__col--before li i{color:var(--danger);margin-top:3px;font-size:12px}
.transform__col--after li i{color:var(--success);margin-top:3px;font-size:12px}
.transform__arrow{display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--amber);padding-top:50px}

/* ═══════════════════════ ABOUT ═══════════════════════ */
.about{padding:var(--space-3xl) 0}
.about__layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about__media{position:relative}
.about__img-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg)}
.about__img-frame img{width:100%;height:420px;object-fit:cover}
.about__logo-float{
    position:absolute;top:-16px;right:-16px;width:90px;height:90px;background:var(--surface);
    border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-md);z-index:2;
}
.about__content p{color:var(--ink-muted);margin-bottom:16px;font-size:15px}
.about__stats{display:flex;gap:32px;margin-top:28px;padding-top:24px;border-top:1px solid var(--border)}
.about__stat{text-align:center}
.about__stat strong{display:block;font-size:28px;font-weight:800;color:var(--navy-soft);font-family:var(--font-body)}
.about__stat span{font-size:13px;color:var(--ink-muted)}

/* ═══════════════════════ MVV ═══════════════════════ */
.mvv{padding:var(--space-3xl) 0;background:var(--surface-2)}
.mvv__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.mvv__card{
    background:var(--surface);border-radius:var(--r-md);padding:36px 28px;text-align:center;
    box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease-out);
    border-top:3px solid transparent;
}
.mvv__card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-top-color:var(--amber)}
.mvv__icon{
    width:64px;height:64px;border-radius:50%;
    background:linear-gradient(135deg,var(--navy-soft),var(--navy-mid));
    color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:24px;margin:0 auto 18px;
}
.mvv__card h3{font-size:22px;margin-bottom:12px}
.mvv__card p{font-size:14px;color:var(--ink-muted);line-height:1.7}

/* ═══════════════════════ CAREER PLAN ═══════════════════════ */
.plan{padding:var(--space-3xl) 0}
.plan__layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.plan__content p{color:var(--ink-muted);margin-bottom:24px;font-size:15px}
.plan__logos{display:flex;gap:20px;align-items:center;margin-top:28px;flex-wrap:wrap}
.plan__logos img{filter:grayscale(100%);opacity:.5;transition:all .3s}
.plan__logos img:hover{filter:grayscale(0%);opacity:1}
.plan__visual{position:relative}
.plan__visual>img{border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%}
.plan__badge{
    position:absolute;top:16px;right:16px;background:var(--amber);color:#fff;
    padding:12px 20px;border-radius:var(--r-sm);font-weight:700;font-size:14px;
    box-shadow:var(--sh-glow);font-family:var(--font-body);
}

/* ═══════════════════════ PROGRAMS ═══════════════════════ */
.programs{padding:var(--space-3xl) 0;background:var(--surface-2)}
.programs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.prog-card{
    background:var(--surface);border-radius:var(--r-md);overflow:hidden;
    box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease-out);
}
.prog-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.prog-card__img{position:relative;overflow:hidden}
.prog-card__img img{width:100%;height:200px;object-fit:cover;transition:transform .6s var(--ease-out)}
.prog-card:hover .prog-card__img img{transform:scale(1.06)}
.prog-card__badge{
    position:absolute;top:12px;right:12px;background:var(--amber);color:#fff;
    padding:4px 14px;border-radius:50px;font-size:12px;font-weight:700;
}
.prog-card__body{padding:24px}
.prog-card__body h3{font-size:19px;margin-bottom:10px}
.prog-card__body p{font-size:14px;color:var(--ink-muted);margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.prog-card__meta{display:flex;gap:16px;margin-bottom:14px}
.prog-card__meta span{font-size:13px;color:var(--ink-muted);display:flex;align-items:center;gap:5px}
.prog-card__meta i{color:var(--amber);font-size:12px}
.prog-card__link{
    font-size:14px;font-weight:700;color:var(--navy-soft);
    display:inline-flex;align-items:center;gap:6px;transition:all .3s;
}
.prog-card__link:hover{color:var(--copper);gap:10px}

.programs__also{background:var(--surface);border-radius:var(--r-md);padding:28px;margin-top:36px;box-shadow:var(--sh-sm)}
.programs__also h3{font-family:var(--font-body);font-size:17px;font-weight:700;color:var(--navy-soft);margin-bottom:18px}
.programs__also h3 i{color:var(--amber)}
.programs__also-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.also-chip{
    display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--r-sm);
    border:1px solid var(--border);font-size:14px;font-weight:600;color:var(--ink-soft);transition:all .3s;
}
.also-chip:hover{background:var(--navy-soft);color:#fff;border-color:var(--navy-soft)}
.also-chip i{color:var(--amber);font-size:15px}
.also-chip:hover i{color:#fff}
.programs__cta{text-align:center;margin-top:36px}

/* ═══════════════════════ CAMPUS ═══════════════════════ */
.campus{padding:var(--space-3xl) 0}
.campus__layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.campus__content p{color:var(--ink-muted);margin-bottom:24px;font-size:15px}
.campus__features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.campus__feat{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--ink-soft)}
.campus__feat i{color:var(--amber);font-size:16px}
.campus__media img{border-radius:var(--r-lg);box-shadow:var(--sh-lg)}

/* ═══════════════════════ LEVELS ═══════════════════════ */
.levels{padding:var(--space-3xl) 0;background:var(--surface-2)}
.levels__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.level-card{border-radius:var(--r-md);overflow:hidden;position:relative;height:300px}
.level-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.level-card:hover img{transform:scale(1.06)}
.level-card__overlay{
    position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(12,29,46,.88));
    display:flex;flex-direction:column;justify-content:flex-end;padding:24px 20px;color:#fff;
}
.level-card__overlay h3{font-size:20px;margin-bottom:4px;color:#fff}
.level-card__overlay p{font-size:13px;opacity:.8}

/* ═══════════════════════ PARTNERS ═══════════════════════ */
.partners{padding:40px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.partners__label{text-align:center;font-size:13px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:2px;font-weight:600;margin-bottom:22px}
.partners__row{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.partners__row img{height:40px;filter:grayscale(100%);opacity:.4;transition:all .3s}
.partners__row img:hover{filter:grayscale(0%);opacity:1}

/* ═══════════════════════ BONUS (HYPERFOCO) ═══════════════════════ */
.bonus{padding:var(--space-3xl) 0}
.bonus__card{
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 60%,#1a4872 100%);
    border-radius:var(--r-xl);padding:60px;display:grid;grid-template-columns:1fr auto;
    gap:60px;align-items:center;color:#fff;position:relative;overflow:hidden;
}
.bonus__card::before{
    content:'';position:absolute;top:-80px;right:-80px;width:300px;height:300px;
    background:radial-gradient(circle,rgba(232,136,43,.15) 0%,transparent 70%);pointer-events:none;
}
.bonus__content p{opacity:.85;margin-bottom:20px;font-size:15px}
.bonus__list{margin-bottom:28px}
.bonus__list li{padding:5px 0;font-size:15px;display:flex;align-items:center;gap:10px;font-weight:500}
.bonus__list i{color:var(--amber-hot);font-size:14px}
.bonus__glyph{font-size:140px;opacity:.08;color:var(--amber)}

/* ═══════════════════════ TESTIMONIALS ═══════════════════════ */
.testimonials{padding:var(--space-3xl) 0;background:var(--surface-2)}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.testi-card{
    background:var(--surface);border-radius:var(--r-md);padding:32px;
    box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease-out);
    border-left:4px solid transparent;
}
.testi-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-left-color:var(--amber)}
.testi-card__quote{color:var(--amber);font-size:28px;margin-bottom:14px}
.testi-card__text{font-size:14px;color:var(--ink-muted);line-height:1.75;margin-bottom:20px;font-style:italic}
.testi-card__author{display:flex;align-items:center;gap:12px}
.testi-card__author img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.testi-card__avatar{
    width:46px;height:46px;border-radius:50%;background:var(--navy-soft);color:#fff;
    display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;
    font-family:var(--font-display);
}
.testi-card__author strong{display:block;font-size:15px;font-family:var(--font-body);font-weight:700;color:var(--ink)}
.testi-card__author span{font-size:13px;color:var(--ink-muted)}

/* ═══════════════════════ COUNTERS ═══════════════════════ */
.counters{position:relative;padding:var(--space-3xl) 0;color:#fff;overflow:hidden}
.counters__bg{
    position:absolute;inset:0;
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 50%,#14394f 100%);
}
.counters__bg::after{
    content:'';position:absolute;inset:0;
    background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0L60 30L30 60L0 30Z' fill='none' stroke='rgba(255,255,255,.03)' stroke-width='1'/%3E%3C/svg%3E");
}
.counters .container{position:relative;z-index:2}
.counters__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:center}
.counter__number{
    display:block;font-size:clamp(36px,5vw,52px);font-weight:800;
    font-family:var(--font-body);margin-bottom:6px;color:var(--amber-hot);
}
.counter__label{font-size:14px;opacity:.7;text-transform:uppercase;letter-spacing:1.5px;font-weight:600}

/* ═══════════════════════ CTA BAND ═══════════════════════ */
.cta-band{padding:80px 0;background:var(--amber);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--amber) 0%,var(--copper) 100%);
}
.cta-band__inner{position:relative;z-index:2}
.cta-band h2{font-size:clamp(26px,3.5vw,38px);margin-bottom:14px;color:#fff}
.cta-band p{font-size:17px;opacity:.9;max-width:560px;margin:0 auto 28px}
.cta-band__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════ CONTACT ═══════════════════════ */
.contact{padding:var(--space-3xl) 0}
.contact__layout{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.contact__media img{border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;height:520px;object-fit:cover}
.contact__sub{color:var(--ink-muted);margin-bottom:28px;font-size:15px}

.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.field input,.field select,.field textarea{
    width:100%;padding:13px 16px;border:2px solid var(--border);border-radius:var(--r-sm);
    font-size:15px;transition:border-color .3s;background:var(--surface);color:var(--ink);
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy-soft)}
.field select{
    appearance:none;cursor:pointer;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b6b82' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;
}
.contact-form__submit{width:100%;justify-content:center;margin-top:4px}

.form-success{display:flex;align-items:center;justify-content:center;padding:50px 20px}
.form-success__inner{text-align:center}
.form-success__inner i{font-size:52px;color:var(--success);margin-bottom:16px;display:block}
.form-success__inner h3{font-size:24px;margin-bottom:8px}
.form-success__inner p{color:var(--ink-muted)}

/* ═══════════════════════ PREFOOTER ═══════════════════════ */
.prefooter{position:relative;padding:80px 0;overflow:hidden;color:#fff}
.prefooter__bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%)}
.prefooter__inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.prefooter__title{font-size:clamp(28px,4vw,40px);color:#fff;margin-bottom:8px}
.prefooter__sub{opacity:.75;font-size:16px}
.prefooter__actions{display:flex;gap:14px;flex-wrap:wrap}

/* ═══════════════════════ FOOTER ═══════════════════════ */
.site-footer{background:var(--navy);color:rgba(255,255,255,.75);padding:60px 0 0}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px}
.footer__logo{height:38px;width:auto;margin-bottom:14px;filter:brightness(10)}
.footer__brand p{font-size:14px;line-height:1.7;margin-bottom:18px}
.footer__social{display:flex;gap:8px}
.footer__social a{
    width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.15);
    display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);
    font-size:14px;transition:all .3s;
}
.footer__social a:hover{background:var(--amber);border-color:var(--amber);color:#fff}
.footer__col h4{
    font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;
    margin-bottom:18px;padding-bottom:10px;position:relative;
}
.footer__col h4::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:2px;background:var(--amber)}
.footer__col ul li{margin-bottom:9px}
.footer__col ul a{color:rgba(255,255,255,.6);font-size:14px;transition:all .3s}
.footer__col ul a:hover{color:var(--amber);padding-left:4px}
.footer__see-all{font-weight:700;color:var(--amber) !important}
.footer__contact-list li{display:flex;gap:10px;margin-bottom:12px;font-size:14px}
.footer__contact-list i{color:var(--amber);margin-top:3px;width:14px;text-align:center;flex-shrink:0}
.footer__contact-list a{color:rgba(255,255,255,.6)}
.footer__contact-list a:hover{color:var(--amber)}

.footer__bottom{margin-top:36px;padding:18px 0;border-top:1px solid rgba(255,255,255,.08)}
.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center}
.footer__bottom p{font-size:13px;color:rgba(255,255,255,.4)}
.footer__badges{display:flex;gap:16px}
.footer__badges span{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3)}

/* ═══════════════════════ WHATSAPP FAB ═══════════════════════ */
.whatsapp-fab{
    position:fixed;bottom:90px;right:24px;width:58px;height:58px;
    background:#25D366;color:#fff;border-radius:50%;display:flex;
    align-items:center;justify-content:center;font-size:26px;z-index:999;
    box-shadow:0 4px 14px rgba(37,211,102,.4);transition:all .3s;
}
.whatsapp-fab:hover{transform:scale(1.1);color:#fff;box-shadow:0 6px 20px rgba(37,211,102,.5)}
.whatsapp-fab__pulse{
    position:absolute;inset:-6px;border-radius:50%;border:2px solid #25D366;
    animation:wa-pulse 2s ease-out infinite;pointer-events:none;
}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.4);opacity:0}}

/* ═══════════════════════ MOBILE BAR ═══════════════════════ */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:998;box-shadow:0 -2px 10px rgba(0,0,0,.1)}
.mobile-bar__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;font-size:15px;font-weight:700}
.mobile-bar__call{background:var(--navy-soft);color:#fff}
.mobile-bar__wa{background:#25D366;color:#fff}

/* ═══════════════════════ RESPONSIVE ═══════════════════════ */
@media(max-width:1024px){
    .hero__inner{grid-template-columns:1fr;text-align:center}
    .hero__visual{display:none}
    .hero__title{font-size:clamp(30px,5vw,44px)}
    .hero__desc{margin:0 auto 34px}
    .hero__ctas{justify-content:center}
    .pillars__grid{grid-template-columns:repeat(2,1fr)}
    .about__layout,.plan__layout,.campus__layout,.contact__layout{grid-template-columns:1fr;gap:40px}
    .programs__grid{grid-template-columns:repeat(2,1fr)}
    .programs__also-grid{grid-template-columns:repeat(2,1fr)}
    .testimonials__grid{grid-template-columns:repeat(2,1fr)}
    .counters__grid{grid-template-columns:repeat(2,1fr)}
    .levels__grid{grid-template-columns:repeat(2,1fr)}
    .footer__grid{grid-template-columns:repeat(2,1fr)}
    .transform__grid{grid-template-columns:1fr}
    .transform__arrow{padding:0;transform:rotate(90deg)}
    .prefooter__inner{flex-direction:column;text-align:center}
    .prefooter__actions{justify-content:center}
    .bonus__card{grid-template-columns:1fr;padding:40px}
    .bonus__glyph{display:none}
}

@media(max-width:768px){
    section{padding:60px 0}
    .topbar__credentials{display:none}
    .site-header__nav,.site-header__cta{display:none}
    .hamburger{display:flex}
    .hero{padding:60px 0 120px}
    .hero__ctas{flex-direction:column;align-items:center}
    .hero__ctas .btn{width:100%;max-width:280px;justify-content:center}
    .pillars__grid,.mvv__grid,.programs__grid,.testimonials__grid,.levels__grid{grid-template-columns:1fr}
    .programs__also-grid{grid-template-columns:1fr}
    .footer__grid{grid-template-columns:1fr}
    .contact-form__row{grid-template-columns:1fr}
    .campus__features{grid-template-columns:1fr}
    .footer__bottom-inner{flex-direction:column;gap:8px;text-align:center}
    .about__logo-float{top:-10px;right:-10px;width:70px;height:70px}
    .cta-band h2{font-size:24px}
    .mobile-bar{display:flex}
    .whatsapp-fab{bottom:68px;right:16px;width:50px;height:50px;font-size:22px}
    body{padding-bottom:52px}
    .contact__media{display:none}
    .counters__grid{gap:20px}
    .bonus__card{padding:32px 24px}
}

@media(max-width:480px){
    .container{padding:0 16px}
    .btn--lg{padding:14px 28px;font-size:15px}
    .counter__number{font-size:34px}
    .hero__title{font-size:28px}
}
