/* ════════════════════════════════════════════════════════════════════
   TOP EDUCATION SOLUTIONS — index.html Styles
   index.css · Homepage only
   Version 5.0 · June 2026 — TES4 + Programs Hub
════════════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ─────────────────────────────────────────────────── */
:root {
  --green-950:#080f24; --green-900:#0f1e3c; --green-800:#162d5a;
  --green-700:#1e3d7a; --green-600:#2952a3; --green-500:#3a6bc4;
  --green-400:#5285d6; --green-100:#dbeafe; --green-50:#eff6ff;
  --gold:#c9a227; --gold-lt:#e2b83a; --gold-pale:#fdf3d0; --gold-deep:#a07c0f;
  --cream:#faf8f3; --cream-dark:#f0ede7; --white:#ffffff;
  --text:#1c1c1e; --text-md:#3d3d3f; --text-muted:#6b7280;
  --border:rgba(0,0,0,0.08);
  --shadow-sm:0 1px 4px rgba(0,0,0,0.06);
  --shadow-md:0 4px 20px rgba(0,0,0,0.09);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.13);
  --r:8px; --r-md:12px; --r-lg:20px; --r-xl:28px;
  --t:0.18s ease; --t-md:0.28s ease;
  --px:clamp(16px,5vw,48px); --max:1240px;
}

/* ── RESET + BASE ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
ul,ol{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
::selection{background:rgba(201,162,39,0.25);color:#0d2118;}

/* ── UTILITIES ─────────────────────────────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--px);}
.section{padding:88px var(--px);}
.section--alt{background:var(--white);}
.section--dark{background:var(--green-900);}
.section--green{background:var(--green-800);}
.section--cream{background:var(--cream);}
.section__header{text-align:center;max-width:680px;margin:0 auto 56px;}
.section__label{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);background:var(--gold-pale);padding:5px 14px;border-radius:50px;margin-bottom:16px;}
.section__label--light{background:rgba(201,162,39,.15);color:var(--gold-lt);}
.section__title{font-family:'Playfair Display',serif;font-size:clamp(26px,3.5vw,40px);font-weight:700;line-height:1.25;color:var(--text);margin-bottom:16px;}
.section__title--light{color:var(--white);}
.section__desc{font-size:16px;color:var(--text-muted);line-height:1.75;}
.section__desc--light{color:rgba(255,255,255,.7);}

/* ── BUTTONS ───────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--r-md);font-size:14px;font-weight:700;transition:all var(--t);cursor:pointer;border:none;white-space:nowrap;}
.btn--gold{background:var(--gold);color:var(--green-900);box-shadow:0 3px 12px rgba(201,162,39,.35);}
.btn--gold:hover{background:var(--gold-lt);transform:translateY(-1px);box-shadow:0 5px 20px rgba(201,162,39,.45);}
.btn--green{background:var(--green-600);color:var(--white);box-shadow:0 3px 12px rgba(41,82,163,.3);}
.btn--green:hover{background:var(--green-500);transform:translateY(-1px);}
.btn--ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.4);}
.btn--ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7);}
.btn--outline-gold{background:transparent;color:var(--gold);border:1.5px solid var(--gold);}
.btn--outline-gold:hover{background:var(--gold);color:var(--green-900);}
.btn--lg{padding:15px 32px;font-size:15px;}
.btn--sm{padding:9px 18px;font-size:13px;}

/* ── BADGES ────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:50px;}
.badge--gold{background:var(--gold);color:var(--green-900);}
.badge--green{background:var(--green-100);color:var(--green-700);}
.badge--red{background:#fee2e2;color:#991b1b;}
.badge--orange{background:#ffedd5;color:#9a3412;}
.badge--blue{background:#dbeafe;color:#1e40af;}

/* ── ANNOUNCE BAR ──────────────────────────────────────────────────── */
.announce-bar{background:var(--gold);color:var(--green-900);padding:10px var(--px);text-align:center;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:12px;}
.announce-bar a{text-decoration:underline;color:var(--green-900);font-weight:800;}
.announce-bar__pulse{width:8px;height:8px;border-radius:50%;background:var(--green-800);animation:pulse 1.6s ease-in-out infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.4);opacity:.6;}}

