﻿/* ============================================================
   CSS VARIABLES & RESET
============================================================ */
:root {
  --blue-900: #0f2861;
  --blue-800: #1a3a7a;
  --blue-700: #1e4ea0;
  --blue-600: #2563eb;
  --blue-400: #60a5fa;
  --blue-300: #93c5fd;
  --blue-100: #dbeafe;
  --blue-50:  #eff6ff;
  --yellow-500: #f59e0b;
  --yellow-400: #fbbf24;
  --yellow-300: #fcd34d;
  --yellow-100: #fef9c3;
  --green-500: #10b981;
  --green-300: #6ee7b7;
  --purple-500: #8b5cf6;
  --purple-300: #c4b5fd;
  --orange-500: #f97316;
  --red-500: #ef4444;
  --red-300: #fca5a5;
  --gray-900: #111827;
  --gray-700: #374151;
  --gray-500: #6b7280;
  --gray-300: #d1d5db;
  --gray-100: #f3f4f6;
  --white: #ffffff;
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
  --shadow-md: 0 6px 24px rgba(0,0,0,.10);
  --shadow-lg: 0 16px 48px rgba(0,0,0,.14);
  --shadow-blue: 0 8px 32px rgba(37,99,235,.25);
  --dark-text-strong: rgba(255,255,255,.90);
  --dark-text: rgba(255,255,255,.80);
  --dark-text-soft: rgba(255,255,255,.65);
  --dark-text-muted: rgba(255,255,255,.50);
  --dark-text-faint: rgba(255,255,255,.45);
  --glass-blue: rgba(37,99,235,.20);
  --glass-blue-border: rgba(37,99,235,.30);
  --glass-green: rgba(16,185,129,.20);
  --glass-green-border: rgba(16,185,129,.30);
  --glass-gold: rgba(251,191,36,.20);
  --glass-gold-border: rgba(251,191,36,.30);
  --glass-purple: rgba(124,58,237,.20);
  --glass-purple-border: rgba(124,58,237,.30);
  --glass-cyan: rgba(6,182,212,.20);
  --glass-cyan-border: rgba(6,182,212,.30);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Nunito',sans-serif;color:var(--gray-900);background:var(--white);overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:'Sora',sans-serif;line-height:1.2}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;font-family:inherit}

/* ============================================================
   UTILITY CLASSES
============================================================ */
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.section-tag{display:inline-flex;align-items:center;gap:6px;background:var(--yellow-100);color:var(--yellow-500);font-weight:800;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:14px}
.section-tag .dot{width:8px;height:8px;background:var(--yellow-400);border-radius:50%;display:inline-block}
.section-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;color:var(--blue-900);margin-bottom:12px}
.section-title span{color:var(--blue-600)}
.section-sub{font-size:1rem;color:var(--gray-500);max-width:600px;line-height:1.7}
.text-center{text-align:center}
.text-center .section-sub{margin:0 auto}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--blue-600);color:var(--white);font-weight:800;font-size:1rem;padding:14px 28px;border-radius:100px;box-shadow:var(--shadow-blue);transition:all .22s ease;white-space:nowrap}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-2px);box-shadow:0 12px 36px rgba(37,99,235,.38)}
.btn-yellow{display:inline-flex;align-items:center;gap:8px;background:var(--yellow-400);color:var(--blue-900);font-weight:800;font-size:1rem;padding:14px 28px;border-radius:100px;transition:all .22s ease;white-space:nowrap}
.btn-yellow:hover{background:var(--yellow-300);transform:translateY(-2px);box-shadow:0 12px 36px rgba(251,191,36,.4)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--blue-600);font-weight:800;font-size:1rem;padding:13px 27px;border-radius:100px;border:2px solid var(--blue-600);transition:all .22s ease}
.btn-outline:hover{background:var(--blue-50)}
/* Ghost button â€” semi-transparent, for use on coloured backgrounds */
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);color:var(--white);font-weight:800;font-size:1rem;padding:14px 28px;border-radius:100px;border:2px solid rgba(255,255,255,.35);transition:all .22s ease;white-space:nowrap;backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.6);transform:translateY(-2px)}
/* Hero variant â€” matches hero sizing */
.btn-ghost-hero{font-size:1.05rem;padding:15px 32px}

/* ============================================================
   ANNOUNCEMENT BAR
============================================================ */
.announcement-bar{background:linear-gradient(90deg,var(--blue-900),var(--blue-700));color:var(--white);text-align:center;padding:10px 20px;font-size:.85rem;font-weight:700;letter-spacing:.02em}
.announcement-bar span{color:var(--yellow-300);margin:0 8px}

/* ============================================================
   STICKY HEADER
============================================================ */
.header{position:sticky;top:0;z-index:999;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-100);padding:12px 0;transition:box-shadow .3s}
.header.scrolled{box-shadow:var(--shadow-md)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--blue-600),var(--blue-800));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.logo-text{font-family:'Sora',sans-serif;font-weight:800;font-size:.95rem;color:var(--blue-900);line-height:1.2}
.logo-text small{display:block;font-family:'Nunito',sans-serif;font-weight:600;font-size:.72rem;color:var(--gray-500)}
/* Logo home link hover */
.logo a{text-decoration:none;display:flex;align-items:center;gap:10px;border-radius:12px;padding:4px 8px 4px 4px;margin:-4px -8px -4px -4px;transition:background .2s ease}
.logo a:hover{background:rgba(37,99,235,.07)}
.logo a .logo-icon{transition:transform .22s cubic-bezier(.34,1.56,.64,1)}
.logo a:hover .logo-icon{transform:scale(1.1) rotate(-3deg)}
.nav-cta{display:flex;align-items:center;gap:10px}
.seats-badge{background:var(--red-500);color:var(--white);font-size:.72rem;font-weight:800;padding:4px 10px;border-radius:100px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}

/* ============================================================
   HERO SECTION
============================================================ */
.hero{position:relative;background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue-700) 60%,var(--blue-600) 100%);overflow:hidden;padding:80px 0 60px}
.hero::before{content:'';position:absolute;inset:0}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;position:relative;z-index:1}
.hero-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;font-size:.78rem;font-weight:800;letter-spacing:.05em}
.badge-open{background:rgba(16,185,129,.2);color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}
.badge-limited{background:rgba(239,68,68,.2);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.badge-class{background:rgba(251,191,36,.15);color:var(--yellow-300);border:1px solid rgba(251,191,36,.3)}
.hero h1{font-size:clamp(1.8rem,4vw,3rem);color:var(--white);font-weight:800;line-height:1.15;margin-bottom:16px}
.hero h1 .highlight{color:var(--yellow-400)}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.82);line-height:1.75;margin-bottom:28px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}
.hero-stats{display:flex;flex-wrap:wrap;gap:20px}
.hero-stat{display:flex;align-items:center;gap:10px}
.hero-stat-icon{width:38px;height:38px;background:rgba(255,255,255,.12);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.hero-stat-text strong{display:block;color:var(--white);font-size:.95rem;font-weight:700}
.hero-stat-text span{color:rgba(255,255,255,.6);font-size:.78rem}
.hero-visual{position:relative;display:flex;justify-content:center}
.hero-card-stack{position:relative;width:360px;max-width:100%}
.hero-main-card{background:rgba(255,255,255,.1);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-xl);padding:30px;color:var(--white)}
.hero-main-card .card-title{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.course-list{display:flex;flex-direction:column;gap:10px}
.course-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:rgba(255,255,255,.08);border-radius:var(--radius-sm);font-size:.88rem;font-weight:600}
.course-item .ci-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.float-card{position:absolute;background:var(--white);border-radius:var(--radius-md);padding:12px 16px;box-shadow:var(--shadow-lg);font-size:.82rem;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--gray-700)}
.float-card-1{top:-20px;right:-20px;animation:float1 3s ease-in-out infinite}
.float-card-2{bottom:-14px;left:-16px;animation:float2 3.5s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ============================================================
   HERO PRICING TEASER
============================================================ */
.hero-pricing{display:flex;flex-direction:column;gap:8px;margin:20px 0 28px;padding:14px 18px;background:rgba(255,255,255,.08);border:1px solid rgba(251,191,36,.25);border-radius:var(--radius-md);backdrop-filter:blur(8px)}
.hp-price-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px}
.hp-original{font-family:'Sora',sans-serif;font-size:.95rem;color:rgba(255,255,255,.38);text-decoration:line-through;font-weight:700}
.hp-arrow{color:rgba(255,255,255,.35);font-size:.9rem}
.hp-offer{font-family:'Sora',sans-serif;font-size:1.15rem;font-weight:800;color:var(--yellow-400)}
.hp-fire{font-size:.82rem;font-weight:800;color:#fca5a5;background:rgba(239,68,68,.18);border:1px solid rgba(239,68,68,.28);padding:3px 10px;border-radius:100px;white-space:nowrap}
.hp-perks{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px}
.hp-perk{font-size:.8rem;font-weight:700;color:rgba(255,255,255,.72)}
.hp-sep{color:rgba(255,255,255,.25);font-size:.8rem}
@media(max-width:480px){
  .hp-price-row{gap:6px 8px}
  .hp-offer{font-size:1.05rem}
  .hero-pricing{padding:12px 14px;gap:7px}
}

/* ============================================================
   COUNTDOWN / URGENCY BAR
============================================================ */
.urgency-bar{background:var(--yellow-400);padding:14px 0}
.urgency-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:16px}
.urgency-text{font-weight:800;font-size:.95rem;color:var(--blue-900)}
.countdown-wrap{display:flex;gap:8px;align-items:center}
.countdown-unit{background:var(--blue-900);color:var(--white);border-radius:8px;padding:6px 12px;text-align:center;min-width:52px}
.countdown-unit .num{display:block;font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:800;line-height:1}
.countdown-unit .lbl{display:block;font-size:.62rem;color:rgba(255,255,255,.7);letter-spacing:.06em;text-transform:uppercase}
.countdown-sep{font-size:1.2rem;font-weight:900;color:var(--blue-900);line-height:1}

/* ============================================================
   WHY PARENTS CHOOSE
============================================================ */
.why-section{padding:80px 0;background:var(--white)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.why-card{background:var(--blue-50);border-radius:var(--radius-lg);padding:28px 24px;transition:all .25s ease;border:1px solid transparent}
.why-card:hover{background:var(--white);border-color:var(--blue-100);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.why-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px}
.why-card h4{font-size:1rem;font-weight:800;color:var(--blue-900);margin-bottom:8px}
.why-card p{font-size:.88rem;color:var(--gray-500);line-height:1.65}

/* ============================================================
   PROGRAM HIGHLIGHTS
============================================================ */
.highlights-section{padding:80px 0;background:var(--blue-900)}
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.hl-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:28px 24px;text-align:center;transition:all .25s ease}
.hl-card:hover{background:rgba(255,255,255,.12);transform:translateY(-4px)}
.hl-icon{font-size:2.2rem;margin-bottom:12px}
.hl-value{font-family:'Sora',sans-serif;font-size:1.6rem;font-weight:800;color:var(--yellow-400);margin-bottom:4px}
.hl-label{font-size:.88rem;color:rgba(255,255,255,.7);font-weight:600}

/* ============================================================
   CURRICULUM SECTION
============================================================ */
.curriculum-section{padding:80px 0;background:var(--gray-100)}
.levels-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px}
.level-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100)}
.level-header{padding:20px 24px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:background .2s}
.level-header:hover{background:var(--blue-50)}
.level-num{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-size:1rem;font-weight:800;color:var(--white);flex-shrink:0}
.level-info h4{font-size:1rem;font-weight:800;color:var(--blue-900)}
.level-info span{font-size:.8rem;color:var(--gray-500)}
.level-arrow{margin-left:auto;font-size:1.1rem;transition:transform .3s;color:var(--gray-500)}
.level-body{display:none;padding:0 24px 20px}
.level-body.open{display:block}
.level-topics{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.topic-chip{background:var(--blue-50);color:var(--blue-700);font-size:.78rem;font-weight:700;padding:5px 12px;border-radius:100px;border:1px solid var(--blue-100)}

/* ============================================================
   PROJECTS SHOWCASE
============================================================ */
.projects-section{padding:80px 0;background:var(--white)}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.project-card{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all .25s ease}
.project-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.project-top{height:130px;display:flex;align-items:center;justify-content:center;font-size:3.5rem}
.project-bottom{padding:18px 20px;background:var(--white)}
.project-bottom h4{font-size:.95rem;font-weight:800;color:var(--blue-900);margin-bottom:4px}
.project-bottom p{font-size:.8rem;color:var(--gray-500)}

/* ============================================================
   TEACHING METHODOLOGY
============================================================ */
.method-section{padding:80px 0;background:linear-gradient(135deg,var(--blue-900),var(--blue-700))}
.method-ratio{display:flex;border-radius:var(--radius-lg);overflow:hidden;margin-top:48px;box-shadow:var(--shadow-lg)}
.ratio-block{padding:36px 28px;text-align:center;flex:1}
.ratio-block h3{font-family:'Sora',sans-serif;font-size:1.8rem;font-weight:800;color:var(--white);margin-bottom:6px}
.ratio-block p{font-size:.88rem;color:rgba(255,255,255,.75)}
.rb-explain{background:rgba(255,255,255,.1)}
.rb-do{background:rgba(37,99,235,.4)}
.rb-practice{background:rgba(251,191,36,.2)}
.method-features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.mf-item{display:flex;align-items:center;gap:12px;padding:14px 18px;background:rgba(255,255,255,.08);border-radius:var(--radius-md)}
.mf-icon{font-size:1.4rem;flex-shrink:0}
.mf-text{font-size:.88rem;font-weight:700;color:rgba(255,255,255,.9)}

/* ============================================================
   DAILY EXPERIENCE
============================================================ */
.daily-section{padding:80px 0;background:var(--blue-50)}
.daily-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.daily-card{background:var(--white);border-radius:var(--radius-md);padding:24px 20px;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--blue-100)}
.daily-icon{font-size:2.2rem;margin-bottom:12px}
.daily-card h4{font-size:.92rem;font-weight:800;color:var(--blue-900);margin-bottom:6px}
.daily-card p{font-size:.8rem;color:var(--gray-500)}

/* ============================================================
   PARENT TRUST
============================================================ */
.trust-section{padding:80px 0;background:var(--white)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px}
.trust-card{background:var(--blue-50);border-radius:var(--radius-lg);padding:28px 22px;border-left:4px solid var(--blue-600)}
.trust-icon{font-size:1.8rem;margin-bottom:12px}
.trust-card h4{font-size:.92rem;font-weight:800;color:var(--blue-900);margin-bottom:6px}
.trust-card p{font-size:.8rem;color:var(--gray-500);line-height:1.6}

/* ============================================================
   TESTIMONIALS
============================================================ */
.testimonials-section{padding:80px 0;background:var(--gray-100)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.testi-card{background:var(--white);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:all .25s}
.testi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.testi-stars{color:var(--yellow-400);font-size:1rem;margin-bottom:12px}
.testi-text{font-size:.9rem;color:var(--gray-700);line-height:1.7;font-style:italic;margin-bottom:18px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue-400),var(--blue-600));display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--white);font-weight:800;flex-shrink:0}
.testi-name{font-weight:800;font-size:.9rem;color:var(--blue-900)}
.testi-role{font-size:.78rem;color:var(--gray-500)}

