/* ============================================================
   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);
}