/* ── TOPBAR / NAV ──────────────────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:200;background:var(--green-900);border-bottom:1px solid rgba(255,255,255,.07);box-shadow:0 2px 16px rgba(0,0,0,.25);}
.topbar__inner{max-width:var(--max);margin:0 auto;padding:0 var(--px);height:132px;display:flex;align-items:center;gap:20px;position:relative;}
.topbar__logo{display:flex;align-items:center;gap:12px;flex-shrink:0;text-decoration:none;}
.topbar__logo img{height:148px;width:auto;}
.topbar__brand{font-size:15px;font-weight:800;color:var(--white);line-height:1.2;}
.topbar__brand span{display:block;font-size:11px;font-weight:500;color:var(--gold);letter-spacing:.04em;}
.topbar__nav{display:flex;align-items:center;gap:0;position:absolute;left:50%;transform:translateX(-50%);}
.nav-link{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:var(--r);font-size:13px;font-weight:600;color:rgba(255,255,255,.75);transition:all var(--t);white-space:nowrap;}
.nav-link:hover{color:var(--white);background:rgba(255,255,255,.08);}
.nav-link--gold{color:var(--gold);}
.nav-link--gold:hover{background:rgba(201,162,39,.12);color:var(--gold-lt);}
.nav-link--cta{background:var(--gold);color:var(--green-900);border-radius:var(--r-md);padding:9px 18px;font-weight:800;}
.nav-link--cta:hover{background:var(--gold-lt);color:var(--green-900);}
.topbar__toggle{display:none;color:var(--white);margin-left:auto;padding:6px;}
.mobile-nav{display:none;flex-direction:column;gap:4px;background:var(--green-900);padding:16px var(--px) 20px;border-top:1px solid rgba(255,255,255,.07);}
.mobile-nav.open{display:flex;}

/* ── NAV DROPDOWN ──────────────────────────────────────────────────── */
.nav-dropdown{position:relative;}
.nav-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;background:white;border-radius:var(--r-md);box-shadow:0 12px 40px rgba(15,30,60,0.15);min-width:260px;padding:8px 0;display:none;z-index:300;border:1px solid rgba(15,30,60,0.06);}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown.open .nav-dropdown-menu{display:block;}
.nav-dropdown-menu a{display:flex;align-items:center;gap:10px;padding:10px 18px;font-size:14px;color:var(--text);text-decoration:none;transition:all .15s;font-weight:500;}
.nav-dropdown-menu a:hover{background:var(--green-50);color:var(--green-600);}
.nav-dropdown-label{padding:8px 18px 4px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);}
.nav-dropdown-divider{height:1px;background:var(--border);margin:6px 12px;}

/* ── HERO ──────────────────────────────────────────────────────────── */
.hero{background:var(--green-900);padding:80px var(--px);position:relative;overflow:hidden;background-image:url('images/30.jpeg');background-size:cover;background-position:center 20%;}
.hero::before{content:'';position:absolute;inset:0;background:rgba(8,15,36,.82);}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(201,162,39,.06) 0%,transparent 60%),radial-gradient(ellipse 50% 60% at 10% 80%,rgba(41,82,163,.25) 0%,transparent 50%);}
.hero__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 420px;gap:64px;align-items:center;position:relative;z-index:2;}
.hero__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;}
.hero__eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);}
.hero__title{font-family:'Playfair Display',serif;font-size:clamp(32px,4.5vw,54px);font-weight:700;line-height:1.2;color:var(--white);margin-bottom:24px;}
.hero__title em{color:var(--gold);font-style:italic;}
.hero__subtitle{font-size:17px;color:rgba(255,255,255,.72);line-height:1.75;max-width:560px;margin-bottom:36px;}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px;}
.hero__trust{display:flex;align-items:center;gap:16px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;}
.hero__trust-item{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,.6);font-weight:500;}
.hero__trust-item svg{color:var(--gold);flex-shrink:0;}
.hero__paths{display:flex;flex-direction:column;gap:12px;}
.path-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-left:2px solid var(--gold);border-radius:var(--r-md);padding:14px 18px;display:flex;align-items:center;gap:14px;transition:all var(--t-md);cursor:pointer;text-decoration:none;}
.path-card:hover{background:rgba(255,255,255,.09);border-color:var(--gold);border-left-color:var(--gold);transform:translateX(5px);}
.path-card__icon{display:none;}
.path-card__body{flex:1;}
.path-card__title{font-size:14px;font-weight:700;color:var(--white);margin-bottom:2px;letter-spacing:.01em;}
.path-card__desc{font-size:12px;color:rgba(255,255,255,.5);line-height:1.5;}
.path-card__arrow{color:var(--gold);flex-shrink:0;opacity:.4;transition:all var(--t);font-size:16px;}
.path-card:hover .path-card__arrow{opacity:1;transform:translateX(3px);}