/* ============================================================
   FAQ
============================================================ */
.faq-section{padding:80px 0;background:var(--white)}
.faq-list{max-width:760px;margin:48px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--blue-50);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--blue-100)}
.faq-q{padding:18px 22px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:12px;transition:background .2s}
.faq-q:hover{background:var(--blue-100)}
.faq-q span{font-weight:700;font-size:.95rem;color:var(--blue-900)}
.faq-arrow{font-size:1.2rem;transition:transform .3s;color:var(--blue-600);flex-shrink:0}
.faq-a{display:none;padding:0 22px 18px;font-size:.9rem;color:var(--gray-700);line-height:1.7}
.faq-a.open{display:block}

/* ============================================================
   ADMISSION FORM
============================================================ */
.form-section{padding:80px 0;background:linear-gradient(135deg,var(--blue-900),var(--blue-700))}
.form-wrapper{
  max-width:820px;margin:48px auto 0;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-xl);
  padding:48px 44px;
}

/* 2-column responsive grid */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px 24px}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-group.full{grid-column:1/-1}

/* Section divider labels */
.form-section-label{
  grid-column:1/-1;
  font-family:'Sora',sans-serif;
  font-size:.7rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--yellow-300);
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.1);
  margin-top:10px;
}
.form-section-label:first-child{margin-top:0}

/* Labels */
.form-group label{
  font-size:.84rem;
  font-weight:700;
  color:rgba(255,255,255,.88);
  letter-spacing:.01em;
  display:flex;
  align-items:center;
  gap:5px;
}
.form-group label .req{color:var(--yellow-300);font-size:.9em;line-height:1}
.form-optional{font-size:.75rem;font-weight:600;color:rgba(255,255,255,.4);margin-left:2px}

/* Inputs & selects */
.form-group input,
.form-group select,
.form-group textarea{
  background:rgba(255,255,255,.09);
  border:1.5px solid rgba(255,255,255,.18);
  border-radius:10px;
  padding:13px 16px;
  font-family:'Nunito',sans-serif;
  font-size:.93rem;
  color:var(--white);
  transition:border .2s,background .2s,box-shadow .2s;
  outline:none;
  width:100%;
  appearance:none;
  -webkit-appearance:none;
}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,0.5)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
}
.form-group input::placeholder{color:rgba(255,255,255,.35)}
.form-group select option{background:var(--blue-900);color:var(--white)}
.form-group input:focus,
.form-group select:focus{
  border-color:var(--yellow-400);
  background:rgba(255,255,255,.14);
  box-shadow:0 0 0 3px rgba(251,191,36,.18);
}

/* Submit button wrapper */
.form-submit-wrap{margin-top:6px}
.form-submit{
  width:100%;
  padding:17px 24px;
  font-family:'Sora',sans-serif;
  font-size:1.05rem;
  font-weight:800;
  background:var(--yellow-400);
  color:var(--blue-900);
  border-radius:100px;
  border:none;
  cursor:pointer;
  transition:all .25s;
  box-shadow:0 8px 28px rgba(251,191,36,.38);
  letter-spacing:.01em;
}
.form-submit:hover{
  background:var(--yellow-300);
  transform:translateY(-2px);
  box-shadow:0 14px 36px rgba(251,191,36,.52);
}
.form-submit:active{transform:translateY(0);box-shadow:0 6px 18px rgba(251,191,36,.3)}
.form-submit:disabled{opacity:.55;transform:none;cursor:not-allowed}

.form-note{
  text-align:center;
  margin-top:16px;
  font-size:.8rem;
  color:rgba(255,255,255,.45);
  line-height:1.6;
}

/* Mobile */
@media(max-width:640px){
  .form-wrapper{padding:28px 20px}
  .form-grid{grid-template-columns:1fr;gap:16px}
  .form-group.full{grid-column:1}
  .form-section-label{font-size:.65rem}
  .form-submit{font-size:.97rem;padding:16px}
}

/* ============================================================
   FOOTER
============================================================ */
.footer{background:var(--gray-900);padding:56px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.footer-brand h3{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;color:var(--white);margin-bottom:8px}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:20px}
.social-links{display:flex;gap:10px}
.social-link{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .2s;color:rgba(255,255,255,.7)}
.social-link:hover{background:var(--blue-600);color:var(--white)}
.footer-col h4{font-size:.88rem;font-weight:800;color:var(--white);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a,.footer-contact-item{font-size:.85rem;color:rgba(255,255,255,.5);transition:color .2s;display:flex;align-items:center;gap:8px}
.footer-col ul li a:hover{color:var(--white)}
.footer-contact-item{margin-bottom:10px}
.footer-divider{border-color:rgba(255,255,255,.08);margin:0 0 22px}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.35)}

/* ============================================================
   FLOATING WHATSAPP
============================================================ */
.whatsapp-float{position:fixed;bottom:28px;right:24px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.whatsapp-btn{display:flex;align-items:center;gap:10px;background:#25d366;color:var(--white);font-weight:800;font-size:.88rem;padding:12px 18px;border-radius:100px;box-shadow:0 8px 28px rgba(37,211,102,.45);transition:all .25s;animation:waFloat 2.5s ease-in-out infinite}
.whatsapp-btn:hover{background:#1ebe5c;transform:scale(1.05)}
@keyframes waFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.whatsapp-icon{width:26px;height:26px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem}

/* ============================================================
   SUCCESS / ERROR STATES
============================================================ */
.form-success{text-align:center;padding:40px 20px}
.form-success h3{font-family:'Sora',sans-serif;color:var(--white);font-size:1.5rem;font-weight:800;margin-bottom:10px}
.form-success p{color:rgba(255,255,255,.7);font-size:.95rem}
.success-icon{font-size:3.5rem;margin-bottom:16px}

/* ============================================================
   SECTION DIVIDER WAVE
============================================================ */
.wave{display:block;width:100%;overflow:hidden;line-height:0}
.wave svg{display:block}

/* ============================================================
   PRICING SECTION
============================================================ */
.pricing-section{padding:80px 0;background:linear-gradient(150deg,var(--blue-900) 0%,#112270 50%,var(--blue-800) 100%);position:relative;overflow:hidden}
.pricing-section::after{content:'';position:absolute;top:-120px;right:-120px;width:420px;height:420px;background:radial-gradient(circle,rgba(251,191,36,.07) 0%,transparent 70%);pointer-events:none}
.pricing-wrap{max-width:640px;margin:48px auto 0}
.pricing-card{background:rgba(255,255,255,.07);backdrop-filter:blur(24px);border:1px solid rgba(251,191,36,.22);border-radius:var(--radius-xl);padding:44px 40px;position:relative;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.35)}
.pricing-top-bar{position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--yellow-500),var(--yellow-300),var(--yellow-500));border-radius:4px 4px 0 0}
.pricing-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(251,191,36,.15);color:var(--yellow-300);font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:7px 16px;border-radius:100px;border:1px solid rgba(251,191,36,.28);margin-bottom:18px}
.pricing-original{font-size:.9rem;color:rgba(255,255,255,.5);font-weight:600;margin-bottom:6px}
.pricing-original span{text-decoration:line-through;color:rgba(255,255,255,.38)}
.pricing-main{margin-bottom:26px;padding-bottom:22px;border-bottom:1px solid rgba(255,255,255,.08)}
.pricing-amount{font-family:'Sora',sans-serif;font-size:clamp(3rem,7vw,4rem);font-weight:800;color:var(--yellow-400);line-height:1}
.pricing-label{font-size:.85rem;color:rgba(255,255,255,.55);margin-top:6px;font-weight:600}
.pricing-urgency{display:flex;align-items:flex-start;gap:14px;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.28);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:14px}
.pu-icon{font-size:1.5rem;flex-shrink:0;line-height:1.1;margin-top:1px}
.pu-text{display:flex;flex-direction:column;gap:4px}
.pu-text strong{font-size:.95rem;color:#fca5a5;font-weight:800;line-height:1.3}
.pu-text span{font-size:.8rem;color:rgba(255,255,255,.55);line-height:1.4}
.pricing-reserve{background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:26px;text-align:center}
.pr-amount{font-size:1rem;font-weight:800;color:var(--yellow-300);margin-bottom:5px}
.pr-amount span{font-family:'Sora',sans-serif;font-size:1.2rem;color:var(--yellow-400)}
.pr-note{font-size:.78rem;color:rgba(255,255,255,.5)}
.pricing-features{display:flex;flex-direction:column;gap:13px;margin-bottom:28px;padding:0}
.pricing-features li{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:rgba(255,255,255,.8);line-height:1.55}
.pf-icon{flex-shrink:0;font-size:1rem;line-height:1.4}
.pricing-cta{display:flex;width:100%;justify-content:center;font-size:1.05rem;padding:16px 28px;font-family:'Sora',sans-serif}
.pricing-footer-note{text-align:center;font-size:.78rem;color:rgba(255,255,255,.38);margin-top:12px}
@media(max-width:600px){.pricing-card{padding:30px 22px}}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1024px){
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .highlights-grid{grid-template-columns:repeat(2,1fr)}
  .projects-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .method-features{grid-template-columns:repeat(2,1fr)}
  .daily-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-badge-row{justify-content:center}
  .hero-ctas{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-visual{display:none}
  .levels-grid{grid-template-columns:1fr}
  .method-ratio{flex-direction:column}
  .form-grid{grid-template-columns:1fr}
  .form-group.full{grid-column:1}
  .form-wrapper{padding:28px 20px}
  .nav-cta .btn-outline{display:none}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .highlights-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr}
  /* mission-grid stack */
  .mission-grid{grid-template-columns:1fr!important}
  /* weekend grid compact */
  .weekend-grid{grid-template-columns:1fr}
  /* blog grid compact */
  .blog-grid{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:480px){
  .highlights-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .daily-grid{grid-template-columns:repeat(2,1fr)}
  .method-features{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;align-items:center}
  .ratio-block h3{font-size:1.4rem}
  .blog-grid{grid-template-columns:1fr!important}
}

/* ============================================================
   ENTRANCE ANIMATIONS â€” initial state only
   Transitions defined in enhancements.css to avoid duplication.
============================================================ */
.fade-up{opacity:0;transform:translateY(28px)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up-delay-1{transition-delay:.1s}
.fade-up-delay-2{transition-delay:.2s}
.fade-up-delay-3{transition-delay:.3s}

/* ============================================================
   PERFORMANCE: content-visibility for below-fold sections
   Browser skips painting/rendering until section is near viewport.
============================================================ */
.why-section,.curriculum-section,.outcomes-section,
.projects-section,.method-section,.daily-section,
.trust-section,.testimonials-section,.faq-section,
.blog-section,.certificate-section,
.weekend-section,.scholar-section,.before-after-section{
  content-visibility:auto;
  contain-intrinsic-size:0 400px;
}

/* ============================================================
   STICKY MOBILE CTA
============================================================ */
.sticky-mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9998;background:linear-gradient(90deg,var(--blue-900),var(--blue-800));border-top:2px solid var(--yellow-400);padding:12px 16px;align-items:center;justify-content:space-between;gap:10px}
.smc-text{color:rgba(255,255,255,.8);font-size:.78rem;font-weight:700;line-height:1.3}
.smc-text strong{color:var(--yellow-400);display:block;font-size:.9rem}
.smc-btns{display:flex;gap:8px;flex-shrink:0}
.smc-btns a{display:inline-flex;align-items:center;gap:5px;padding:9px 14px;border-radius:100px;font-size:.8rem;font-weight:800;white-space:nowrap}
.smc-demo{background:rgba(255,255,255,.12);color:var(--white);border:1px solid rgba(255,255,255,.25)}
.smc-enroll{background:var(--yellow-400);color:var(--blue-900)}
@media(max-width:768px){.sticky-mobile-cta{display:flex}.whatsapp-float{bottom:80px}}

/* ============================================================
   GAMING VS SKILLS â€” emotional parent section
============================================================ */
.gaming-section {
  padding: 80px 0;
  background: var(--blue-900);
}

.gaming-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-top: 40px;
  align-items: stretch;
}

.gaming-col {
  border-radius: 16px;
  padding: 30px;
}

.gaming-col-bad{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25)}