/* ── LIVE CLASSES ──────────────────────────────────────────────────── */
.live-section{padding:88px var(--px);background:var(--cream);}
.live-indicator{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#dc2626;background:#fee2e2;padding:5px 12px;border-radius:50px;}
.live-dot{width:7px;height:7px;border-radius:50%;background:#dc2626;animation:pulse 1.4s ease-in-out infinite;}
.live-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px;}
.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;}
.class-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--t-md);display:flex;flex-direction:column;}
.class-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);}
.class-card__top{padding:20px 22px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.class-card__subject{font-size:17px;font-weight:800;color:var(--text);margin-bottom:4px;}
.class-card__grade{font-size:12px;color:var(--text-muted);font-weight:500;}
.class-card__body{padding:16px 22px;flex:1;}
.class-info-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-md);margin-bottom:10px;}
.class-info-row svg{color:var(--green-600);flex-shrink:0;}
.class-card__footer{padding:14px 22px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.seats-info{display:flex;flex-direction:column;gap:3px;}
.seats-badge{font-size:11px;font-weight:600;letter-spacing:.01em;}
.seats-badge--urgent{color:#dc2626;}
.seats-badge--warn{color:#d97706;}
.seats-badge--ok{color:var(--green-600);}
.seats-progress{width:80px;height:5px;background:#e5e7eb;border-radius:50px;overflow:hidden;}
.seats-progress__fill{height:100%;border-radius:50px;transition:width .4s ease;}
.seats-progress__fill--urgent{background:linear-gradient(90deg,#dc2626,#ef4444);}
.seats-progress__fill--warn{background:linear-gradient(90deg,#d97706,#f59e0b);}
.seats-progress__fill--ok{background:linear-gradient(90deg,var(--green-700),var(--green-500));}
.register-btn{background:var(--green-600);color:var(--white);border:none;border-radius:var(--r-md);padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;transition:all var(--t);white-space:nowrap;}
.register-btn:hover{background:var(--green-500);transform:scale(1.03);}
.register-btn--gold{background:var(--gold);color:var(--green-900);}
.register-btn--gold:hover{background:var(--gold-lt);}

/* ── PROGRAMS HUB ──────────────────────────────────────────────────── */
.programs-hub{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:var(--max);margin:0 auto;}
.program-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:28px 24px;transition:all var(--t-md);display:flex;flex-direction:column;gap:10px;text-decoration:none;}
.program-card:hover{border-color:var(--green-400);box-shadow:var(--shadow-md);transform:translateY(-3px);}
.program-card__emoji{font-size:32px;}
.program-card__title{font-family:'Playfair Display',serif;font-size:19px;font-weight:700;color:var(--text);}
.program-card__desc{font-size:13.5px;color:var(--text-muted);line-height:1.7;flex:1;}
.program-card__link{font-size:13px;font-weight:700;color:var(--green-600);margin-top:4px;}

/* ── LEARNING MODELS ───────────────────────────────────────────────── */
.models-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:var(--max);margin:0 auto;}
.model-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--border);padding:32px;transition:all var(--t-md);}
.model-card:hover{border-color:var(--green-400);box-shadow:var(--shadow-md);}
.model-card--featured{background:var(--green-800);border-color:transparent;}
.model-card__icon-wrap{width:56px;height:56px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:26px;}
.model-card__icon-wrap--gold{background:var(--gold-pale);}
.model-card__icon-wrap--green{background:var(--green-50);}
.model-card__icon-wrap--teal{background:#e0f2fe;}
.model-card__tag{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:block;}
.model-card__title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:10px;line-height:1.3;}
.model-card--featured .model-card__title{color:var(--white);}
.model-card__desc{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:20px;}
.model-card--featured .model-card__desc{color:rgba(255,255,255,.65);}
.model-card__list{display:flex;flex-direction:column;gap:8px;}
.model-card__list li{display:flex;align-items:flex-start;gap:9px;font-size:13.5px;color:var(--text-md);}
.model-card--featured .model-card__list li{color:rgba(255,255,255,.75);}
.model-card__list li::before{content:'✓';color:var(--green-600);font-weight:800;flex-shrink:0;margin-top:1px;font-size:13px;}
.model-card--featured .model-card__list li::before{color:var(--gold);}

/* ── FEATURES / PLATFORM ───────────────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--max);margin:0 auto;}
.feature-card{display:flex;gap:18px;padding:24px;border-radius:var(--r-lg);background:var(--white);border:1px solid var(--border);transition:all var(--t-md);}
.feature-card:hover{background:var(--green-50);border-color:var(--green-400);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.feature-icon{width:52px;height:52px;border-radius:var(--r-md);background:var(--green-900);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.feature-text h3{font-size:16px;font-weight:700;color:var(--green-800);margin-bottom:6px;}
.feature-text p{font-size:13px;color:var(--text-muted);line-height:1.65;}

/* ── SCHOOLS LISTING ───────────────────────────────────────────────── */
.schools-grid-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:var(--max);margin:0 auto;}
.schools-col h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--green-800);margin-bottom:18px;padding-bottom:10px;border-bottom:2px solid var(--green-100);}
.school-item{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border);font-size:14px;font-weight:500;}
.school-item:last-child{border-bottom:none;}
.school-dot{width:8px;height:8px;border-radius:50%;background:var(--green-600);flex-shrink:0;}
.school-new{background:var(--gold);color:var(--green-900);font-size:10px;padding:2px 7px;border-radius:50px;font-weight:700;}

/* ── SUMMER BANNER ─────────────────────────────────────────────────── */
.summer-banner{background:linear-gradient(135deg,var(--green-900) 0%,#162d5a 50%,var(--green-800) 100%);padding:72px var(--px);position:relative;overflow:hidden;}
.summer-banner::before{content:'☀';position:absolute;right:-40px;top:-60px;font-size:280px;opacity:.04;line-height:1;}
.summer-banner__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;}
.summer-banner__early-bird{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:var(--green-900);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:50px;margin-bottom:18px;}
.summer-banner__title{font-family:'Playfair Display',serif;font-size:clamp(26px,3.5vw,40px);font-weight:700;color:var(--white);line-height:1.25;margin-bottom:14px;}
.summer-banner__desc{font-size:15px;color:rgba(255,255,255,.7);line-height:1.7;max-width:540px;margin-bottom:28px;}
.summer-programs-list{display:flex;flex-direction:column;gap:12px;}
.summer-prog-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;min-width:280px;}
.summer-prog-item__name{font-size:14px;font-weight:700;color:var(--white);margin-bottom:3px;}
.summer-prog-item__dates{font-size:12px;color:rgba(255,255,255,.55);}
.countdown-wrap{text-align:left;margin-top:28px;}
.countdown-label{font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;}
.countdown{display:flex;gap:8px;}
.countdown-unit{background:rgba(255,255,255,.08);border-radius:var(--r);padding:8px 12px;text-align:center;min-width:52px;}
.countdown-unit__num{font-size:22px;font-weight:800;color:var(--gold);line-height:1;}
.countdown-unit__label{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.45);margin-top:3px;}