.gaming-col-good{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25)}
.gaming-col-head{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08)}
.gaming-col-head .gch-icon{font-size:2.2rem}
.gaming-col-head h3{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;color:var(--white)}
.gaming-col-head span{font-size:.78rem;color:rgba(255,255,255,.55);display:block;margin-top:2px}
.gaming-items{display:flex;flex-direction:column;gap:12px}
.gi-item{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;font-weight:600;line-height:1.55}
.gi-bad{color:rgba(255,255,255,.75)}
.gi-bad .gi-dot{color:#f87171;flex-shrink:0;font-size:1.1rem;margin-top:1px}
.gi-good{color:rgba(255,255,255,.85)}
.gi-good .gi-dot{color:#34d399;flex-shrink:0;font-size:1.1rem;margin-top:1px}
.gaming-cta-row{margin-top:44px;text-align:center}
.gaming-cta-row p{color:rgba(255,255,255,.65);font-size:.95rem;margin-bottom:18px;line-height:1.7}
@media(max-width:640px){.gaming-grid{grid-template-columns:1fr}}

/* ============================================================
   WEEKEND BATCH SECTION
============================================================ */
.weekend-section{padding:80px 0;background:var(--blue-50)}
.weekend-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;margin-top:48px}
.weekend-grid > *{min-width:0}
.weekend-info{display:flex;flex-direction:column;gap:18px;min-width:0}
.wi-card{background:var(--white);border-radius:var(--radius-md);padding:20px 22px;box-shadow:var(--shadow-sm);border-left:4px solid var(--blue-600);display:flex;align-items:flex-start;gap:14px;max-width:100%;width:100%}
.wi-icon{font-size:1.8rem;flex-shrink:0}
.wi-card > div:last-child{min-width:0}
.wi-card-success{border-left-color:var(--green-500)}
.wi-card h4{font-size:.95rem;font-weight:800;color:var(--blue-900);margin-bottom:4px}
.wi-card p{font-size:.85rem;color:var(--gray-500);line-height:1.6}
.weekend-batches{display:flex;flex-direction:column;gap:14px}
.wb-badge{background:var(--white);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow-md);border:1px solid var(--blue-100);display:flex;align-items:center;gap:16px}
.wb-badge.wb-popular{border-color:var(--yellow-400);background:linear-gradient(135deg,#fffbeb,#fef9c3)}
.wb-time{font-family:'Sora',sans-serif;font-size:1.5rem;font-weight:800;color:var(--blue-900);min-width:90px}
.wb-details h4{font-size:.92rem;font-weight:800;color:var(--blue-900);margin-bottom:2px}
.wb-details p{font-size:.8rem;color:var(--gray-500)}
.wb-tag{margin-left:auto;background:var(--yellow-400);color:var(--blue-900);font-size:.72rem;font-weight:800;padding:4px 10px;border-radius:100px;white-space:nowrap}
@media(max-width:768px){.weekend-grid{grid-template-columns:1fr}}
@media(max-width:480px){.wi-card{padding:18px 16px;gap:12px}.wb-badge{flex-wrap:wrap}.wb-tag{margin-left:0}}

/* ============================================================
   FOUNDER / WHO IS BEHIND SECTION
============================================================ */
.founder-section{padding:80px 0;background:var(--white)}
.founder-card{max-width:860px;margin:48px auto 0;background:var(--blue-50);border-radius:var(--radius-xl);padding:44px 40px;display:grid;grid-template-columns:180px 1fr;gap:40px;align-items:start;border:1px solid var(--blue-100);box-shadow:var(--shadow-md)}
/* CLS fix: explicit dimensions + aspect-ratio prevent layout shift while image loads */
.founder-avatar{width:120px;height:120px;aspect-ratio:1;border-radius:50%;overflow:hidden;margin:0 auto 20px;border:4px solid var(--yellow-400);box-shadow:0 8px 25px rgba(0,0,0,0.15);flex-shrink:0}
.founder-avatar img{width:100%;height:100%;object-fit:cover;display:block;}
.founder-bio h3{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:800;color:var(--blue-900);margin-bottom:4px}
.founder-bio .founder-title{font-size:.88rem;font-weight:700;color:var(--blue-600);margin-bottom:16px;display:block}
.founder-bio p{font-size:.92rem;color:var(--gray-700);line-height:1.75;margin-bottom:18px}
.founder-badges{display:flex;flex-wrap:wrap;gap:8px}
.fb-badge{display:inline-flex;align-items:center;gap:5px;background:var(--white);color:var(--blue-800);font-size:.78rem;font-weight:700;padding:5px 12px;border-radius:100px;border:1px solid var(--blue-100);box-shadow:var(--shadow-sm)}
@media(max-width:640px){.founder-card{grid-template-columns:1fr;text-align:center;padding:28px 22px}.founder-avatar{margin:0 auto}.founder-badges{justify-content:center}}

/* ============================================================
   CERTIFICATE PREVIEW
============================================================ */
.certificate-section{padding:80px 0;background:var(--blue-900);position:relative;overflow:hidden}
.certificate-section::after{content:'';position:absolute;bottom:-80px;right:-80px;width:360px;height:360px;background:radial-gradient(circle,rgba(251,191,36,.07) 0%,transparent 70%);pointer-events:none}
.cert-wrap{max-width:720px;margin:48px auto 0;text-align:center}
.cert-mockup{background:linear-gradient(135deg,#fff9e6,#fffdf0);border:3px solid var(--yellow-400);border-radius:var(--radius-xl);padding:44px 40px;box-shadow:0 24px 64px rgba(0,0,0,.4);position:relative;overflow:hidden}
.cert-mockup::before{content:'';position:absolute;inset:8px;border:1px solid rgba(251,191,36,.4);border-radius:calc(var(--radius-xl) - 4px);pointer-events:none}
.cert-logo{font-size:3rem;margin-bottom:8px}
.cert-org{font-family:'Sora',sans-serif;font-size:.85rem;font-weight:800;color:var(--blue-800);text-transform:uppercase;letter-spacing:.12em;margin-bottom:20px}
.cert-title-text{font-family:'Sora',sans-serif;font-size:.8rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.cert-main-title{font-family:'Sora',sans-serif;font-size:clamp(1.4rem,4vw,2rem);font-weight:800;color:var(--blue-900);margin-bottom:24px}
.cert-presented{font-size:.85rem;color:var(--gray-500);margin-bottom:8px}
.cert-name{font-family:'Sora',sans-serif;font-size:1.8rem;font-weight:800;color:var(--blue-700);border-bottom:2px solid var(--yellow-400);padding-bottom:6px;display:inline-block;margin-bottom:20px}
.cert-course{font-size:.9rem;color:var(--gray-700);font-weight:600;margin-bottom:28px}
.cert-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid rgba(251,191,36,.3)}
.cert-date,.cert-sign{text-align:center;font-size:.78rem;color:var(--gray-500)}
.cert-sign-line{width:100px;height:1px;background:var(--gray-300);margin:0 auto 6px}
.cert-note{color:rgba(255,255,255,.6);font-size:.85rem;margin-top:22px;font-style:italic}
@media(max-width:480px){.cert-mockup{padding:28px 18px}.cert-footer{flex-direction:column;gap:16px;align-items:center}}

/* ============================================================
   UPI PAYMENT SECTION
============================================================ */
.upi-section{padding:60px 0;background:linear-gradient(150deg,#112270 0%,var(--blue-800) 100%)}
.upi-wrap{max-width:700px;margin:0 auto;text-align:center}
.upi-header{color:rgba(255,255,255,.7);font-size:.9rem;margin-bottom:28px}
.upi-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:28px}
.upi-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:24px 20px;text-align:center}
.upi-card.upi-card-highlight{background:rgba(251,191,36,.12);border-color:rgba(251,191,36,.35)}
.upi-card-icon{font-size:2rem;margin-bottom:10px}
.upi-card h4{font-family:'Sora',sans-serif;font-size:1rem;font-weight:800;color:var(--white);margin-bottom:4px}
.upi-card .upi-amt{font-family:'Sora',sans-serif;font-size:1.8rem;font-weight:800;color:var(--yellow-400);margin-bottom:4px}
.upi-card p{font-size:.8rem;color:rgba(255,255,255,.55);line-height:1.5}
.upi-id-box{background:rgba(255,255,255,.06);border:1px solid rgba(251,191,36,.28);border-radius:var(--radius-md);padding:18px 24px;margin-bottom:20px}
.upi-id-label{font-size:.78rem;color:rgba(255,255,255,.5);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.upi-id-value{font-family:'Sora',sans-serif;font-size:1.25rem;font-weight:800;color:var(--yellow-400);letter-spacing:.04em}
.upi-id-apps{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:12px}
.upi-app{font-size:.75rem;font-weight:700;color:rgba(255,255,255,.7);background:rgba(255,255,255,.08);padding:4px 12px;border-radius:100px}
.upi-note{font-size:.82rem;color:rgba(255,255,255,.45);margin-top:16px;line-height:1.6}
@media(max-width:480px){.upi-cards{grid-template-columns:1fr}}

/* ============================================================
   REFUND POLICY SECTION
============================================================ */
.refund-section{padding:64px 0;background:var(--gray-100)}
.refund-wrap{max-width:780px;margin:40px auto 0}
.refund-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.refund-card{background:var(--white);border-radius:var(--radius-lg);padding:26px 22px;box-shadow:var(--shadow-sm);text-align:center;border-top:4px solid var(--blue-600)}
.refund-card.refund-green{border-top-color:var(--green-500)}
.refund-card.refund-yellow{border-top-color:var(--yellow-500)}
.refund-card.refund-red{border-top-color:var(--red-500)}
.refund-icon{font-size:2rem;margin-bottom:12px}
.refund-card h4{font-size:.92rem;font-weight:800;color:var(--blue-900);margin-bottom:6px}
.refund-card p{font-size:.82rem;color:var(--gray-500);line-height:1.6}
.refund-footer-note{text-align:center;margin-top:22px;font-size:.85rem;color:var(--gray-500);font-style:italic}
@media(max-width:640px){.refund-grid{grid-template-columns:1fr}}

/* ============================================================
   SCHOLARSHIP TEST SECTION
============================================================ */
.scholar-section{padding:80px 0;background:linear-gradient(135deg,#f0f9ff,var(--blue-50))}
.scholar-wrap{max-width:680px;margin:48px auto 0;background:var(--white);border-radius:var(--radius-xl);padding:44px 40px;box-shadow:var(--shadow-lg);border:1px solid var(--blue-100)}
.scholar-badges{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:28px}
.sch-badge{display:inline-flex;align-items:center;gap:5px;background:var(--blue-50);color:var(--blue-700);font-size:.78rem;font-weight:700;padding:5px 12px;border-radius:100px;border:1px solid var(--blue-100)}
.scholar-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.scholar-form-grid .form-group input{background:var(--blue-50);border:1px solid var(--blue-100);color:var(--gray-900);border-radius:var(--radius-sm);padding:12px 16px;font-family:'Nunito',sans-serif;font-size:.92rem;transition:border .2s;outline:none}
.scholar-form-grid .form-group input::placeholder{color:var(--gray-500)}
.scholar-form-grid .form-group input:focus{border-color:var(--blue-600);background:var(--white)}
.scholar-form-grid .form-group label{font-size:.85rem;font-weight:700;color:var(--blue-900);display:flex;flex-direction:column;gap:6px}
.scholar-form-grid .full{grid-column:1/-1}
.scholar-submit{width:100%;padding:16px;font-family:'Sora',sans-serif;font-size:1.05rem;font-weight:700;background:var(--blue-600);color:var(--white);border-radius:100px;margin-top:8px;transition:all .25s;box-shadow:var(--shadow-blue);border:none;cursor:pointer}
.scholar-submit:hover{background:var(--blue-700);transform:translateY(-2px)}
.scholar-note{text-align:center;margin-top:12px;font-size:.8rem;color:var(--gray-500)}
@media(max-width:600px){.scholar-wrap{padding:28px 20px}.scholar-form-grid{grid-template-columns:1fr}}

/* ============================================================
   IMPROVED PRICING CARDS (2-card vertical layout)
============================================================ */
.pricing-cards-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:48px;max-width:860px;margin-left:auto;margin-right:auto}
.prc-card{background:rgba(255,255,255,.07);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-xl);padding:38px 32px;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}
.prc-card:hover{transform:translateY(-4px);box-shadow:0 28px 72px rgba(0,0,0,.38)}
.prc-card.prc-popular{border-color:rgba(251,191,36,.45);background:rgba(251,191,36,.07)}
.prc-top-bar{position:absolute;top:0;left:0;right:0;height:4px;background:rgba(255,255,255,.15);border-radius:4px 4px 0 0}
.prc-popular .prc-top-bar{background:linear-gradient(90deg,var(--yellow-500),var(--yellow-300),var(--yellow-500))}
.prc-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5);margin-bottom:10px}
.prc-popular .prc-label{color:var(--yellow-300)}
.prc-popular-badge{display:inline-block;background:var(--yellow-400);color:var(--blue-900);font-size:.7rem;font-weight:800;padding:3px 10px;border-radius:100px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
.prc-original{font-size:.85rem;color:rgba(255,255,255,.35);text-decoration:line-through;font-weight:600;margin-bottom:4px}
.prc-price{font-family:'Sora',sans-serif;font-size:clamp(2.2rem,5vw,3rem);font-weight:800;color:var(--white);line-height:1;margin-bottom:4px}
.prc-popular .prc-price{color:var(--yellow-400)}
.prc-sublabel{font-size:.8rem;color:rgba(255,255,255,.5);margin-bottom:20px;font-weight:600}
.prc-divider{height:1px;background:rgba(255,255,255,.08);margin-bottom:20px}
.prc-perks{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}
.prc-perk{display:flex;align-items:center;gap:8px;font-size:.85rem;color:rgba(255,255,255,.8);font-weight:600}
.prc-perk-icon{flex-shrink:0}
.prc-cta{display:flex;width:100%;justify-content:center;align-items:center;padding:14px;border-radius:100px;font-family:'Sora',sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .22s;text-align:center;border:none;text-decoration:none}
.prc-cta-outline{background:transparent;color:rgba(255,255,255,.8);border:1.5px solid rgba(255,255,255,.25)}
.prc-cta-outline:hover{border-color:rgba(255,255,255,.6);color:var(--white)}
.prc-cta-yellow{background:var(--yellow-400);color:var(--blue-900)}
.prc-cta-yellow:hover{background:var(--yellow-300);box-shadow:0 10px 28px rgba(251,191,36,.45)}
.prc-deadline{font-size:.75rem;color:rgba(255,255,255,.35);text-align:center;margin-top:10px}
.prc-popular .prc-deadline{color:rgba(251,191,36,.5)}
@media(max-width:640px){.pricing-cards-wrap{grid-template-columns:1fr;max-width:420px}}

/* ============================================================
   DEMO CLASS SECTION
============================================================ */
.demo-section{background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue-700) 100%);padding:80px 0;position:relative;overflow:hidden}
.demo-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}

/* Container â€” same max-width & padding as .form-wrapper */
.demo-wrap{max-width:820px;margin:48px auto 0;background:rgba(255,255,255,.07);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-xl);padding:44px;position:relative;z-index:1}

/* Perk badges */
.demo-perks{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px;justify-content:center}
.demo-perk-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.28);color:#6ee7b7;font-size:.78rem;font-weight:800;padding:5px 13px;border-radius:100px;letter-spacing:.04em}

/* 2-column grid â€” mirrors .form-grid */
.demo-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.demo-form-grid .full{grid-column:1/-1}

/* Labels â€” match admission form .form-group label */
.demo-form-grid .form-group label{font-size:.85rem;font-weight:700;color:rgba(255,255,255,.9);letter-spacing:.02em;display:flex;flex-direction:column;gap:6px}

/* Inputs â€” match admission form .form-group input */
.demo-form-grid .form-group input{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);padding:12px 16px;font-family:'Nunito',sans-serif;font-size:.92rem;color:var(--white);transition:border .2s,background .2s;outline:none;width:100%}
.demo-form-grid .form-group input::placeholder{color:rgba(255,255,255,.4)}
.demo-form-grid .form-group input:focus{border-color:var(--yellow-400);background:rgba(255,255,255,.15)}

/* CTA button â€” green, matching form-submit shape */
.demo-submit{width:100%;padding:16px;font-family:'Sora',sans-serif;font-size:1.05rem;font-weight:700;background:var(--green-500);color:var(--white);border-radius:100px;border:none;cursor:pointer;transition:all .25s;box-shadow:0 8px 24px rgba(16,185,129,.35);margin-top:8px;letter-spacing:.02em}
.demo-submit:hover{background:#059669;transform:translateY(-2px);box-shadow:0 12px 32px rgba(16,185,129,.5)}
.demo-submit:disabled{opacity:.6;transform:none;cursor:not-allowed}

/* Footer note */
.demo-note{text-align:center;margin-top:12px;font-size:.8rem;color:rgba(255,255,255,.5)}

/* Mobile â€” single column, reduced padding (mirrors .form-wrapper mobile) */
@media(max-width:640px){
  .demo-wrap{padding:28px 20px}
  .demo-form-grid{grid-template-columns:1fr}
  .demo-form-grid .full{grid-column:1}
}

/* Admission form field error state */
#admissionForm input.field-error,
#admissionForm select.field-error{border:2px solid #ef4444 !important;box-shadow:0 0 0 3px rgba(239,68,68,.18) !important}

/* ============================================================
   6-WEEK ROADMAP (curriculum section replacement)
============================================================ */
.roadmap-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:40px;
}
.roadmap-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:26px 22px;
  border-top:4px solid var(--rmc);
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:transform .22s,box-shadow .22s;
}
.roadmap-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.rmc-week{
  font-size:.7rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--rmc);
  background:color-mix(in srgb,var(--rmc) 10%,transparent);
  display:inline-block;
  padding:3px 10px;
  border-radius:100px;
  width:fit-content;
}
.rmc-icon{font-size:2rem;line-height:1;margin:4px 0}
.rmc-title{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;color:var(--blue-900)}
.rmc-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.rmc-chip{
  font-size:.72rem;
  font-weight:700;
  background:var(--gray-100);
  color:var(--gray-700);
  padding:4px 10px;
  border-radius:100px;
}

/* Progress bar strip */
.roadmap-bar{
  display:flex;
  align-items:center;
  gap:4px;
  margin-top:32px;
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:22px 24px;
  box-shadow:var(--shadow-sm);
  overflow-x:auto;
  flex-wrap:wrap;
  justify-content:center;
}
.rb-step{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:5px;
  flex:1;
  min-width:80px;
  text-align:center;
}
.rb-step span{
  width:32px;height:32px;border-radius:50%;
  background:var(--rbs);
  color:#fff;
  font-weight:800;
  font-size:.72rem;
  display:flex;align-items:center;justify-content:center;
}
.rb-step{font-size:.72rem;font-weight:700;color:var(--gray-700)}
.rb-arrow{font-size:1.1rem;color:var(--gray-300);flex-shrink:0}