/* ── SUBJECTS ──────────────────────────────────────────────────────── */
.subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;max-width:var(--max);margin:0 auto;}
.subject-chip{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-md);padding:16px 18px;display:flex;align-items:center;gap:11px;transition:all var(--t);}
.subject-chip:hover{border-color:var(--green-600);background:var(--green-50);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.subject-chip__icon{font-size:20px;flex-shrink:0;}
.subject-chip__name{font-size:13.5px;font-weight:700;color:var(--text);}
.subject-chip__level{font-size:11px;color:var(--text-muted);margin-top:2px;}

/* ── COMPETITION CARDS ─────────────────────────────────────────────── */
.competition-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--max);margin:0 auto;}
.comp-card{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all var(--t-md);}
.comp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.comp-header{padding:20px 22px;color:white;display:flex;align-items:center;gap:12px;}
.comp-header-amc8{background:linear-gradient(135deg,#7c3aed,#5b21b6);}
.comp-header-amc10{background:linear-gradient(135deg,var(--green-800),var(--green-600));}
.comp-header-amc12{background:linear-gradient(135deg,#b45309,#92400e);}
.comp-icon{font-size:28px;}
.comp-header h3{font-family:'Playfair Display',serif;font-size:18px;}
.comp-header p{font-size:12px;opacity:.8;}
.comp-body{padding:20px 22px;background:white;}
.comp-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--cream-dark);font-size:13px;}
.comp-row:last-child{border-bottom:none;}
.comp-label{color:var(--text-muted);font-weight:500;}
.comp-value{color:var(--text);font-weight:600;}

/* ── TJ SPOTLIGHT ──────────────────────────────────────────────────── */
.tj-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;max-width:var(--max);margin:0 auto;}
.tj-info-cards{display:flex;flex-direction:column;gap:14px;}
.tj-info-card{background:white;border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--shadow-sm);display:flex;gap:14px;align-items:flex-start;border:1px solid var(--border);}
.tj-info-card:hover{border-color:var(--green-400);box-shadow:var(--shadow-md);}
.tj-info-icon{font-size:22px;flex-shrink:0;margin-top:2px;}
.tj-info-card h4{font-family:'Playfair Display',serif;font-size:15px;color:var(--green-800);margin-bottom:4px;}
.tj-info-card p{font-size:13px;color:var(--text-muted);line-height:1.6;}
.tj-timeline{background:white;border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-lg);border:1px solid var(--border);}
.tj-timeline h3{font-family:'Playfair Display',serif;font-size:18px;color:var(--green-800);margin-bottom:20px;}
.timeline-item{display:flex;gap:16px;padding-bottom:20px;position:relative;}
.timeline-item:not(:last-child)::after{content:'';position:absolute;left:14px;top:30px;bottom:0;width:2px;background:var(--green-50);}
.timeline-dot{width:30px;height:30px;border-radius:50%;background:var(--green-600);display:flex;align-items:center;justify-content:center;color:white;font-size:12px;font-weight:700;flex-shrink:0;}
.timeline-content h4{font-size:14px;font-weight:600;color:var(--text);}
.timeline-content p{font-size:13px;color:var(--text-muted);margin-top:2px;}

/* ── TRUST CARDS ───────────────────────────────────────────────────── */
.trust-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;max-width:var(--max);margin:0 auto;}
.trust-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--border);padding:28px 24px;text-align:center;}
.trust-card__icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 16px;background:var(--green-50);}
.trust-card__title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px;}
.trust-card__desc{font-size:13px;color:var(--text-muted);line-height:1.65;}

/* ── FOUNDER ────────────────────────────────────────────────────────── */
.founder-wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;align-items:start;}
.founder-photo-col{display:flex;flex-direction:column;gap:16px;align-items:center;}
.founder-photo-frame{width:100%;max-width:480px;border-radius:var(--r-lg);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.18);border:3px solid var(--gold-pale);}
.founder-photo{width:100%;height:auto;display:block;}
.founder-badge-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.founder-badge{font-size:12px;font-weight:700;padding:6px 14px;border-radius:50px;background:var(--green-50);color:var(--green-700);border:1px solid var(--green-100);}
.founder-name{font-family:'Playfair Display',serif;font-size:clamp(30px,3.5vw,42px);font-weight:700;color:var(--text);margin-bottom:4px;}
.founder-role{font-size:13px;font-weight:700;color:var(--green-600);margin-bottom:6px;letter-spacing:.02em;}
.founder-tagline{font-size:13px;color:var(--text-muted);margin-bottom:20px;}
.founder-divider{width:48px;height:3px;background:var(--gold);border-radius:2px;margin-bottom:20px;}
.founder-para{font-size:14.5px;color:var(--text-md);line-height:1.85;margin-bottom:14px;}
.founder-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;}
@media(max-width:860px){
  .founder-wrap{grid-template-columns:1fr;gap:36px;}
  .founder-photo-frame{max-width:340px;}
}

/* ── EDUCATORS ─────────────────────────────────────────────────────── */
.educators-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px;max-width:var(--max);margin:0 auto;}
.educator-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;text-align:center;transition:all var(--t-md);}
.educator-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.educator-card__photo-wrap{position:relative;overflow:hidden;height:480px;}
.educator-card__photo-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.85));pointer-events:none;}
.educator-card__photo{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block;}
.educator-card__avatar{width:100%;height:400px;background:linear-gradient(135deg,var(--green-600),var(--green-400));display:flex;align-items:center;justify-content:center;font-size:80px;font-weight:800;color:white;font-family:'Playfair Display',serif;}
.educator-card__body{padding:20px 20px 22px;}
.educator-card__name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px;}
.educator-card__role{font-size:12px;color:var(--green-600);font-weight:600;margin-bottom:10px;}
.educator-card__subjects{font-size:12px;color:var(--text-muted);line-height:1.6;margin-bottom:14px;}
.educator-card__badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.05em;background:var(--green-50);color:var(--green-700);padding:3px 9px;border-radius:50px;}

/* ── BLOG ──────────────────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:var(--max);margin:0 auto;}
.blog-card{background:white;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--t-md);cursor:pointer;border:1px solid var(--border);}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.blog-img{height:160px;display:flex;align-items:center;justify-content:center;font-size:48px;}
.blog-img-1{background:linear-gradient(135deg,#dbeafe,#ede9fe);}
.blog-img-2{background:linear-gradient(135deg,#d1fae5,var(--green-50));}
.blog-img-3{background:linear-gradient(135deg,#fed7aa,#fef3c7);}
.blog-body{padding:20px;}
.blog-tag{display:inline-block;background:var(--green-50);color:var(--green-600);padding:3px 10px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;margin-bottom:10px;}
.blog-title{font-family:'Playfair Display',serif;font-size:16px;color:var(--text);margin-bottom:8px;line-height:1.4;}
.blog-excerpt{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:14px;}
.blog-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);}

/* ── NEWS ──────────────────────────────────────────────────────────── */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:var(--max);margin:0 auto;}
.news-card{background:white;border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-sm);border-left:4px solid var(--green-600);transition:all var(--t-md);cursor:pointer;border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);}
.news-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.news-category{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;border-radius:50px;margin-bottom:10px;}
.cat-sat{background:#dbeafe;color:#1e40af;}
.cat-tj{background:#ede9fe;color:#5b21b6;}
.cat-amc{background:#fef3c7;color:#92400e;}
.cat-general{background:var(--green-50);color:var(--green-600);}
.news-title{font-family:'Playfair Display',serif;font-size:15px;color:var(--text);margin-bottom:8px;line-height:1.4;}
.news-body{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:12px;}
.news-date{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px;}
.news-dot{width:6px;height:6px;border-radius:50%;background:var(--green-600);}

/* ── FAQ ───────────────────────────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:var(--max);margin:0 auto;}
.faq-item{background:white;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
.faq-question{padding:18px 20px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:14px;color:var(--text);gap:12px;transition:color var(--t);}
.faq-question:hover{color:var(--green-600);}
.faq-arrow{font-size:13px;color:var(--green-600);transition:transform .3s;flex-shrink:0;}
.faq-item.open .faq-arrow{transform:rotate(180deg);}
.faq-answer{padding:0 20px;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s;font-size:13px;color:var(--text-muted);line-height:1.7;}
.faq-item.open .faq-answer{max-height:300px;padding:0 20px 18px;}

/* ── PARTNERSHIPS ──────────────────────────────────────────────────── */
.partnerships-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--max);margin:0 auto;}
.partnership-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:32px 28px;transition:all var(--t-md);}
.partnership-card:hover{background:rgba(255,255,255,.08);border-color:var(--gold);transform:translateY(-3px);}
.partnership-card__icon{font-size:32px;margin-bottom:18px;}
.partnership-card__title{font-size:18px;font-weight:800;color:var(--white);margin-bottom:10px;}
.partnership-card__desc{font-size:13.5px;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:20px;}
.partnership-card__list{display:flex;flex-direction:column;gap:7px;margin-bottom:24px;}
.partnership-card__list li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.7);}
.partnership-card__list li::before{content:'→';color:var(--gold);flex-shrink:0;font-weight:700;}

/* ── TEACHER CTA ───────────────────────────────────────────────────── */
.teacher-cta{background:var(--green-50);border:1.5px solid var(--green-100);border-radius:var(--r-xl);padding:56px 48px;max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;}
.teacher-cta__badge{display:inline-flex;align-items:center;gap:8px;background:var(--green-100);color:var(--green-700);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:50px;margin-bottom:14px;}
.teacher-cta__title{font-family:'Playfair Display',serif;font-size:clamp(22px,2.5vw,30px);font-weight:700;color:var(--text);line-height:1.3;margin-bottom:12px;}
.teacher-cta__desc{font-size:14px;color:var(--text-muted);line-height:1.7;max-width:480px;}
.teacher-cta__actions{display:flex;flex-direction:column;gap:12px;align-items:flex-start;flex-shrink:0;}
.teacher-cta__perk{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-md);font-weight:500;}
.teacher-cta__perk::before{content:'✓';color:var(--green-600);font-weight:800;font-size:12px;}