/* ============================================================
   STUDENT OUTCOMES SECTION
============================================================ */
.outcomes-section{
  padding:80px 0;
  background:var(--gray-100);
}
.outcomes-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:40px;
}
.outcome-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:26px 22px;
  box-shadow:var(--shadow-sm);
  display:flex;
  align-items:flex-start;
  gap:16px;
  transition:transform .22s,box-shadow .22s;
}
.outcome-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.oc-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;flex-shrink:0;
}
.oc-body h4{
  font-family:'Sora',sans-serif;
  font-size:.95rem;
  font-weight:800;
  color:var(--blue-900);
  margin-bottom:6px;
}
.oc-body p{
  font-size:.84rem;
  color:var(--gray-500);
  line-height:1.6;
}
.outcomes-cta{
  text-align:center;
  margin-top:40px;
}

/* Responsive */
@media(max-width:900px){
  .roadmap-grid{grid-template-columns:repeat(2,1fr)}
  .outcomes-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .roadmap-grid{grid-template-columns:1fr}
  .outcomes-grid{grid-template-columns:1fr}
  .roadmap-bar{gap:8px}
  .rb-arrow{display:none}
}

/* ============================================================
   MID-PAGE CTA BANNER
============================================================ */
.midpage-cta-banner{
  background:linear-gradient(120deg,var(--blue-900) 0%,var(--blue-700) 60%,var(--blue-600) 100%);
  padding:40px 0;
  position:relative;
  overflow:hidden;
}
.midpage-cta-banner::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none;
}
.midpage-cta-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  position:relative;z-index:1;
  flex-wrap:wrap;
}
.midpage-cta-text h3{
  font-family:'Sora',sans-serif;font-size:clamp(1.1rem,2.5vw,1.5rem);
  font-weight:800;color:var(--white);margin-bottom:6px;
}
.midpage-cta-text p{
  font-size:.88rem;color:rgba(255,255,255,.65);font-weight:600;
}
.midpage-cta-btns{
  display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap;
}
@media(max-width:768px){
  .midpage-cta-inner{flex-direction:column;text-align:center}
  .midpage-cta-btns{justify-content:center}
}

/* ============================================================
   FOOTER CTA ROW
============================================================ */
.footer-cta-row{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);
  padding:28px 32px;
  margin-bottom:28px;
  flex-wrap:wrap;
}
.footer-cta-text h3{
  font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;
  color:var(--white);margin-bottom:5px;
}
.footer-cta-text p{
  font-size:.85rem;color:rgba(255,255,255,.55);font-weight:600;
}
.footer-cta-btns{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}
/* Footer ghost variant â€” slightly smaller */
.btn-ghost-footer{font-size:.9rem;padding:12px 24px}
@media(max-width:640px){
  .footer-cta-row{flex-direction:column;text-align:center;padding:22px 20px}
  .footer-cta-btns{justify-content:center}
}

/* ============================================================
   BLOG PREVIEW SECTION
============================================================ */
.blog-section{padding:80px 0;background:var(--gray-100)}
.blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:48px 0 40px}
.blog-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.blog-card-img{position:relative;height:130px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.blog-card-emoji{font-size:2.8rem;line-height:1}
.blog-tag{position:absolute;bottom:12px;left:14px;font-size:.68rem;font-weight:800;padding:4px 10px;border-radius:100px;letter-spacing:.06em;text-transform:uppercase}
.blog-tag-blue{background:var(--blue-100);color:var(--blue-700)}
.blog-tag-green{background:#d1fae5;color:#065f46}
.blog-tag-yellow{background:var(--yellow-100);color:#92400e}
.blog-tag-purple{background:#ede9fe;color:#5b21b6}
.blog-card-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.blog-date{font-size:.72rem;font-weight:700;color:var(--gray-500)}
.blog-read{font-size:.72rem;font-weight:700;color:var(--gray-500);background:var(--gray-100);padding:3px 8px;border-radius:100px}
.blog-card-body h3{font-family:'Sora',sans-serif;font-size:.92rem;font-weight:800;color:var(--blue-900);line-height:1.45;margin-bottom:10px;flex:1}
.blog-card-body p{font-size:.82rem;color:var(--gray-500);line-height:1.65;margin-bottom:16px}
.blog-read-more{font-size:.82rem;font-weight:800;color:var(--blue-600);display:inline-flex;align-items:center;gap:4px;transition:gap .2s ease,color .2s ease;margin-top:auto}
.blog-read-more:hover{color:var(--blue-800);gap:8px}
.blog-cta-row{text-align:center;padding-top:4px}
@media(max-width:1100px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.blog-grid{grid-template-columns:1fr;gap:18px}.blog-section{padding:56px 0}}

@media(min-width: 950px) { .desktop-nav { display: flex !important; } }
.desktop-nav a:hover { color: var(--yellow-500) !important; }

/* Added Mobile Optimizations */
.desktop-nav { display: none; gap: 24px; align-items: center; }
@media(max-width: 768px) {
  .hero h1 { font-size: 2.2rem !important; }
  .header-inner { flex-wrap: wrap; }
  .nav-cta { margin-top: 10px; width: 100%; justify-content: center; }
  .gallery-card, .review-card { padding: 20px; }
  .hero-pricing { margin-top: 20px; }
  .desktop-nav { display: none !important; }
}

/* Mobile hero & WhatsApp positioning */
.whatsapp-float{z-index:9999;position:fixed;bottom:20px;right:20px}
@media(max-width:768px){
  /* nav-cta hidden on mobile - hamburger menu handles navigation */
  .nav-cta{display:none!important}
  .whatsapp-float{display:none!important} /* mobile sticky CTA covers this */
  .whatsapp-btn{padding:10px 16px;font-size:0.9rem;border-radius:100px}
  .hero-ctas{flex-direction:column;gap:15px}
  .hero-ctas a{width:100%}
}

/* Cleaner Mobile Hero Spacing */
@media (max-width: 768px) {
  .hero { padding: 50px 0 70px 0 !important; }
  .hero-badge-row { margin-bottom: 20px !important; }
  .hero h1 { margin-top: 15px !important; margin-bottom: 20px !important; font-size: 2.3rem !important; }
  .hero-sub { margin-bottom: 30px !important; font-size: 1.05rem !important; line-height: 1.6 !important; }
  .hero-ctas { margin-top: 35px !important; gap: 16px !important; }
  .hero-ctas a { padding: 18px !important; font-weight: 800 !important; font-size: 1.05rem !important; border-radius: 100px !important; }
}

/* New Sticky Mobile CTA Layout */
.new-sticky-layout {
  display: none;
  flex-direction: column;
  padding: 12px 16px;
  background: var(--blue-900);
  border-top: 2px solid var(--yellow-400);
  z-index: 9998;
  gap: 12px;
}
@media (max-width: 768px) {
  .new-sticky-layout {
    display: flex !important;
  }
}
.new-sticky-layout .smc-top-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.new-sticky-layout .smc-text {
  flex: 1;
  color: rgba(255,255,255,0.9);
  line-height: 1.3;
}
.new-sticky-layout .smc-text strong {
  color: var(--yellow-400);
  font-size: 0.85rem;
  display: block;
  white-space: nowrap;
}
.new-sticky-layout .smc-price {
  font-size: 1.1rem;
  font-weight: 800;
  display: block;
  margin: 3px 0;
  color: #fff;
}
.new-sticky-layout .smc-sub {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.7);
  display: block;
}
.new-sticky-layout .smc-btns {
  flex: 1.4;
  display: flex;
  gap: 8px;
  flex-direction: row;
}
.new-sticky-layout .smc-demo, .new-sticky-layout .smc-enroll {
  flex: 1;
  text-align: center;
  padding: 10px 4px;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.15;
}
.new-sticky-layout .smc-demo {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.3);
}
.new-sticky-layout .smc-enroll {
  background: var(--yellow-400);
  color: var(--blue-900);
  border: none;
}
.new-sticky-layout .smc-bottom-row {
  width: 100%;
  display: flex;
  justify-content: center;
}
.new-sticky-layout .smc-whatsapp {
  background: #25D366;
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
  padding: 12px;
  border-radius: 100px;
  text-decoration: none;
  width: 90%;
  text-align: center;
  box-shadow: 0 4px 10px rgba(37,211,102,0.3);
}

/* Fix Duplicate WhatsApp Button Overlap on Mobile */
@media (max-width: 768px) {
  .whatsapp-float { display: none !important; }
}

/* Mobile Navigation Menu */
.mobile-nav-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 2rem;
  color: var(--blue-900);
  cursor: pointer;
  padding: 5px;
  line-height: 1;
}
.mobile-nav-menu {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(15, 40, 97, 0.98);
  z-index: 10000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.mobile-nav-menu.active {
  opacity: 1;
  pointer-events: auto;
}
.mobile-nav-content {
  display: flex;
  flex-direction: column;
  gap: 35px;
  text-align: center;
}
.mobile-nav-content a {
  color: white;
  font-size: 1.6rem;
  font-weight: 700;
  font-family: 'Sora', sans-serif;
  text-decoration: none;
  transition: color 0.2s;
}
.mobile-nav-content a:active {
  color: var(--yellow-400);
}
.mobile-nav-close {
  position: absolute;
  top: 25px;
  right: 25px;
  background: none;
  border: none;
  color: white;
  font-size: 2.2rem;
  cursor: pointer;
  line-height: 1;
}

@media (max-width: 768px) {
  .mobile-nav-toggle { display: block; }
}
/* ============================================================
   CLICK FEEDBACK & SCROLL POPUP
=========================================================== */
.btn-primary:active, .btn-yellow:active, .btn-outline:active, .btn-ghost:active {
  transform: scale(0.95) !important;
  box-shadow: none !important;
}

.btn-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.btn-loading::after {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  top: 50%;
  left: 50%;
  margin-top: -10px;
  margin-left: -10px;
  border: 3px solid rgba(255,255,255,0.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 0.8s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

.scroll-cta-popup {
  position: fixed;
  bottom: 100px;
  right: 20px;
  background: var(--blue-900);
  padding: 20px 25px;
  border-radius: var(--radius-lg);
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  z-index: 9997;
  border: 1px solid var(--yellow-400);
  animation: slideInUp 0.5s ease;
}
@keyframes slideInUp {
  from { opacity: 0; transform: translateY(40px); }
  to { opacity: 1; transform: translateY(0); }
}
.scp-content p {
  color: var(--white);
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  margin-bottom: 12px;
  font-size: 1.1rem;
}
.scp-close {
  position: absolute;
  top: 10px;
  right: 15px;
  background: transparent;
  color: rgba(255,255,255,0.5);
  font-size: 1.5rem;
  line-height: 1;
}
.scp-close:hover {
  color: var(--white);
}

@media(max-width:768px){
  .scroll-cta-popup {
    bottom: 90px;
    right: 10px;
    left: 10px;
    text-align: center;
  }
}


/* =========================================================
   GLOBAL RESPONSIVE FIXES
========================================================= */
/* Normalize Section Spacing */
@media (max-width: 768px) {
  section{padding:48px 0!important}
  .hero{padding:40px 0 50px 0!important}
  .container{padding:0 16px!important}

  /* Fix Heading Overflows â€” use clamp for natural scaling */
  h1{font-size:clamp(1.8rem,6vw,2.4rem)!important;line-height:1.2!important}
  h2.section-title{font-size:clamp(1.4rem,5vw,1.9rem)!important;line-height:1.3!important}

  /* Prevent horizontal scroll */
  body{overflow-x:hidden;padding-bottom:70px}

  /* Stack 2-column grids on mobile */
  .conv-grid,.ba-grid,.mission-grid,.gaming-grid,.weekend-grid,.blog-grid{
    grid-template-columns:1fr!important;
    gap:20px!important
  }

  /* Fix Comparison Section */
  .ba-card{padding:24px!important;text-align:left}
  .ba-card ul li{align-items:center}

  /* Mobile buttons: only full-width inside flex containers, NOT globally */
  .hero-ctas .btn-yellow,.hero-ctas .btn-primary,.hero-ctas .btn-outline{
    width:100%;
    justify-content:center;
    text-align:center
  }
  .smc-btns a,.gaming-cta-row a{
    min-width:120px
  }

  /* Fix Mobile Nav */
  .mobile-nav-content{gap:20px!important;padding:20px}
  .mobile-nav-content a{font-size:1.25rem!important;font-weight:600!important}

  /* Card Padding Consistency */
  .why-card,.conv-card,.hl-card{padding:20px!important}

  /* Sticky layout visibility */
  .new-sticky-layout{
    display:none!important;
    position:fixed;
    bottom:0;left:0;right:0;
    z-index:9998;
    background:var(--blue-900);
    padding:12px 16px;
    box-shadow:0 -4px 15px rgba(0,0,0,0.15)
  }
  .new-sticky-layout.is-visible{
    display:flex!important
  }
}


/* Blog Card CTA Actions */
.blog-card-actions {
  margin-top: 30px;
  border-top: 1px solid var(--gray-100);
  padding-top: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
}

@media (max-width: 640px) {
  .blog-card-actions {
    flex-direction: column;
    align-items: stretch;
  }
}


/* Collapsible Curriculum */
.rmc-chips {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, margin-top 0.3s ease;
  margin-top: 0 !important;
}
.rmc-chips.expanded {
  max-height: 200px;
  margin-top: 15px !important;
}
.rmc-title {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rmc-title::after {
  content: '+';
  font-size: 1.4rem;
  transition: transform 0.3s;
}
.rmc-title.expanded::after {
  transform: rotate(45deg);
}

/* =========================================================
   SECONDARY PAGE THEME UNIFICATION
========================================================= */
.header .logo {
  text-decoration: none;
}

.desktop-nav a.nav-active {
  color: var(--yellow-500) !important;
}

.btn-sm {
  padding: 10px 20px;
  font-size: .88rem;
}

.btn-article {
  padding: 10px 20px;
  font-size: .9rem;
}

.btn-lg {
  padding: 16px 36px;
  font-size: 1.1rem;
}

.page-hero {
  text-align: center;
}

.blog-hero-date {
  max-width: none;
  font-weight: 800;
  color: var(--dark-text-soft);
}

.secondary-main {
  padding: 80px 0 100px;
}

.article-main {
  padding-top: 60px;
  padding-bottom: 80px;
}

.secondary-layer {
  position: relative;
  z-index: 1;
}

.article-shell {
  max-width: 860px;
  margin: 0 auto;
  padding: 48px;
  border-radius: var(--radius-lg);
}

.article-content p {
  font-size: 1.1rem;
  color: var(--dark-text);
  line-height: 1.8;
  margin-bottom: 20px;
}

.article-content h2 {
  font-family: 'Sora', sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--yellow-400);
  margin: 36px 0 16px;
}

.article-content h3 {
  font-family: 'Sora', sans-serif;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--yellow-400);
  margin: 24px 0 12px;
}

.article-content ul {
  padding-left: 24px;
  margin-bottom: 20px;
  list-style: disc;
}

.article-content li {
  font-size: 1.1rem;
  color: var(--dark-text);
  line-height: 1.7;
  margin-bottom: 12px;
}

.article-content strong {
  color: var(--yellow-400);
}

.article-content em {
  color: var(--dark-text-strong);
}

.article-cta-box {
  margin: 40px 0;
  padding: 28px 30px;
  background: var(--fg-card-bg);
  border-left: 4px solid var(--blue-600);
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-blue-border);
}

.article-cta-box h3 {
  font-family: 'Sora', sans-serif;
  font-size: 1.15rem;
  color: var(--yellow-400);
  margin-bottom: 10px;
}

.article-cta-box p {
  font-size: .95rem;
  color: var(--dark-text);
  margin-bottom: 16px;
}

.cta-btn-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.article-final-cta {
  margin-top: 50px;
  border-radius: var(--radius-lg);
  padding: 36px;
  text-align: center;
}

.article-final-cta h3 {
  font-family: 'Sora', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--white);
  margin-bottom: 12px;
}

.article-final-cta p {
  font-size: 1rem;
  color: var(--dark-text);
  margin-bottom: 24px;
}

.blog-tag-large {
  padding: 6px 14px;
  font-size: .8rem;
}

.review-grid,
.project-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 28px;
  margin-top: 60px;
}