/* ── PORTAL ACCESS ─────────────────────────────────────────────────── */
.portal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--max);margin:0 auto;}
.portal-card{background:var(--green-800);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:28px;display:flex;flex-direction:column;gap:16px;transition:all var(--t-md);}
.portal-card:hover{border-color:var(--gold);box-shadow:0 8px 32px rgba(0,0,0,.2);}
.portal-card__icon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.portal-card__icon--blue{background:rgba(96,165,250,.15);}
.portal-card__icon--gold{background:rgba(201,162,39,.15);}
.portal-card__icon--green{background:rgba(96,165,250,.15);}
.portal-card__title{font-size:17px;font-weight:800;color:var(--white);}
.portal-card__desc{font-size:13px;color:rgba(255,255,255,.6);line-height:1.65;flex:1;}
.portal-card__link{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:700;color:var(--gold);transition:gap var(--t);}
.portal-card:hover .portal-card__link{gap:12px;}
.portal-card__status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#60a5fa;}
.portal-card__status::before{content:'';width:6px;height:6px;border-radius:50%;background:#60a5fa;display:block;}

/* ── STATS STRIP ───────────────────────────────────────────────────── */
.stats-strip{background:var(--gold);padding:48px var(--px);}
.stats-strip__inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-around;flex-wrap:wrap;gap:32px;}
.stat{text-align:center;}
.stat__number{font-family:'Playfair Display',serif;font-size:clamp(32px,4vw,48px);font-weight:700;color:var(--green-900);line-height:1;}
.stat__label{font-size:13px;font-weight:600;color:var(--green-800);margin-top:6px;opacity:.8;}

/* ── FOOTER ────────────────────────────────────────────────────────── */
.footer{background:var(--green-950);padding:64px var(--px) 32px;}
.footer__top{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07);}
.footer__brand img{height:44px;width:auto;margin-bottom:16px;}
.footer__brand p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.75;max-width:280px;margin-bottom:20px;}
.footer__social{display:flex;gap:10px;}
.footer__social a{width:36px;height:36px;border-radius:var(--r);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:all var(--t);font-size:13px;font-weight:700;}
.footer__social a:hover{background:var(--gold);color:var(--green-900);border-color:var(--gold);}
.footer__col h4{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.footer__col ul{display:flex;flex-direction:column;gap:10px;}
.footer__col ul li a{font-size:13px;color:rgba(255,255,255,.5);transition:color var(--t);}
.footer__col ul li a:hover{color:var(--white);}
.footer__bottom{max-width:var(--max);margin:0 auto;padding-top:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.footer__copy{font-size:12px;color:rgba(255,255,255,.3);}
.footer__copy a{color:rgba(255,255,255,.45);}
.footer__copy a:hover{color:var(--gold);}
.footer__links{display:flex;gap:20px;}
.footer__links a{font-size:12px;color:rgba(255,255,255,.35);transition:color var(--t);}
.footer__links a:hover{color:var(--gold);}

/* ── MODAL + FORM ──────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity var(--t-md);}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--white);border-radius:var(--r-xl);padding:40px;max-width:520px;width:100%;box-shadow:0 24px 80px rgba(0,0,0,.25);transform:translateY(20px);transition:transform var(--t-md);max-height:90vh;overflow-y:auto;position:relative;}
.modal-overlay.open .modal{transform:translateY(0);}
.modal__title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:var(--text);margin-bottom:6px;}
.modal__subtitle{font-size:14px;color:var(--text-muted);margin-bottom:24px;}
.modal__close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#f3f4f6;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-muted);transition:background var(--t);}
.modal__close:hover{background:#e5e7eb;}
.form-group{margin-bottom:18px;}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;}
.form-input{width:100%;border:1.5px solid #e5e7eb;border-radius:var(--r);padding:11px 14px;font-size:14px;font-family:'Inter',sans-serif;color:var(--text);background:var(--white);transition:border-color var(--t);outline:none;}
.form-input:focus{border-color:var(--green-600);}
.form-submit{width:100%;background:var(--green-600);color:var(--white);border:none;border-radius:var(--r-md);padding:14px;font-size:15px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;transition:all var(--t);margin-top:8px;}
.form-submit:hover{background:var(--green-500);}
.modal-class-info{background:var(--green-50);border:1px solid var(--green-100);border-radius:var(--r-md);padding:16px;margin-bottom:24px;}
.modal-class-info__name{font-weight:700;color:var(--text);margin-bottom:4px;}
.modal-class-info__detail{font-size:13px;color:var(--text-muted);}

/* ── CHAT WIDGET ───────────────────────────────────────────────────── */
.chat-widget{position:fixed;bottom:28px;right:28px;z-index:999;}
.chat-toggle{width:58px;height:58px;border-radius:50%;background:var(--green-600);color:white;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 6px 24px rgba(41,82,163,0.4);transition:all .3s;position:relative;}
.chat-toggle:hover{transform:scale(1.08);}
.chat-toggle .chat-dot{position:absolute;top:4px;right:4px;width:12px;height:12px;border-radius:50%;background:var(--gold);border:2px solid white;}
.chat-window{position:absolute;bottom:72px;right:0;width:340px;background:white;border-radius:18px;box-shadow:0 20px 60px rgba(15,30,60,0.2);overflow:hidden;display:none;flex-direction:column;max-height:480px;}
.chat-window.open{display:flex;}
.chat-header{background:var(--green-800);color:white;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;}
.chat-header-info{display:flex;align-items:center;gap:12px;}
.chat-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:18px;}
.chat-header-text h4{font-size:14px;font-weight:600;}
.chat-header-text p{font-size:11px;opacity:.75;}
.chat-close{background:none;border:none;color:white;font-size:18px;cursor:pointer;opacity:.75;}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;}
.chat-msg{max-width:80%;}
.chat-msg.bot{align-self:flex-start;}
.chat-msg.user{align-self:flex-end;}
.chat-bubble{padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.5;}
.chat-msg.bot .chat-bubble{background:var(--cream);color:var(--text);border-bottom-left-radius:4px;}
.chat-msg.user .chat-bubble{background:var(--green-600);color:white;border-bottom-right-radius:4px;}
.chat-quick-btns{display:flex;flex-wrap:wrap;gap:6px;padding:0 16px 12px;}
.chat-quick-btn{background:var(--green-50);color:var(--green-600);border:none;padding:6px 12px;border-radius:50px;font-size:12px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s;}
.chat-quick-btn:hover{background:var(--green-600);color:white;}
.chat-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--cream-dark);}
.chat-input{flex:1;border:1.5px solid var(--cream-dark);border-radius:8px;padding:9px 12px;font-family:'Inter',sans-serif;font-size:13px;outline:none;transition:border-color .2s;}
.chat-input:focus{border-color:var(--green-600);}
.chat-send{background:var(--green-600);color:white;border:none;width:36px;height:36px;border-radius:8px;cursor:pointer;font-size:16px;transition:all .2s;}
.chat-send:hover{background:var(--green-500);}