.stats-row {
  display: flex;
  gap: 32px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 60px;
}

.stat-card {
  padding: 24px 36px;
  text-align: center;
  min-width: 160px;
}

.stat-value {
  font-family: 'Sora', sans-serif;
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--yellow-400);
}

.stat-label {
  color: var(--dark-text-soft);
  font-size: .9rem;
  margin-top: 4px;
}

.stars {
  color: var(--yellow-400);
  font-size: 1.3rem;
  margin-bottom: 14px;
  letter-spacing: 2px;
}

.review-card {
  padding: 32px;
}

.gallery-card {
  padding: 36px 24px;
  text-align: center;
}

.project-chip-row {
  margin-top: 20px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}

.project-chip {
  padding: 4px 12px;
  border-radius: 100px;
  font-size: .78rem;
  font-weight: 700;
  border: 1px solid var(--glass-blue-border);
  background: var(--glass-blue);
  color: var(--blue-300);
}

.project-chip-blue {
  background: var(--glass-blue);
  border-color: var(--glass-blue-border);
  color: var(--blue-300);
}

.project-chip-green {
  background: var(--glass-green);
  border-color: var(--glass-green-border);
  color: var(--green-300);
}

.project-chip-gold {
  background: var(--glass-gold);
  border-color: var(--glass-gold-border);
  color: var(--yellow-300);
}

.project-chip-purple {
  background: var(--glass-purple);
  border-color: var(--glass-purple-border);
  color: var(--purple-300);
}

.project-chip-cyan {
  background: var(--glass-cyan);
  border-color: var(--glass-cyan-border);
  color: var(--fg-cyan);
}

.secondary-cta {
  margin-top: 70px;
  text-align: center;
}

@media (max-width: 768px) {
  .secondary-main,
  .article-main {
    padding: 56px 0 72px;
  }

  .article-shell {
    padding: 30px 22px;
  }

  .stats-row {
    gap: 18px;
    margin-bottom: 44px;
  }
}

/* =========================================================
   BREADCRUMB & INJECTED SECTION FIXES
========================================================= */

/* Breadcrumb visibility fix without modifying HTML inline styles */
nav[aria-label="Breadcrumb"] {
    background: #f8fafc !important;
}
nav[aria-label="Breadcrumb"] a {
    color: var(--blue-700) !important;
}
nav[aria-label="Breadcrumb"] span {
    color: var(--gray-800) !important;
}
nav[aria-label="Breadcrumb"] span > span {
    color: var(--gray-500) !important;
}

/* Founder bio box fix for mobile without touching HTML */
@media (max-width: 768px) {
  div:has(> img[src="assets/founder.jpeg"]) {
    flex-direction: column !important;
    text-align: center !important;
    gap: 12px !important;
  }
}

/* =========================================================
   ADVANCED MOBILE & PERFORMANCE OPTIMIZATIONS
========================================================= */

/* 1. Reduce GPU-heavy effects selectively on mobile */
@media (max-width: 768px) {
  /* Simplify layered shadows and blurs */
  .hero-pricing, .trust-signals, .blog-card, .ba-card, .why-card {
    box-shadow: 0 4px 10px rgba(0,0,0,0.08) !important;
    backdrop-filter: none !important;
  }
  
  /* Reduce excessive blur intensity on small screens */
  .midpage-cta-banner::before, .header {
    backdrop-filter: blur(4px) !important;
  }
  
  /* Simplify badge glows */
  .hero-badge, .fg-badge {
    animation: none !important;
    box-shadow: 0 2px 5px rgba(251,191,36,0.2) !important;
  }
  
  /* Optimize scrolling smoothness */
  .mobile-nav-menu {
    -webkit-overflow-scrolling: touch;
  }
}

/* 2. Prefers Reduced Motion Handling */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* 3. Lightweight rendering strategy & Touch responsiveness */
html {
  text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
}

/* ============================================================
   FUTURISTIC-GLOBAL.CSS  â€” Motion, Animation & Color Layer
   Preserves: ALL @keyframes, transform, transition, 3D,
              scroll-reveal, backdrop-filter, perspective
   Added:     Site color tokens from skillnest.co.in
   ============================================================ */

/* ============================================================
   1. IMPORT FONTS
   ============================================================ */
/* Note: Google Fonts loaded via <link> in HTML head â€” @import removed to prevent duplicate request */

/* ============================================================
   2. ANIMATION TIMING TOKENS
   ============================================================ */
:root {
  --fg-ease-bounce: cubic-bezier(.34,1.56,.64,1);
  --fg-ease-smooth: cubic-bezier(.22,1,.36,1);
  --fg-dur-fast:    .22s;
  --fg-dur-mid:     .32s;
  --fg-dur-slow:    .70s;

  /* â”€â”€ Site color tokens â”€â”€ */
  --fg-navy:        #080f1f;
  --fg-navy-mid:    #0a1628;
  --fg-navy-deep:   #0f1f4a;
  --fg-blue-900:    #0f2861;
  --fg-blue-800:    #1a3a7a;
  --fg-blue-700:    #1e4ea0;
  --fg-blue-600:    #2563eb;
  --fg-blue-400:    #60a5fa;
  --fg-gold:        #fbbf24;
  --fg-gold-light:  #fcd34d;
  --fg-gold-dim:    rgba(251,191,36,.18);
  --fg-cyan:        #06b6d4;
  --fg-purple:      #7c3aed;
  --fg-green:       #10b981;
  --fg-card-bg:     rgba(255,255,255,.06);
  --fg-card-border: rgba(255,255,255,.12);
}

/* ============================================================
   3. REDUCED-MOTION SAFETY
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .tilt-3d, .parallax-hero, .depth-layer, .fg-reveal {
    transform: none !important;
    opacity: 1 !important;
  }
}

/* ============================================================
   4. PAGE HERO â€” dark gradient + animated orb overlay
   ============================================================ */
.page-hero {
  position: relative;
  padding: 120px 0 80px;
  overflow: hidden;
  background: linear-gradient(160deg, var(--fg-navy) 0%, var(--fg-navy-mid) 55%, var(--fg-navy-deep) 100%);
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(ellipse 70% 60% at 50% 0%, rgba(37,99,235,.18) 0%, transparent 70%);
}
/* fg-orb-drift removed: replaced with static opacity to eliminate continuous animation overhead */
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(ellipse 50% 40% at 80% 80%, rgba(124,58,237,.08) 0%, transparent 65%);
  opacity: .55;
}
.page-hero .container { position: relative; z-index: 2; }

/* Page hero text colors */
.page-hero h1             { color: #ffffff; }
.page-hero h1 span        { color: var(--fg-gold); }
.page-hero p              { color: rgba(255,255,255,.78); font-size: 1.05rem; line-height: 1.75; }

/* ============================================================
   5. PAGE HERO TAG â€” gold badge with glow
   ============================================================ */
.page-hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 100px;
  padding: 6px 16px;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 20px;
  backdrop-filter: blur(8px);
  background: rgba(251,191,36,.14);
  border: 1px solid rgba(251,191,36,.32);
  color: var(--fg-gold);
  box-shadow: 0 0 6px rgba(251,191,36,.20), 0 0 14px rgba(251,191,36,.06);
}
.page-hero-tag::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 0 12px rgba(251,191,36,.40), 0 0 26px rgba(251,191,36,.12);
  opacity: 0;
  animation: fg-badge-glow-opacity 3s ease-in-out infinite;
  pointer-events: none;
}
.page-hero-tag .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--fg-gold);
  animation: fg-dot-pulse 2.2s ease-in-out infinite;
}
@keyframes fg-badge-glow-opacity {
  0%,100% { opacity: 0; }
  50%      { opacity: 1; }
}
@keyframes fg-dot-pulse {
  0%,100% { opacity: 1; transform: scale(1);   }
  50%      { opacity: .7; transform: scale(1.3); }
}

/* ============================================================
   6. SECTION TITLE â€” gradient underline animated
   ============================================================ */
.section-title {
  position: relative;
  display: inline-block;
}
.section-title::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 0;
  height: 3px;
  border-radius: 3px;
  transition: width .65s var(--fg-ease-smooth) .15s;
  background: linear-gradient(90deg, var(--fg-blue-600), var(--fg-cyan), var(--fg-gold));
  background-size: 200%;
  animation: fg-text-shift 4s ease infinite;
}
.text-center .section-title::after { left: 50%; transform: translateX(-50%); }
.fade-up.visible .section-title::after,
.section-title.title-visible::after { width: 72%; }
@keyframes fg-text-shift {
  0%,100% { background-position: 0%; }
  50%      { background-position: 100%; }
}

/* ============================================================
   7. SECTION TAG â€” motion + colors
   ============================================================ */
.section-tag {
  transition: transform var(--fg-dur-fast) var(--fg-ease-bounce),
              box-shadow var(--fg-dur-fast) ease;
}
.section-tag:hover { transform: translateY(-2px) scale(1.04); }
.section-tag .dot  { animation: fg-dot-pulse 2.2s ease-in-out infinite; }

/* ============================================================
   8. FG-SECTION-DARK â€” dark navy section base
   ============================================================ */
.fg-section-dark {
  background: linear-gradient(160deg, var(--fg-navy) 0%, var(--fg-navy-mid) 55%, var(--fg-navy-deep) 100%);
  position: relative;
  overflow: hidden;
}
.fg-section-dark::before {
  content: '';
  position: absolute;
  top: -120px; right: -120px;
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(37,99,235,.10) 0%, transparent 70%);
  pointer-events: none;
}
.fg-section-dark::after {
  content: '';
  position: absolute;
  bottom: -80px; left: -80px;
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(124,58,237,.08) 0%, transparent 70%);
  pointer-events: none;
}

/* ============================================================
   9. FG-CARD â€” glassmorphic dark card
   ============================================================ */
.fg-card {
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  transition: transform var(--fg-dur-mid) var(--fg-ease-bounce),
              box-shadow var(--fg-dur-mid) ease;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.11);
  box-shadow: 0 8px 32px rgba(0,0,0,.28);
}
.fg-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 40%;
  height: 100%;
  background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.10) 50%, transparent 80%);
  pointer-events: none;
  animation: fg-sweep 5s ease-in-out infinite;
  animation-delay: var(--sweep-delay, 0s);
}
@keyframes fg-sweep {
  0%   { transform: translateX(-130%) skewX(-12deg); opacity: 0; }
  10%  { opacity: .45; }
  70%  { opacity: .20; }
  100% { transform: translateX(230%)  skewX(-12deg); opacity: 0; }
}
.fg-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 40%;
  height: 100%;
  background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.08) 50%, transparent 80%);
  pointer-events: none;
  animation: fg-sweep 8s ease-in-out infinite;  /* slowed from 5s to 8s */
  animation-delay: var(--sweep-delay, 0s);
}
.fg-card:hover {
  transform: translateY(-10px) perspective(700px) rotateX(2deg);
  box-shadow: 0 20px 56px rgba(0,0,0,.40), 0 0 0 1px rgba(251,191,36,.15);
}

/* ============================================================
   10. SCROLL REVEAL
   ============================================================ */
.fg-reveal {
  opacity: 0;
  transform: translateY(32px) scale(.982);
  transition: opacity var(--fg-dur-slow) var(--fg-ease-smooth),
              transform var(--fg-dur-slow) var(--fg-ease-smooth);
}
.fg-reveal.fg-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.fg-reveal-delay-1 { transition-delay: .10s; }
.fg-reveal-delay-2 { transition-delay: .20s; }
.fg-reveal-delay-3 { transition-delay: .30s; }
.fg-reveal-delay-4 { transition-delay: .45s; }

/* ============================================================
   11. FADE-UP
   ============================================================ */
.fade-up {
  opacity: 0;
  transform: translateY(30px) scale(.982);
  transition: opacity var(--fg-dur-slow) var(--fg-ease-smooth),
              transform var(--fg-dur-slow) var(--fg-ease-smooth);
}
.fade-up.visible      { opacity: 1; transform: translateY(0) scale(1); }
.fade-up-delay-1      { transition-delay: .10s; }
.fade-up-delay-2      { transition-delay: .20s; }
.fade-up-delay-3      { transition-delay: .30s; }

/* ============================================================
   12. TILT 3D / PARALLAX
   ============================================================ */
.tilt-3d {
  transform-style: preserve-3d;
  transition: transform .10s ease-out, box-shadow .10s ease-out;
  perspective: 900px;
}
.parallax-hero {
  transition: transform .08s linear;
  will-change: transform;
  transform-style: preserve-3d;
}
.depth-layer { transform-style: preserve-3d; }

/* ============================================================
   13. BUTTON HOVER â€” shimmer + 3D lift
   ============================================================ */
.btn-primary, .btn-yellow { position: relative; overflow: hidden; }
.btn-primary::before, .btn-yellow::before {
  content: '';
  position: absolute;
  top: 0; left: -130%;
  width: 65%; height: 100%;
  background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.26) 50%, transparent 80%);
  pointer-events: none;
  border-radius: inherit;
  transition: left 0s;
}
.btn-primary:hover::before,
.btn-yellow:hover::before  { left: 130%; transition: left .55s ease; }

.btn-primary:hover { transform: translateY(-3px) scale(1.02); }
.btn-yellow:hover  { transform: translateY(-3px) scale(1.02); }
.btn-outline:hover { transform: translateY(-2px) scale(1.01); }
.btn-ghost:hover   { transform: translateY(-3px) scale(1.01); }

.btn-primary:active,
.btn-yellow:active,
.btn-outline:active,
.btn-ghost:active {
  transform: translateY(1px) scale(.975) !important;
  transition: transform .05s ease !important;
}

/* ============================================================
   14. CARD HOVER 3D TRANSFORMS + COLOR ACCENTS
   ============================================================ */
.why-card {
  transform-style: preserve-3d;
  transition: transform var(--fg-dur-mid) var(--fg-ease-bounce),
              box-shadow var(--fg-dur-mid) ease;
}
.why-card:hover {
  transform: translateY(-10px) perspective(700px) rotateX(2deg);
  box-shadow: 0 20px 48px rgba(37,99,235,.18);
}
.why-icon { transition: transform .35s var(--fg-ease-bounce); }
.why-card:hover .why-icon { transform: scale(1.2) rotate(-6deg) translateY(-3px); }

.hl-card {
  transition: transform var(--fg-dur-mid) var(--fg-ease-bounce),
              box-shadow var(--fg-dur-mid) ease;
  position: relative; overflow: hidden;
}
.hl-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(251,191,36,.08) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}
.hl-card:hover { transform: translateY(-10px) perspective(700px) rotateX(2deg); }
.hl-card:hover::before { opacity: 1; }
.hl-icon { transition: transform .35s var(--fg-ease-bounce); display: block; }
.hl-card:hover .hl-icon { transform: scale(1.3) translateY(-4px); }