/* ── RESPONSIVE ────────────────────────────────────────────────────── */
@media(max-width:1024px) {
  .partnerships-grid{grid-template-columns:1fr 1fr;}
  .portal-grid{grid-template-columns:1fr 1fr;}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px;}
  .features-grid{grid-template-columns:1fr 1fr;}
  .competition-cards{grid-template-columns:1fr;}
  .news-grid{grid-template-columns:1fr 1fr;}
  .blog-grid{grid-template-columns:1fr 1fr;}
  .programs-hub{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px) {
  .hero__inner{grid-template-columns:1fr;gap:40px;}
  .hero__paths{display:none;}
  .models-grid{grid-template-columns:1fr;}
  .partnerships-grid{grid-template-columns:1fr;}
  .portal-grid{grid-template-columns:1fr;}
  .summer-banner__inner{grid-template-columns:1fr;}
  .teacher-cta{grid-template-columns:1fr;}
  .footer__top{grid-template-columns:1fr 1fr;}
  .topbar__nav{display:none;}
  .topbar__toggle{display:flex;}
  .features-grid{grid-template-columns:1fr;}
  .schools-grid-2col{grid-template-columns:1fr;}
  .tj-grid{grid-template-columns:1fr;}
  .faq-grid{grid-template-columns:1fr;}
  .news-grid{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .programs-hub{grid-template-columns:1fr;}
  .chat-window{width:300px;}
}
@media(max-width:480px) {
  .footer__top{grid-template-columns:1fr;}
  .classes-grid{grid-template-columns:1fr;}
  .competition-cards{grid-template-columns:1fr;}
}
@media print {
  .topbar,.announce-bar,.modal-overlay,.footer,.chat-widget{display:none!important;}
  body{background:white;color:black;}
  .hero{background:white!important;}
  .hero__title,.hero__subtitle{color:black!important;}
}
 