.testi-card {
  position: relative; overflow: hidden;
  transition: transform .35s var(--fg-ease-bounce), box-shadow .35s ease;
}
.testi-card::before {
  content: '"';
  position: absolute;
  top: -10px; right: 16px;
  font-size: 7rem;
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  line-height: 1;
  pointer-events: none;
  color: rgba(37,99,235,.07);
  transition: opacity .3s ease, transform .3s ease;
}
.testi-card:hover { transform: translateY(-10px) perspective(800px) rotateX(1.5deg); }
.testi-card:hover::before { transform: scale(1.1) rotate(-3deg); }
.testi-card:hover .testi-avatar {
  transform: scale(1.12);
  transition: transform .3s ease, box-shadow .3s ease;
  box-shadow: 0 0 0 3px rgba(251,191,36,.45);
}

.trust-card {
  transition: transform .30s var(--fg-ease-bounce), box-shadow .30s ease;
  position: relative; overflow: hidden;
}
.trust-card::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--fg-blue-600), var(--fg-cyan));
  opacity: 0;
  transition: opacity .3s ease;
}
.trust-card:hover { transform: translateY(-7px) translateX(3px); }
.trust-card:hover::after { opacity: 1; }

.daily-card {
  transition: transform .35s var(--fg-ease-bounce), box-shadow .35s ease;
}
.daily-card:hover { transform: translateY(-9px) scale(1.02); }
.daily-icon { transition: transform .35s var(--fg-ease-bounce); display: block; }
.daily-card:hover .daily-icon { transform: scale(1.22) rotate(8deg) translateY(-3px); }

.project-card {
  transition: transform .35s var(--fg-ease-bounce), box-shadow .35s ease;
}
.project-card:hover {
  transform: translateY(-12px) perspective(700px) rotateX(2deg) scale(1.015);
  box-shadow: 0 24px 56px rgba(0,0,0,.22);
}
.project-top { transition: font-size .3s ease; }
.project-card:hover .project-top { font-size: 4.5rem; }

.level-card {
  transition: transform .30s var(--fg-ease-bounce), box-shadow .30s ease;
}
.level-card:hover { transform: translateY(-6px); }

.pricing-card {
  transition: transform .35s var(--fg-ease-bounce), box-shadow .35s ease;
}
.pricing-card:hover {
  transform: translateY(-8px) scale(1.015);
  box-shadow: 0 28px 64px rgba(0,0,0,.45), 0 0 0 1px rgba(251,191,36,.25);
}

/* ============================================================
   15. FAQ MOTION
   ============================================================ */
.faq-item {
  transition: transform .24s ease, box-shadow .24s ease;
}
.faq-item:hover  { transform: translateX(4px); }
.faq-arrow       { transition: transform .35s var(--fg-ease-bounce) !important; }

/* ============================================================
   16. GAMING / ROADMAP / WEEKEND CARDS
   ============================================================ */
.gaming-col {
  transition: transform var(--fg-dur-mid) var(--fg-ease-bounce), box-shadow var(--fg-dur-mid) ease;
}
.gaming-col:hover { transform: translateY(-6px); }

.roadmap-card {
  transition: transform .30s var(--fg-ease-bounce), box-shadow .30s ease;
}
.roadmap-card:hover { transform: translateY(-6px) scale(1.02); }

.wi-card, .wb-badge {
  transition: transform .28s var(--fg-ease-bounce), box-shadow .28s ease;
}
.wi-card:hover, .wb-badge:hover { transform: translateX(6px); }

/* ============================================================
   17. ARTICLE CARDS
   ============================================================ */
article {
  transition: transform .30s var(--fg-ease-bounce), box-shadow .30s ease !important;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
}
article:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 48px rgba(0,0,0,.32) !important;
  border-color: rgba(251,191,36,.18);
}

/* ============================================================
   18. SOCIAL LINKS
   ============================================================ */
.social-link {
  transition: background .22s ease,
              transform .35s var(--fg-ease-bounce),
              box-shadow .3s ease;
}
.social-link:hover { transform: translateY(-5px) scale(1.18); }

/* ============================================================
   19. WHATSAPP FLOAT
   ============================================================ */
.whatsapp-btn { animation: waFloat 2.8s ease-in-out infinite; transition: transform .2s ease; }

/* ============================================================
   20. LOGO ICON HOVER
   ============================================================ */
.logo-icon {
  transition: transform .4s var(--fg-ease-bounce), box-shadow .3s ease;
}
.logo:hover .logo-icon {
  transform: rotate(-8deg) scale(1.12) translateY(-2px);
  box-shadow: 0 8px 24px rgba(37,99,235,.45);
}

/* ============================================================
   21. HERO STAT ICON HOVER
   ============================================================ */
.hero-stat-icon {
  backdrop-filter: blur(8px);
  transition: transform .3s var(--fg-ease-bounce), box-shadow .3s ease;
}
.hero-stat:hover .hero-stat-icon {
  transform: scale(1.12) rotate(-6deg);
  box-shadow: 0 0 18px rgba(6,182,212,.45);
}

/* ============================================================
   22. HERO CARD STACK
   ============================================================ */
.hero-card-stack {
  filter: drop-shadow(0 32px 56px rgba(37,99,235,.28));
  transition: filter .4s ease;
}
.hero-card-stack:hover {
  filter: drop-shadow(0 40px 64px rgba(37,99,235,.45));
}
.course-item {
  transition: background .25s ease, transform .25s ease;
}
.course-item:hover {
  transform: translateX(4px);
  background: rgba(255,255,255,.13);
}

/* ============================================================
   23. HERO BADGE HOVER
   ============================================================ */
.hero-badge {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .3s var(--fg-ease-bounce);
}
.hero-badge:hover { transform: translateY(-2px) scale(1.04); }

/* ============================================================
   24. ANNOUNCEMENT BAR SHIMMER
   ============================================================ */
.announcement-bar { position: relative; overflow: hidden; }
.announcement-bar::after {
  content: '';
  position: absolute;
  top: 0; left: -80%;
  width: 55%; height: 100%;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,.09), transparent);
  animation: bar-shimmer 5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes bar-shimmer { 0% { left: -80%; } 100% { left: 110%; } }

/* ============================================================
   25. HEADER BLUR + NAV UNDERLINE
   ============================================================ */
.header {
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  transition: box-shadow .4s ease, background .4s ease;
}
.desktop-nav a { position: relative; }
.desktop-nav a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 0; height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--fg-blue-600), var(--fg-cyan));
  transition: width .3s var(--fg-ease-smooth);
}
.desktop-nav a:hover::after { width: 100%; }

/* ============================================================
   26. B2B FEATURE CARD â€” dark glass card for b2b-schools
   ============================================================ */
.b2b-feature-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  transition: transform var(--fg-dur-mid) var(--fg-ease-bounce),
              box-shadow var(--fg-dur-mid) ease,
              border-color var(--fg-dur-mid) ease;
}
.b2b-feature-card:hover {
  transform: translateY(-8px) scale(1.01);
  border-color: rgba(251,191,36,.22);
  box-shadow: 0 20px 52px rgba(0,0,0,.35);
}

/* B2B CTA block */
.b2b-cta-block {
  background: linear-gradient(135deg, rgba(37,99,235,.22), rgba(124,58,237,.18));
  border: 1px solid rgba(37,99,235,.30);
}
.b2b-cta-block h2 {
  color: #ffffff;
}
.b2b-cta-block p {
  color: rgba(255, 255, 255, 0.85);
}

/* ============================================================
   27. REVIEW CARD â€” for parent-testimonials page
   ============================================================ */
.review-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  transition: transform .32s var(--fg-ease-bounce),
              box-shadow .32s ease,
              border-color .32s ease;
}
.review-card:hover {
  transform: translateY(-8px);
  border-color: rgba(251,191,36,.22);
  box-shadow: 0 20px 48px rgba(0,0,0,.35);
}
.review-card .review-text { color: rgba(255,255,255,.80); line-height: 1.75; }
.review-card .parent-name  { font-weight: 800; color: #ffffff; margin-top: 14px; }
.review-card .student-detail { font-size: .82rem; color: rgba(255,255,255,.50); }

/* ============================================================
   28. GALLERY CARD â€” student-projects page
   ============================================================ */
.gallery-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  transition: transform .32s var(--fg-ease-bounce),
              box-shadow .32s ease,
              border-color .32s ease;
}
.gallery-card:hover {
  transform: translateY(-8px) scale(1.015);
  border-color: rgba(6,182,212,.25);
  box-shadow: 0 20px 52px rgba(0,0,0,.38);
}
.gallery-card .gallery-icon  { font-size: 3rem; margin-bottom: 14px; }
.gallery-card .gallery-title { font-family: 'Sora',sans-serif; font-weight: 800; color: #ffffff; margin-bottom: 10px; }
.gallery-card .gallery-desc  { color: rgba(255,255,255,.65); font-size: .9rem; line-height: 1.65; }

/* ============================================================
   29. BLOG PAGE â€” blog-tag colors
   ============================================================ */
.blog-tag         { font-size: .72rem; font-weight: 800; padding: 4px 12px; border-radius: 100px; letter-spacing: .06em; text-transform: uppercase; }
.blog-tag-blue    { background: rgba(37,99,235,.18); color: #93c5fd; border: 1px solid rgba(37,99,235,.30); }
.blog-tag-green   { background: rgba(16,185,129,.15); color: #6ee7b7; border: 1px solid rgba(16,185,129,.28); }
.blog-tag-purple  { background: rgba(124,58,237,.18); color: #c4b5fd; border: 1px solid rgba(124,58,237,.30); }
.blog-tag-yellow  { background: rgba(251,191,36,.15); color: #fcd34d; border: 1px solid rgba(251,191,36,.28); }
.blog-date        { font-size: .82rem; font-weight: 700; color: rgba(255,255,255,.45); }

/* ============================================================
   30. MID-PAGE CTA BANNER
   ============================================================ */
.midpage-cta-banner {
  background: linear-gradient(90deg, var(--fg-blue-900), #112270, var(--fg-blue-800));
  padding: 28px 0;
  position: relative;
  overflow: hidden;
}
.midpage-cta-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,.04), transparent);
  animation: bar-shimmer 6s ease-in-out infinite;
  pointer-events: none;
}
.midpage-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
.midpage-cta-text h3 { color: #ffffff; font-family: 'Sora',sans-serif; font-size: 1.1rem; font-weight: 800; margin-bottom: 4px; }
.midpage-cta-text p  { color: rgba(255,255,255,.60); font-size: .88rem; }
.midpage-cta-btns    { display: flex; gap: 10px; flex-wrap: wrap; }

/* ============================================================
   31. FOOTER CTA ROW
   ============================================================ */
.footer-cta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  padding: 28px 0 24px;
}
.footer-cta-text h3 { font-family: 'Sora',sans-serif; font-size: 1.05rem; font-weight: 800; color: #ffffff; margin-bottom: 4px; }
.footer-cta-text p  { color: rgba(255,255,255,.50); font-size: .88rem; }
.footer-cta-btns    { display: flex; gap: 10px; flex-wrap: wrap; }
.btn-ghost-footer   { border-color: rgba(255,255,255,.25); }
.btn-ghost-footer:hover { border-color: rgba(255,255,255,.60); background: rgba(255,255,255,.15); }

/* ============================================================
   32. STICKY CTA STRIP â€” injected by enhancements.js
   ============================================================ */
.sticky-cta-strip {
  transform: translateY(100%);
  transition: transform .45s var(--fg-ease-smooth);
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9990;
  background: linear-gradient(90deg, var(--fg-blue-900), #112270);
  border-top: 2px solid var(--fg-gold);
  padding: 12px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  box-shadow: 0 -4px 20px rgba(0,0,0,.30);
}
.sticky-cta-strip.visible { transform: translateY(0); }
.sticky-cta-strip p       { color: rgba(255,255,255,.80); font-weight: 700; font-size: .88rem; }
.sticky-cta-strip .strip-cta {
  background: var(--fg-gold);
  color: var(--fg-blue-900);
  font-weight: 800;
  font-size: .85rem;
  padding: 9px 20px;
  border-radius: 100px;
  white-space: nowrap;
  transition: background .2s, transform .2s;
}
.sticky-cta-strip .strip-cta:hover { background: var(--fg-gold-light); transform: scale(1.04); }
.sticky-cta-strip .strip-close {
  background: transparent;
  color: rgba(255,255,255,.45);
  font-size: 1.2rem;
  line-height: 1;
  flex-shrink: 0;
  transition: color .2s;
}
.sticky-cta-strip .strip-close:hover { color: #ffffff; }

/* ============================================================
   33. EXIT / SCROLL POPUPS
   ============================================================ */
#exitPopup > div { animation: popIn3D .5s var(--fg-ease-bounce); }
@keyframes popIn3D {
  from { opacity: 0; transform: scale(.78) translateY(28px) perspective(600px) rotateX(8deg); }
  to   { opacity: 1; transform: scale(1)   translateY(0)    perspective(600px) rotateX(0deg); }
}
.scroll-cta-popup { animation: slideInUp3D .5s var(--fg-ease-bounce); }
@keyframes slideInUp3D {
  from { opacity: 0; transform: translateY(56px) scale(.88) perspective(500px) rotateX(10deg); }
  to   { opacity: 1; transform: translateY(0)    scale(1)   perspective(500px) rotateX(0deg); }
}

/* ============================================================
   34. FORM BLUR
   ============================================================ */
.form-wrapper {
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
}

/* ============================================================
   35. SCROLLBAR
   ============================================================ */
::-webkit-scrollbar        { width: 6px; }
::-webkit-scrollbar-track  { background: var(--fg-navy); }
::-webkit-scrollbar-thumb  {
  background: linear-gradient(180deg, var(--fg-blue-600), var(--fg-purple));
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: var(--fg-cyan); }

/* ============================================================
   36. MOBILE â€” disable heavy 3D
   ============================================================ */
@media (max-width: 768px) {
  .tilt-3d, .parallax-hero { transform: none !important; transition: none !important; }
  .page-hero::after         { animation: none; }
  .fg-card::after           { display: none; }
  .announcement-bar::after  { display: none; }

  .why-card:hover, .hl-card:hover, .testi-card:hover,
  .trust-card:hover, .daily-card:hover, .project-card:hover,
  .level-card:hover, .pricing-card:hover {
    transform: translateY(-4px) !important;
  }

  .midpage-cta-inner  { flex-direction: column; text-align: center; }
  .midpage-cta-btns   { justify-content: center; }
  .footer-cta-row     { flex-direction: column; text-align: center; }
  .footer-cta-btns    { justify-content: center; }
  .sticky-cta-strip p { font-size: .78rem; }
}

/* ============================================================
   COLOR-DYNAMICS.CSS â€” Animation, Motion & Color Layer
   OPTIMIZED: All animations now use only transform/opacity
   Removed: box-shadow/filter keyframes (caused full repaints)
   Preserved: gradient-flow, light-sweep (GPU composited)
   ============================================================ */

/* ============================================================
   ANIMATION TIMING TOKENS
============================================================ */
:root {
  --cd-cycle-dur:  7s;
  --cd-flow-dur:   9s;
  --cd-sweep-dur:  6s;    /* Slowed from 3.6s â†’ reduces paint frequency */
  --cd-bg-size:    400% 400%;

  /* â”€â”€ Site color palette â”€â”€ */
  --cd-blue:       #2563eb;
  --cd-purple:     #7c3aed;
  --cd-gold:       #fbbf24;
  --cd-cyan:       #06b6d4;
  --cd-green:      #10b981;
  --cd-navy:       #0f2861;
  --cd-navy-dark:  #080f1f;
}

/* ============================================================
   REDUCED-MOTION
============================================================ */
@media (prefers-reduced-motion: reduce) {
  .cd-glow, .cd-card, .cd-btn-shift, .cd-reflect,
  .cd-hero-orb, .cd-light {
    animation: none !important;
    transition: opacity .3s ease !important;
  }
  .cd-reflect::after { display: none !important; }
}

/* ============================================================
   1. KEYFRAMES â€” GPU-safe only (transform + opacity)
============================================================ */

/* Opacity pulse for glow effect â€” replaces box-shadow animation */
@keyframes cd-glow-pulse {
  0%,100% { opacity: 0.6; }
  50%      { opacity: 1;   }
}

/* Background gradient flow â€” animates background-position (composited) */
@keyframes gradient-flow {
  0%   { background-position: 0%   50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0%   50%; }
}

/* Light sweep across card face â€” transform only (composited) */
@keyframes light-sweep {
  0%   { transform: translateX(-130%) skewX(-12deg); opacity: 0;   }
  10%  { opacity: .45; }
  60%  { opacity: .28; }
  100% { transform: translateX(220%)  skewX(-12deg); opacity: 0;   }
}

/* Button gradient shift â€” background-position (composited) */
@keyframes btn-gradient-shift {
  0%   { background-position: 0%   50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0%   50%; }
}

/* Gold badge glow pulse â€” opacity only (composited) */
@keyframes cd-badge-glow {
  0%,100% { opacity: 0.75; }
  50%      { opacity: 1;    }
}

/* ============================================================
   2. CD-GLOW â€” subtle opacity pulse on seats-badge / section-tag
      Replaces expensive box-shadow color-cycle animation
============================================================ */
.cd-glow {
  animation: cd-glow-pulse var(--cd-cycle-dur) ease-in-out infinite;
}
.cd-glow:hover {
  animation-play-state: paused;
}

/* ============================================================
   3. CD-CARD â€” light sheen sweep on hover-eligible cards
      border-color cycle REMOVED (was animating border-color = repaint)
      Replaced with: subtle pseudo-element opacity shimmer
============================================================ */
.cd-card {
  position: relative;
  overflow: hidden;
}

/* Moving light sheen via pseudo-element transform (GPU composited) */
.cd-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 45%; height: 100%;
  background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.10) 50%, transparent 80%);
  pointer-events: none;
  border-radius: inherit;
  animation: light-sweep var(--cd-sweep-dur) ease-in-out infinite;
  animation-delay: var(--cd-stagger, 0s);
  z-index: 3;
}

.cd-card:hover::after {
  animation-play-state: paused;
  opacity: 0;
  transition: opacity .18s ease;
}

/* ============================================================
   4. CD-BTN-SHIFT â€” living gradient on CTA buttons
      Uses background-position animation (GPU composited)
============================================================ */
.cd-btn-shift {
  background-size: var(--cd-bg-size) !important;
  animation: btn-gradient-shift var(--cd-flow-dur) ease infinite;
  transition: transform .22s ease !important;
}

/* btn-primary: blue â†’ purple gradient */
.btn-primary.cd-btn-shift {
  background: linear-gradient(135deg,
    #2563eb 0%, #1e4ea0 25%, #7c3aed 50%, #2563eb 75%, #06b6d4 100%
  ) !important;
  background-size: var(--cd-bg-size) !important;
}

/* btn-yellow: gold â†’ orange gradient */
.btn-yellow.cd-btn-shift {
  background: linear-gradient(135deg,
    #fbbf24 0%, #f97316 25%, #fbbf24 50%, #fcd34d 75%, #fbbf24 100%
  ) !important;
  background-size: var(--cd-bg-size) !important;
}

/* Hover: 3D lift (transform only â€” composited) */
.btn-primary.cd-btn-shift:hover {
  transform: translateY(-4px) scale(1.03) !important;
}
.btn-yellow.cd-btn-shift:hover {
  transform: translateY(-4px) scale(1.03) !important;
}

/* Press-down */
.btn-primary.cd-btn-shift:active,
.btn-yellow.cd-btn-shift:active,
.btn-ghost.cd-btn-shift:active {
  transform: translateY(2px) scale(.972) !important;
  transition: transform .06s ease !important;
}

/* ============================================================
   5. CD-HERO-ORB â€” animated gradient overlay in hero section
============================================================ */
.cd-hero-orb {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: linear-gradient(135deg,
    rgba(37,99,235,.18) 0%,
    rgba(124,58,237,.14) 35%,
    rgba(6,182,212,.10) 65%,
    rgba(16,185,129,.08) 100%
  );
  background-size: var(--cd-bg-size);
  animation: gradient-flow calc(var(--cd-flow-dur) * 1.6) ease infinite;
  mix-blend-mode: screen;
  border-radius: inherit;
  opacity: .9;
}

/* ============================================================
   6. CD-REFLECT â€” top-edge gradient + light sweep on premium cards
============================================================ */
.cd-reflect {
  position: relative;
  overflow: hidden;
}
.cd-reflect::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  pointer-events: none;
  background: linear-gradient(90deg,
    var(--cd-blue), var(--cd-purple), var(--cd-gold), var(--cd-cyan), var(--cd-blue)
  );
  background-size: var(--cd-bg-size);
  animation: gradient-flow calc(var(--cd-flow-dur) * .8) ease-in-out infinite;
  z-index: 4;
  opacity: .75;
  border-radius: 4px 4px 0 0;
}
.cd-reflect::after {
  content: '';
  position: absolute;
  top: -20%; left: -60%;
  width: 40%; height: 160%;
  background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.07) 50%, transparent 80%);
  pointer-events: none;
  animation: light-sweep calc(var(--cd-sweep-dur) * 1.4) ease-in-out infinite;
  animation-delay: .8s;
  z-index: 4;
}

/* ============================================================
   7. URGENCY BAR â€” animated gradient overlay (composited)
============================================================ */
.urgency-bar {
  position: relative;
  overflow: hidden;
}
.urgency-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(251,191,36,.12) 30%,
    rgba(249,115,22,.10) 60%,
    transparent 100%
  );
  background-size: 300% 100%;
  animation: gradient-flow 5s ease infinite;
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   8. SECTION TITLE chromatic underline
============================================================ */
.cd-card .section-title::after,
.cd-glow.section-title::after {
  background: linear-gradient(90deg,
    var(--cd-blue), var(--cd-cyan), var(--cd-gold), var(--cd-purple), var(--cd-blue)
  );
  background-size: 300%;
  animation: gradient-flow 4s ease infinite;
}

/* ============================================================
   9. HIGHLIGHTS â€” number gradient text (background-clip = composited)
============================================================ */
.hl-card.cd-card .hl-value {
  background: linear-gradient(135deg, var(--cd-gold), #f97316, var(--cd-gold));
  background-size: 300%;
  animation: gradient-flow 4s ease infinite;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ============================================================
   10. FLOAT CARDS â€” subtle opacity pulse
============================================================ */
.float-card.cd-glow {
  animation: cd-glow-pulse calc(var(--cd-cycle-dur) * 1.2) ease-in-out infinite;
}

/* ============================================================
   11. MOBILE â€” simplified, minimal animations
============================================================ */
@media (max-width: 768px) {
  .cd-card::after         { display: none !important; }
  .cd-reflect::after      { display: none !important; }
  .cd-hero-orb            { animation: none !important; opacity: .6; }
  .cd-btn-shift           { animation-duration: 18s !important; }
  .cd-card                { animation: none !important; }
  .cd-glow                { animation: cd-badge-glow 3.5s ease-in-out infinite !important; }
}

/* ============================================================
   12. STAGGER HELPERS
   JS sets: card.style.setProperty('--cd-stagger', i * .55 + 's')
============================================================ */

/* ============================================================
   ENHANCEMENTS.CSS â€” Motion & 3D Layer
   OPTIMIZED: Removed global will-change overuse, removed
   non-composited animations (bar-aurora, scan-line),
   reduced blur intensity, tightened mobile rules.
   Keeps: @keyframes, transform, transition, fade-up, backdrop-filter
   ============================================================ */

/* ============================================================
   PERFORMANCE BASELINE
   Only add will-change to elements actually being animated
============================================================ */
.hero-main-card,.hero-card-stack,.float-card,
.btn-primary,.btn-yellow,.whatsapp-btn{will-change:transform}

/* ============================================================
   REDUCED-MOTION SAFETY
============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .tilt-3d,.parallax-hero,.depth-layer{transform:none!important}
}

/* ============================================================
   ANNOUNCEMENT BAR â€” shimmer sweep only (transform-based)
   Removed: bar-aurora (not visible enough to justify paint)
============================================================ */
.announcement-bar{position:relative;overflow:hidden;letter-spacing:.03em}
.announcement-bar::after{content:'';position:absolute;top:0;left:-80%;width:55%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,0.09),transparent);animation:bar-shimmer 6s ease-in-out infinite;pointer-events:none}
@keyframes bar-shimmer{0%{left:-80%}100%{left:110%}}

/* ============================================================
   HEADER â€” blur & transition only
============================================================ */
.header{backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);transition:box-shadow .4s ease,background .4s ease}
.logo-icon{transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.logo:hover .logo-icon{transform:rotate(-8deg) scale(1.12) translateY(-2px)}
.desktop-nav a{position:relative}
.desktop-nav a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;border-radius:2px;transition:width .3s cubic-bezier(.22,1,.36,1)}
.desktop-nav a:hover::after{width:100%}

/* ============================================================
   HERO â€” layout & animation (no scan-line: invisible, adds overhead)
============================================================ */
.hero{position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.03) 1px,transparent 1px);background-size:36px 36px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);pointer-events:none;z-index:0}
.hero::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;animation:orb-drift 14s ease-in-out infinite alternate}
@keyframes orb-drift{0%{opacity:1;transform:translateY(0) scale(1)}50%{opacity:.75;transform:translateY(-16px) scale(1.03)}100%{opacity:.55;transform:translateY(-8px) scale(1.06)}}
.hero-content,.hero-visual{position:relative;z-index:2}

/* Hero badges */
.hero-badge{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.hero-badge:hover{transform:translateY(-2px) scale(1.04)}
.hero-stat-icon{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.hero-stat:hover .hero-stat-icon{transform:scale(1.12) rotate(-6deg)}

/* ============================================================
   HERO CARD â€” 3D glass (reduced blur from 28px â†’ 20px)
============================================================ */
.tilt-3d{transform-style:preserve-3d;transition:transform .10s ease-out;perspective:900px}
.hero-main-card{backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);transition:transform .10s ease-out;position:relative}
.hero-main-card::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;pointer-events:none}
.course-item{transition:background .25s ease,transform .25s ease}
.course-item:hover{transform:translateX(4px)}
.hero-card-stack{transition:filter .4s ease}
.float-card{backdrop-filter:blur(12px);transition:transform .35s ease}
.parallax-hero{transition:transform .08s linear;will-change:transform;transform-style:preserve-3d}
.depth-layer{transform-style:preserve-3d}

/* ============================================================
   BUTTONS â€” shimmer sweep & 3D lift only
============================================================ */
.btn-primary,.btn-yellow{position:relative;overflow:hidden}
.btn-primary::before,.btn-yellow::before{content:'';position:absolute;top:0;left:-130%;width:65%;height:100%;background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.22) 50%,transparent 80%);pointer-events:none;border-radius:inherit;transition:left 0s}
.btn-primary:hover::before,.btn-yellow:hover::before{left:130%;transition:left .55s ease}
.btn-primary:hover{transform:translateY(-3px) scale(1.02)}
.btn-yellow:hover{transform:translateY(-3px) scale(1.02)}
.btn-outline:hover{transform:translateY(-2px) scale(1.01)}
.btn-ghost:hover{transform:translateY(-3px) scale(1.01)}
.btn-primary:active,.btn-yellow:active,.btn-outline:active,.btn-ghost:active{transform:translateY(1px) scale(.975)!important;transition:transform .05s ease!important}

/* ============================================================
   SECTION TAG â€” dot pulse & hover lift
============================================================ */
.section-tag{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.section-tag:hover{transform:translateY(-2px) scale(1.04)}
.section-tag .dot{animation:dot-pulse 2.2s ease-in-out infinite}
@keyframes dot-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}

/* Section title animated underline */
.section-title{position:relative;display:inline-block}
.section-title::after{content:'';position:absolute;bottom:-5px;left:0;right:0;margin:0 auto;width:0;height:3px;border-radius:3px;transition:width .65s cubic-bezier(.22,1,.36,1) .15s;;background-size:200%}
.text-center .section-title::after{left:50%;transform:translateX(-50%)}
.fade-up.visible .section-title::after,.section-title.title-visible::after{width:72%}
@keyframes gradient-shift{0%,100%{background-position:0%}50%{background-position:100%}}

/* ============================================================
   CARD 3D HOVER SYSTEM â€” simplified (reduced perspective complexity)
============================================================ */
.why-card{transition:transform .32s cubic-bezier(.34,1.56,.64,1),box-shadow .32s ease}
.why-card:hover{transform:translateY(-8px)}
.why-icon{transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.why-card:hover .why-icon{transform:scale(1.2) rotate(-6deg) translateY(-3px)}

.hl-card{transition:transform .32s cubic-bezier(.34,1.56,.64,1),box-shadow .32s ease;position:relative;overflow:hidden}
.hl-card::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .35s ease;pointer-events:none}
.hl-card:hover{transform:translateY(-8px)}
.hl-card:hover::before{opacity:1}
.hl-icon{transition:transform .35s cubic-bezier(.34,1.56,.64,1);display:block}
.hl-card:hover .hl-icon{transform:scale(1.3) translateY(-4px)}

.testi-card{position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease}
.testi-card::before{content:'"';position:absolute;top:-10px;right:16px;font-size:7rem;font-family:'Sora',sans-serif;font-weight:800;line-height:1;pointer-events:none;transition:opacity .3s ease,transform .3s ease}
.testi-card:hover{transform:translateY(-8px)}
.testi-card:hover::before{transform:scale(1.1) rotate(-3deg)}
.testi-card:hover .testi-avatar{transform:scale(1.12);transition:transform .3s ease}

.trust-card{transition:transform .30s cubic-bezier(.34,1.56,.64,1),box-shadow .30s ease;position:relative;overflow:hidden}
.trust-card::after{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;opacity:0;transition:opacity .3s ease}
.trust-card:hover{transform:translateY(-6px) translateX(2px)}
.trust-card:hover::after{opacity:1}

.daily-card{transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease}
.daily-card:hover{transform:translateY(-7px) scale(1.01)}
.daily-icon{transition:transform .35s cubic-bezier(.34,1.56,.64,1);display:block}
.daily-card:hover .daily-icon{transform:scale(1.2) rotate(8deg) translateY(-3px)}

.project-card{transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease}
.project-card:hover{transform:translateY(-10px) scale(1.01)}
.project-top{transition:font-size .3s ease}
.project-card:hover .project-top{font-size:4.2rem}

.level-card{transition:transform .30s cubic-bezier(.34,1.56,.64,1),box-shadow .30s ease}
.level-card:hover{transform:translateY(-5px)}

.pricing-card{transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease}
.pricing-card:hover{transform:translateY(-6px) scale(1.01)}

/* ============================================================
   FAQ MOTION
============================================================ */
.faq-item{transition:transform .24s ease}
.faq-item:hover{transform:translateX(3px)}
.faq-arrow{transition:transform .35s cubic-bezier(.34,1.56,.64,1)!important}

/* ============================================================
   COUNTDOWN â€” digit tick
============================================================ */
.countdown-unit{transition:transform .12s ease;position:relative;overflow:hidden}
.countdown-unit .num{transition:transform .14s ease,opacity .14s ease}
.countdown-unit.cd-tick .num{transform:translateY(-7px);opacity:0}

/* ============================================================
   FORM â€” reduced blur (32px â†’ 20px, significant paint savings)
============================================================ */
.form-wrapper{backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%)}

/* ============================================================
   MISC MOTION
============================================================ */
.social-link{transition:background .22s ease,transform .35s cubic-bezier(.34,1.56,.64,1)}
.social-link:hover{transform:translateY(-4px) scale(1.15)}
.whatsapp-btn{animation:waFloat 3s ease-in-out infinite;transition:transform .2s ease}

/* Fade-up â€” scroll reveal */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up-delay-1{transition-delay:.10s}
.fade-up-delay-2{transition-delay:.20s}
.fade-up-delay-3{transition-delay:.30s}

/* Highlights section */
.highlights-section{position:relative;overflow:hidden}

/* Article hover */
article{transition:transform .30s cubic-bezier(.34,1.56,.64,1),box-shadow .30s ease!important}
article:hover{transform:translateY(-5px)!important}

/* Gaming, roadmap, weekend */
.gaming-col{transition:transform .32s cubic-bezier(.34,1.56,.64,1),box-shadow .32s ease}
.gaming-col:hover{transform:translateY(-5px)}
.roadmap-card{transition:transform .30s cubic-bezier(.34,1.56,.64,1),box-shadow .30s ease}
.roadmap-card:hover{transform:translateY(-5px) scale(1.01)}
.wi-card,.wb-badge{transition:transform .28s cubic-bezier(.34,1.56,.64,1),box-shadow .28s ease}
.wi-card:hover,.wb-badge:hover{transform:translateX(5px)}

/* Popups */
#exitPopup > div{animation:popIn3D .4s cubic-bezier(.34,1.56,.64,1)}
@keyframes popIn3D{from{opacity:0;transform:scale(.82) translateY(24px)}to{opacity:1;transform:scale(1) translateY(0)}}
.scroll-cta-popup{animation:slideInUp3D .4s cubic-bezier(.34,1.56,.64,1)}
@keyframes slideInUp3D{from{opacity:0;transform:translateY(48px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Sticky CTA slide */
.sticky-cta-strip{transform:translateY(100%);transition:transform .45s cubic-bezier(.22,1,.36,1)}
.sticky-cta-strip.visible{transform:translateY(0)}

/* ============================================================
   MOBILE â€” disable heavy effects, preserve basic transitions
============================================================ */
@media(max-width:768px){
  .tilt-3d,.parallax-hero{transform:none!important;transition:none!important}
  .why-card:hover,.hl-card:hover,.testi-card:hover,.trust-card:hover,
  .daily-card:hover,.project-card:hover,.level-card:hover,.pricing-card:hover{transform:translateY(-3px)!important}
  .why-card,.hl-card,.testi-card,.project-card{perspective:none}
  .hero::after{animation:none}
  .announcement-bar::after{display:none}
  .fade-up{transition:opacity .5s ease,transform .5s ease}
}

/* ============================================================
   RESOURCES.CSS â€” NCERT Resources Section
   Scoped under .resources-page to prevent conflicts.
   Extends existing classes; does NOT override them.
   ============================================================ */

/* ============================================================
   RESOURCES NAV DROPDOWN
   Extends existing .desktop-nav a behavior
   ============================================================ */
.nav-resources-item {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav-resources-trigger {
  background: none;
  border: none;
  font-family: 'Nunito', sans-serif;
  font-size: .9rem;
  font-weight: 700;
  color: var(--blue-900);
  cursor: pointer;
  padding: 4px 2px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: color .2s;
  position: relative;
}
.nav-resources-trigger::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 0; height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--blue-600), #06b6d4);
  transition: width .3s cubic-bezier(.22,1,.36,1);
}
.nav-resources-item:hover .nav-resources-trigger::after,
.nav-resources-trigger[aria-expanded="true"]::after { width: 100%; }
.nav-resources-trigger .caret {
  font-size: .65rem;
  transition: transform .25s ease;
}
.nav-resources-trigger[aria-expanded="true"] .caret { transform: rotate(180deg); }

/* Dropdown Panel */
.nav-resources-panel {
  display: none;
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 260px;
  background: #fff;
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 12px 8px;
  z-index: 9000;
  animation: dropdown-appear .18s ease;
}
@keyframes dropdown-appear {
  from { opacity: 0; transform: translateX(-50%) translateY(-6px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.nav-resources-item:hover .nav-resources-panel,
.nav-resources-panel.open { display: block; }

.nav-resources-panel a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  border-radius: var(--radius-sm);
  font-size: .88rem;
  font-weight: 700;
  color: var(--blue-900);
  transition: background .18s, color .18s;
  text-decoration: none;
}
.nav-resources-panel a:hover { background: var(--blue-50); color: var(--blue-600); }
.nav-dropdown-divider {
  height: 1px;
  background: var(--gray-100);
  margin: 6px 8px;
}
.nav-dropdown-classes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding: 6px 6px 2px;
}
.nav-dropdown-classes a {
  font-size: .78rem;
  padding: 6px 8px;
  justify-content: center;
  border: 1px solid var(--gray-100);
  border-radius: 8px;
}
.nav-dropdown-classes a:hover { border-color: var(--blue-300); }

/* Mobile dropdown */
.mobile-resources-section {
  border-top: 1px solid rgba(255,255,255,.1);
  margin-top: 8px;
  padding-top: 8px;
}
.mobile-resources-label {
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--yellow-300);
  padding: 4px 16px;
  display: block;
}
.mobile-resources-classes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding: 8px 14px;
}
.mobile-resources-classes a {
  font-size: .8rem;
  padding: 7px 4px;
  text-align: center;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.85);
  font-weight: 700;
}
.mobile-resources-classes a:hover,
.mobile-resources-classes a.active {
  background: rgba(251,191,36,.2);
  border-color: rgba(251,191,36,.4);
  color: var(--yellow-300);
}

/* ============================================================
   CLASS NAVIGATION STRIP
   ============================================================ */
.class-nav-strip {
  background: var(--white);
  border-bottom: 1px solid var(--gray-100);
  padding: 14px 0;
  position: sticky;
  top: 65px;
  z-index: 90;
  box-shadow: var(--shadow-sm);
}
.class-nav-inner {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.class-nav-inner::-webkit-scrollbar { display: none; }
.class-nav-label {
  font-size: .75rem;
  font-weight: 800;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: .08em;
  white-space: nowrap;
  flex-shrink: 0;
}
.class-nav-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--blue-900);
  background: var(--blue-50);
  border: 1px solid var(--blue-100);
  white-space: nowrap;
  flex-shrink: 0;
  transition: all .2s ease;
  text-decoration: none;
}
.class-nav-pill:hover { background: var(--blue-100); border-color: var(--blue-300); }
.class-nav-pill.active {
  background: var(--blue-600);
  color: var(--white);
  border-color: var(--blue-600);
  box-shadow: 0 4px 12px rgba(37,99,235,.3);
}

/* ============================================================
   SUBJECT SECTION HEADER
   ============================================================ */
.subject-section {
  padding: 60px 0 40px;
}
.subject-section:nth-child(odd) { background: var(--white); }
.subject-section:nth-child(even) { background: var(--blue-50); }
.subject-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--blue-100);
}
.subject-icon-wrap {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  flex-shrink: 0;
}
.subject-header h2 {
  font-family: 'Sora', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--blue-900);
  margin: 0;
}
.subject-book-count {
  margin-left: auto;
  font-size: .78rem;
  font-weight: 700;
  color: var(--gray-500);
  background: var(--gray-100);
  padding: 4px 12px;
  border-radius: 100px;
  white-space: nowrap;
}

/* ============================================================
   BOOK CARD â€” extends .why-card
   ============================================================ */
.book-card {
  /* Inherits .why-card layout */
  display: flex;
  flex-direction: column;
  gap: 0;
}
.book-subject-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 3px 10px;
  border-radius: 100px;
  margin-bottom: 10px;
  width: fit-content;
}
.book-chapter-count {
  font-size: .78rem;
  color: var(--gray-500);
  margin: 4px 0 12px;
  font-weight: 600;
}
.book-desc {
  font-size: .85rem;
  color: var(--gray-500);
  line-height: 1.6;
  margin-bottom: 16px;
  flex: 1;
}
.book-primary-btn {
  font-size: .85rem !important;
  padding: 10px 18px !important;
  margin-bottom: 8px;
  width: 100%;
  justify-content: center;
}

/* Chapter accordion toggle */
.book-chapter-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: var(--blue-50);
  border: 1px solid var(--blue-100);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--blue-700);
  cursor: pointer;
  transition: background .2s;
  font-family: 'Nunito', sans-serif;
  margin-top: 4px;
}
.book-chapter-toggle:hover { background: var(--blue-100); }
.book-chapter-toggle .toggle-caret {
  font-size: .7rem;
  transition: transform .25s ease;
}
.book-chapter-toggle.open .toggle-caret { transform: rotate(180deg); }

.book-chapters-list {
  display: none;
  flex-direction: column;
  gap: 4px;
  margin-top: 8px;
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-sm);
  padding: 6px;
  background: var(--white);
  scrollbar-width: thin;
}
.book-chapters-list.open { display: flex; }
.chapter-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 10px;
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--blue-700);
  text-decoration: none;
  transition: background .18s;
  gap: 8px;
}
.chapter-link:hover { background: var(--blue-50); color: var(--blue-900); }
.chapter-link .dl-icon { flex-shrink: 0; font-size: .85rem; }

/* ============================================================
   EXEMPLAR SECTION
   ============================================================ */
.exemplar-section {
  padding: 80px 0;
}
.exemplar-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(124,58,237,.12);
  border: 1px solid rgba(124,58,237,.25);
  color: #c4b5fd;
  font-size: .75rem;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 10px;
}
.exemplar-card {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease;
}
.exemplar-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 48px rgba(0,0,0,.35);
  border-color: rgba(124,58,237,.3);
}
.exemplar-card h4 {
  font-family: 'Sora', sans-serif;
  font-size: 1rem;
  font-weight: 800;
  color: #fff;
}
.exemplar-card p {
  font-size: .85rem;
  color: rgba(255,255,255,.65);
  line-height: 1.6;
}
.exemplar-chapter-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 200px;
  overflow-y: auto;
  scrollbar-width: thin;
}
.exemplar-chapter-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 10px;
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255,255,255,.75);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  text-decoration: none;
  transition: background .18s;
  margin-top: 2px;
}
.exemplar-chapter-link:hover { background: rgba(124,58,237,.2); color: #c4b5fd; }

/* ============================================================
   STANDALONE BREADCRUMB BAR (above the hero)
   ============================================================ */
.res-breadcrumb-bar {
  background: #fff;
  border-bottom: 1px solid rgba(0,0,0,.07);
  padding: 10px 0;
  width: 100%;
}
.res-breadcrumb-bar .container {
  display: flex;
  align-items: center;
}
.res-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .82rem;
  font-weight: 600;
  color: #64748b;
  list-style: none;
  margin: 0;
  padding: 0;
}
.res-breadcrumb a {
  color: #334155;
  text-decoration: none;
  font-weight: 700;
  transition: color .18s;
}
.res-breadcrumb a:hover { color: var(--blue-600, #2563eb); }
.res-breadcrumb .bc-sep {
  color: #94a3b8;
  font-size: .75rem;
  user-select: none;
}
.res-breadcrumb .bc-current {
  color: #64748b;
  font-weight: 600;
}

/* ============================================================
   RESOURCES HERO TWEAKS (extends .page-hero)
   ============================================================ */
.resources-hero .hero-ctas { justify-content: center; }

/* Class hero stats strip */
.res-stats-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 28px;
  margin-top: 28px;
  justify-content: center;
}
.res-stat {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .85rem;
  font-weight: 700;
  color: rgba(255,255,255,.8);
}
.res-stat-icon { font-size: 1rem; }

/* ============================================================
   RESOURCES LANDING PAGE â€” Class Grid Cards
   ============================================================ */
.class-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 48px;
}
.class-grid-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  text-align: center;
  border: 1px solid var(--blue-100);
  box-shadow: var(--shadow-sm);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease, border-color .3s;
  text-decoration: none;
  display: block;
}
.class-grid-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-md);
  border-color: var(--blue-300);
}
.class-grid-card .cgc-num {
  font-family: 'Sora', sans-serif;
  font-size: 2rem;
  font-weight: 800;
  color: var(--blue-600);
  line-height: 1;
  margin-bottom: 6px;
}
.class-grid-card .cgc-label {
  font-size: .82rem;
  font-weight: 700;
  color: var(--gray-500);
  margin-bottom: 10px;
  display: block;
}
.class-grid-card .cgc-subjects {
  font-size: .72rem;
  color: var(--blue-400);
  line-height: 1.5;
}
.class-grid-card.has-exemplar { border-color: rgba(124,58,237,.25); }
.class-grid-card.has-exemplar:hover { border-color: rgba(124,58,237,.5); }
.cgc-exemplar-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .65rem;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 100px;
  background: rgba(124,58,237,.1);
  color: #7c3aed;
  border: 1px solid rgba(124,58,237,.2);
  margin-top: 8px;
}

/* ============================================================
   INTERNAL CLASS NAVIGATOR (bottom of page)
   ============================================================ */
.class-navigator {
  background: var(--blue-50);
  border-top: 1px solid var(--blue-100);
  border-bottom: 1px solid var(--blue-100);
  padding: 28px 0;
}
.class-navigator-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.class-nav-prev, .class-nav-next {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 100px;
  font-size: .88rem;
  font-weight: 800;
  background: var(--white);
  border: 1px solid var(--blue-100);
  color: var(--blue-900);
  text-decoration: none;
  transition: all .2s ease;
}
.class-nav-prev:hover, .class-nav-next:hover {
  background: var(--blue-600);
  color: var(--white);
  border-color: var(--blue-600);
  transform: translateY(-2px);
}
.class-nav-all-link {
  font-size: .85rem;
  font-weight: 700;
  color: var(--blue-600);
  text-decoration: none;
}
.class-nav-all-link:hover { color: var(--blue-900); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .class-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .nav-resources-panel { min-width: 220px; left: -10px; transform: none; }
  .class-grid { grid-template-columns: repeat(2, 1fr); }
  .class-navigator-inner { flex-direction: column; text-align: center; }
  .subject-section { padding: 40px 0 28px; }
}
@media (max-width: 480px) {
  .class-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .nav-dropdown-classes { grid-template-columns: repeat(3, 1fr); }
  .class-nav-pill { font-size: .75rem; padding: 5px 10px; }
}

/* ============================================================
   LOGO HOME LINK â€” injected by nav-inject.js
   ============================================================ */
.logo a {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 12px;
  padding: 4px 8px 4px 4px;
  margin: -4px -8px -4px -4px;
  transition: background .2s ease;
}
.logo a:hover {
  background: rgba(37, 99, 235, .07);
}
.logo a .logo-icon {
  transition: transform .22s cubic-bezier(.34,1.56,.64,1);
}
.logo a:hover .logo-icon {
  transform: scale(1.1) rotate(-3deg);
}

