/* ═══════════════════════════════════════════
   STRESSLESS LEARNER — MAIN STYLESHEET
   Theme: Sage Green + Off-White + Charcoal
   ═══════════════════════════════════════════ */

:root {
  --primary:       #4F7F6F;
  --primary-dark:  #2D5048;
  --primary-deep:  #1E3D33;
  --sage:          #7FAF9B;
  --sage-light:    #A8C5B8;
  --beige:         #E8E4DC;
  --beige-warm:    #F5F3EE;
  --light:         #FAFAF7;
  --white:         #FFFFFF;
  --text:          #1F1F1F;
  --text-muted:    #6B7280;
  --border:        #E8E4DC;
  --green-ok:      #44CF6C;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.05);
  --shadow-lg: 0 10px 40px rgba(0,0,0,.10), 0 4px 12px rgba(0,0,0,.06);
  --shadow-xl: 0 20px 60px rgba(0,0,0,.12);
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --transition: .25s cubic-bezier(.4,0,.2,1);
}

/* ─── Reset & Base ─── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter','Segoe UI',sans-serif;
  font-size:16px; line-height:1.65;
  color:var(--text); background:var(--light);
  overflow-x:hidden;
}
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
input,textarea,select { font-family:inherit; font-size:1rem; }

.container { width:100%; max-width:1200px; margin:0 auto; padding:0 24px; }

/* ─── Typography ─── */
h1,h2,h3,h4 { font-family:'Poppins',sans-serif; line-height:1.25; font-weight:700; }
h1 { font-size:clamp(2.2rem,5vw,3.8rem); }
h2 { font-size:clamp(1.8rem,3.5vw,2.8rem); }
h3 { font-size:1.25rem; }

.text-gradient {
  background:linear-gradient(135deg,#4F7F6F,#7FAF9B);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.text-gradient-orange {
  background:linear-gradient(135deg,#4F7F6F,#7FAF9B);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.text-white { color:#fff !important; }
.text-muted-light { color:rgba(255,255,255,.65) !important; }

/* ─── Buttons ─── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:50px;
  font-family:'Poppins',sans-serif; font-weight:600; font-size:.95rem;
  transition:var(--transition); cursor:pointer;
  border:2px solid transparent; white-space:nowrap;
}
.btn-primary {
  background:linear-gradient(135deg,#4F7F6F,#3A6357);
  color:#fff; box-shadow:0 6px 24px rgba(79,127,111,.3);
}
.btn-primary:hover {
  transform:translateY(-2px);
  box-shadow:0 10px 32px rgba(79,127,111,.4);
}
.btn-secondary {
  background:transparent; color:var(--primary); border-color:var(--primary);
}
.btn-secondary:hover { background:var(--primary); color:#fff; }
.btn-ghost {
  background:rgba(255,255,255,.12); color:#fff;
  border-color:rgba(255,255,255,.3); backdrop-filter:blur(8px);
}
.btn-ghost:hover { background:rgba(255,255,255,.2); }
.btn-nav-cta {
  background:var(--primary); color:#fff;
  font-size:.88rem; padding:9px 20px;
}
.btn-nav-cta:hover { background:var(--primary-dark); transform:translateY(-1px); }
.btn-plan {
  width:100%; justify-content:center;
  background:transparent; color:var(--primary); border-color:var(--primary);
}
.btn-plan:hover { background:var(--primary); color:#fff; }
.btn-lg { padding:15px 32px; font-size:1rem; }
.btn-whatsapp {
  background:#25D366; color:#fff;
  box-shadow:0 6px 24px rgba(37,211,102,.3);
  font-size:1rem; padding:14px 28px;
}
.btn-whatsapp:hover { background:#1EBE5A; transform:translateY(-2px); }
.play-btn {
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
}
.w-full { width:100%; justify-content:center; }

/* ─── Section Common ─── */
.section { padding:96px 0; }
.bg-dark { background:var(--primary-dark); }
.bg-light { background:var(--light); }
.section-header { text-align:center; margin-bottom:56px; }
.section-header-dark { margin-bottom:56px; text-align:center; }
.section-tag {
  display:inline-block;
  background:rgba(79,127,111,.1); color:var(--primary);
  border:1px solid rgba(79,127,111,.25);
  padding:5px 14px; border-radius:50px;
  font-size:.8rem; font-weight:600; letter-spacing:.04em;
  text-transform:uppercase; margin-bottom:14px;
}
.section-tag-light {
  background:rgba(255,255,255,.12); color:rgba(255,255,255,.85);
  border-color:rgba(255,255,255,.2);
}
.section-heading { margin-bottom:14px; }
.section-sub { color:var(--text-muted); font-size:1.05rem; max-width:540px; margin:0 auto; }

/* ─── AOS Animations ─── */
[data-aos] { opacity:0; transition:opacity .6s ease, transform .6s ease; }
[data-aos="fade-up"] { transform:translateY(30px); }
[data-aos="fade-right"] { transform:translateX(-30px); }
[data-aos="fade-left"] { transform:translateX(30px); }
[data-aos="zoom-in"] { transform:scale(.9); }
[data-aos].aos-animate { opacity:1; transform:none; }

/* ══════════════════════════════
   NAVBAR
══════════════════════════════ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  transition:background .3s,box-shadow .3s; padding:10px 0;
}
.navbar.scrolled {
  background:rgba(29,61,51,.97);
  backdrop-filter:blur(16px);
  box-shadow:0 2px 20px rgba(0,0,0,.15);
  padding:12px 0;
}
.nav-container { display:flex; align-items:center; justify-content:space-between; }
.nav-brand { display:flex; align-items:center; gap:12px; }
.brand-icon {
  width:200px; height:auto;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.brand-icon img { width:200px; height:auto; object-fit:contain; }
.brand-icon::after { display:none; }
.brand-icon-sm { width:200px; height:auto; }
.brand-icon-sm img { width:200px; height:auto; object-fit:contain; border-radius:10px; }
.brand-icon-inner { display:none; }
.brand-text { font-family:'Poppins',sans-serif; font-size:1.15rem; color:#fff; font-weight:500; letter-spacing:-.01em; }
.brand-text strong { font-weight:800; }
.nav-links { display:flex; align-items:center; gap:28px; }
.mobile-menu-logo { display:none; }
.nav-link { color:rgba(255,255,255,.8); font-size:.9rem; font-weight:500; transition:color var(--transition); }
.nav-link:hover { color:#fff; }
.hamburger { display:none; flex-direction:column; gap:5px; padding:6px; background:none; border:none; }
.hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; transition:var(--transition); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ══════════════════════════════
   HERO
══════════════════════════════ */
.hero {
  position:relative; min-height:100vh;
  background:linear-gradient(135deg,#1E3D33 0%,#2D5048 55%,#1A3328 100%);
  display:flex; align-items:center;
  padding:120px 0 80px;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.hero-orb { position:absolute; border-radius:50%; filter:blur(80px); opacity:.22; }
.orb-1 {
  width:600px; height:600px; top:-100px; right:-100px;
  background:radial-gradient(circle,#7FAF9B,transparent);
  animation:floatOrb 8s ease-in-out infinite;
}
.orb-2 {
  width:400px; height:400px; bottom:0; left:-100px;
  background:radial-gradient(circle,#A8C5B8,transparent);
  animation:floatOrb 10s ease-in-out infinite reverse;
}
.orb-3 {
  width:300px; height:300px; top:40%; left:40%;
  background:radial-gradient(circle,#5C9E84,transparent);
  animation:floatOrb 12s ease-in-out infinite 2s;
}
.hero-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:60px 60px;
}
@keyframes floatOrb {
  0%,100% { transform:translateY(0) scale(1); }
  50% { transform:translateY(-30px) scale(1.05); }
}
.hero-container { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:stretch; position:relative; z-index:1; }
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(127,175,155,.18); color:#A8C5B8;
  border:1px solid rgba(127,175,155,.3);
  padding:7px 16px; border-radius:50px;
  font-size:.82rem; font-weight:600; letter-spacing:.03em;
  text-transform:uppercase; margin-bottom:24px;
}
.badge-pulse {
  width:8px; height:8px; border-radius:50%;
  background:#7FAF9B; box-shadow:0 0 0 3px rgba(127,175,155,.3);
  animation:pulse 2s infinite;
}
@keyframes pulse {
  0%,100% { box-shadow:0 0 0 3px rgba(127,175,155,.3); }
  50% { box-shadow:0 0 0 7px rgba(127,175,155,0); }
}
.hero-heading { color:#fff; margin-bottom:20px; font-weight:800; }
.hero-subtext { color:rgba(255,255,255,.75); font-size:1.1rem; max-width:520px; margin-bottom:36px; }
.hero-ctas { display:flex; gap:16px; flex-wrap:nowrap; align-items:center; margin-bottom:44px; }
.hero-stats {
  display:flex; gap:0; align-items:center; width:100%;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
  border-radius:14px; padding:16px 24px; backdrop-filter:blur(10px);
}
.stat-item { text-align:center; padding:0 20px; }
.stat-number { display:block; font-family:'Poppins',sans-serif; font-size:1.6rem; font-weight:800; color:#fff; }
.stat-label { font-size:.75rem; color:rgba(255,255,255,.5); font-weight:500; }
.stat-divider { width:1px; height:40px; background:rgba(255,255,255,.15); flex-shrink:0; }

/* Hero Visual */
.hero-visual { display:flex; flex-direction:column; gap:0; padding:20px 30px 20px 30px; }
.phone-wrap { position:relative; flex:1; padding:20px 20px 40px 20px; min-height:0; }
.mock-phone {
  background:rgba(255,255,255,.07); backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.15); border-radius:var(--radius-xl);
  padding:24px; position:relative; z-index:2; box-shadow:var(--shadow-xl);
  height:100%; box-sizing:border-box;
}
.mock-header { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.mock-avatar {
  width:40px; height:40px; border-radius:50%;
  background:linear-gradient(135deg,#7FAF9B,#4F7F6F); flex-shrink:0;
}
.mock-name { color:#fff; font-weight:600; font-size:.9rem; }
.mock-sub { color:rgba(255,255,255,.5); font-size:.78rem; }
.mock-badge-live {
  margin-left:auto; background:var(--green-ok); color:#fff;
  font-size:.72rem; font-weight:700; padding:3px 9px;
  border-radius:50px; letter-spacing:.04em;
}
.mock-mission-title { color:#fff; font-family:'Poppins',sans-serif; font-size:1.05rem; font-weight:700; margin-bottom:10px; }
.mock-role-chip {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(127,175,155,.2); color:#A8C5B8;
  font-size:.8rem; font-weight:600; padding:4px 12px;
  border-radius:50px; margin-bottom:16px;
}
.mock-steps { display:flex; flex-direction:column; gap:10px; margin-bottom:16px; }
.mock-step { display:flex; align-items:center; gap:10px; font-size:.88rem; color:rgba(255,255,255,.6); }
.mock-step.done { color:var(--green-ok); }
.mock-step.active { color:#fff; font-weight:600; }
.step-icon { width:20px; height:20px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.step-icon.check { background:var(--green-ok); animation:checkPop .4s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes checkPop {
  0%   { transform:scale(0) rotate(-15deg); opacity:0; }
  60%  { transform:scale(1.25) rotate(4deg); }
  100% { transform:scale(1) rotate(0); opacity:1; }
}
.step-icon.check::after {
  content:''; display:block; width:6px; height:10px;
  border:2px solid #fff; border-top:none; border-left:none;
  transform:rotate(45deg) translateY(-1px);
  animation:tickDraw .3s .1s ease both;
}
@keyframes tickDraw {
  from { opacity:0; transform:rotate(45deg) translateY(-1px) scale(.5); }
  to   { opacity:1; transform:rotate(45deg) translateY(-1px) scale(1); }
}
.step-icon.ring-active {
  border:2px solid #7FAF9B;
  box-shadow:0 0 0 3px rgba(127,175,155,.25);
  animation:pulse 1.5s infinite;
}
.step-icon.ring { border:2px solid rgba(255,255,255,.3); }
.mock-progress-wrap { margin-bottom:14px; }
.mock-progress-label { display:flex; justify-content:space-between; font-size:.78rem; color:rgba(255,255,255,.6); margin-bottom:6px; }
.mock-progress-bar { height:6px; border-radius:3px; background:rgba(255,255,255,.1); }
.mock-progress-fill { height:100%; border-radius:3px; background:linear-gradient(90deg,#4F7F6F,#7FAF9B); transition:width .7s cubic-bezier(.4,0,.2,1); }
.mock-skills-row { display:flex; gap:6px; flex-wrap:wrap; }
.mock-skill-tag { background:rgba(127,175,155,.18); color:#A8C5B8; font-size:.75rem; font-weight:600; padding:3px 10px; border-radius:50px; }

/* Float Cards */
.float-card {
  position:absolute;
  background:rgba(255,255,255,.09); backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.15); border-radius:var(--radius-md);
  padding:12px 16px; display:flex; align-items:center; gap:10px;
  box-shadow:var(--shadow-lg);
}
.float-parent { bottom:16px; left:-10px; min-width:220px; z-index:3; }
.float-change { top:16px; right:-10px; min-width:180px; z-index:3; }
.float-icon { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.star-icon { background:rgba(255,215,0,.15); }
.up-icon { background:rgba(68,207,108,.15); }
.float-card-title { color:#fff; font-size:.82rem; font-weight:600; }
.float-card-sub { color:rgba(255,255,255,.5); font-size:.74rem; }
.float-card-metric { color:var(--green-ok); font-size:1rem; font-weight:800; }
.float-card-metric span { color:rgba(255,255,255,.5); font-size:.78rem; font-weight:400; }

.hero-wave { position:absolute; bottom:-1px; left:0; right:0; }
.hero-wave svg { width:100%; height:auto; display:block; }

/* ══════════════════════════════
   PROBLEMS
══════════════════════════════ */
.problems-section { background:var(--light); }
.problems-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:40px; }
.problem-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius-md); padding:24px;
  position:relative; transition:var(--transition); box-shadow:var(--shadow-sm);
}
.problem-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:rgba(79,127,111,.3); }
.problem-num { display:block; font-family:'Poppins',sans-serif; font-size:1.8rem; font-weight:900; color:#4F7F6F; margin-bottom:10px; }
.problem-card p { font-size:.92rem; color:var(--text-muted); line-height:1.6; }
.problems-solution-banner {
  background:linear-gradient(135deg,#fff,var(--beige-warm));
  border:1px solid rgba(79,127,111,.2);
  border-left:4px solid var(--primary);
  border-radius:var(--radius-md); overflow:hidden;
}
.solution-banner-inner { display:flex; align-items:center; gap:20px; padding:24px 28px; }
.solution-icon {
  width:56px; height:56px; border-radius:var(--radius-sm);
  background:rgba(79,127,111,.1);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.solution-label { font-size:.78rem; font-weight:700; color:var(--primary); text-transform:uppercase; letter-spacing:.06em; margin-bottom:4px; }
.solution-text { color:var(--text); font-size:.95rem; }

/* ══════════════════════════════
   ABOUT
══════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.about-lead { font-size:1.1rem; color:var(--text); margin-bottom:16px; font-weight:400; }
.about-body { color:var(--text-muted); margin-bottom:28px; }
.about-beliefs { margin-bottom:32px; }
.belief-item { padding:12px 0 12px 20px; border-left:3px solid var(--sage); margin-bottom:10px; }
.belief-quote { font-style:italic; color:var(--text-muted); font-size:.95rem; }
.about-card-wrap { position:relative; }
.about-main-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); overflow:hidden; }
.about-card-header { background:var(--primary); padding:18px 24px; }
.about-card-title { color:#fff; font-family:'Poppins',sans-serif; font-size:.95rem; font-weight:600; }
.compare-table { padding:8px 0; }
.compare-row { display:grid; grid-template-columns:1fr 1fr 1fr; padding:10px 24px; font-size:.88rem; border-bottom:1px solid var(--border); align-items:center; }
.compare-row:last-child { border-bottom:none; }
.compare-row.header-row { background:var(--light); font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); }
.col-other { text-align:center; color:var(--text-muted); }
.col-us { text-align:center; font-weight:600; }
.bad { color:#EF4444; }
.good { color:#44A870; }
.about-floating-tag {
  position:absolute; bottom:-14px; left:24px;
  background:#fff; border:1px solid var(--border); border-radius:50px; padding:8px 16px;
  font-size:.82rem; font-weight:600; color:var(--text); box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:6px;
}
.tag-2 { bottom:auto; top:-14px; right:24px; left:auto; }

/* ══════════════════════════════
   HOW IT WORKS
══════════════════════════════ */
.hiw-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.hiw-step { display:flex; flex-direction:column; }
.step-num-wrap { display:flex; align-items:center; margin-bottom:20px; padding:0 16px; }
.step-num { font-family:'Poppins',sans-serif; font-size:2.8rem; font-weight:900; color:rgba(255,255,255,.85); flex-shrink:0; text-shadow:0 0 20px rgba(127,175,155,.6); }
.step-line { flex:1; height:2px; background:linear-gradient(90deg,rgba(255,255,255,.7),rgba(255,255,255,.08)); margin-left:10px; box-shadow:0 0 8px rgba(127,175,155,.4); }
.step-card {
  background:rgba(255,255,255,.06); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-lg);
  padding:24px; margin:0 8px; flex:1; transition:var(--transition);
}
.step-card:hover { background:rgba(255,255,255,.1); border-color:rgba(127,175,155,.4); transform:translateY(-4px); }
.step-card-highlight { border-color:rgba(127,175,155,.45); background:rgba(127,175,155,.08); }
.step-card-header { display:flex; align-items:flex-start; gap:14px; margin-bottom:14px; }
.step-icon-wrap { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:#fff; }
.step-icon-orange { background:rgba(127,175,155,.25); }
.step-icon-teal   { background:rgba(168,197,184,.2); }
.step-icon-green  { background:rgba(68,207,108,.2); }
.step-title { font-family:'Poppins',sans-serif; font-size:1.05rem; font-weight:800; color:#fff; letter-spacing:.05em; }
.step-subtitle { font-size:.8rem; color:rgba(255,255,255,.5); }
.step-description { font-size:.9rem; color:rgba(255,255,255,.72); margin-bottom:14px; line-height:1.65; }
.step-note { display:flex; align-items:flex-start; gap:6px; background:rgba(127,175,155,.12); border-radius:var(--radius-sm); padding:8px 12px; font-size:.8rem; color:rgba(255,255,255,.6); }
.parent-note {
  display:flex; align-items:flex-start; gap:14px;
  background:rgba(127,175,155,.1); border:1px solid rgba(127,175,155,.25);
  border-radius:var(--radius-md); padding:20px 24px;
  margin-top:36px; color:rgba(255,255,255,.8); font-size:.92rem; flex-shrink:0;
}
.parent-note svg { flex-shrink:0; margin-top:2px; }

/* ══════════════════════════════
   SKILLS
══════════════════════════════ */
.skills-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:48px; }
/* Skill icon keyframes */
@keyframes skillFloat  { 0%,100%{transform:translateY(0)}    50%{transform:translateY(-5px)} }
@keyframes skillSpin   { 0%{transform:rotate(0)}             100%{transform:rotate(360deg)} }
@keyframes skillPulse  { 0%,100%{transform:scale(1)}         50%{transform:scale(1.2)} }
@keyframes skillBounce { 0%,100%{transform:translateY(0) scale(1)} 40%{transform:translateY(-7px) scale(1.12)} 70%{transform:translateY(-2px) scale(1.04)} }
@keyframes skillWobble { 0%,100%{transform:rotate(0)}   25%{transform:rotate(-12deg)} 75%{transform:rotate(12deg)} }
@keyframes skillShake  { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)} }

.skill-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  transition:var(--transition); box-shadow:var(--shadow-sm);
}
.skill-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:rgba(79,127,111,.3); }
.skill-icon-wrap {
  width:56px; height:56px; border-radius:var(--radius-sm);
  background:rgba(79,127,111,.08); border:1px solid rgba(79,127,111,.15);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px;
  transition:background .3s, box-shadow .3s, transform .3s;
}
.skill-icon-wrap svg { transition:transform .3s; }

/* Idle float — staggered per card */
.skill-card:nth-child(1) .skill-icon-wrap { animation:skillFloat 3s ease-in-out infinite; }
.skill-card:nth-child(2) .skill-icon-wrap { animation:skillFloat 3s ease-in-out infinite .4s; }
.skill-card:nth-child(3) .skill-icon-wrap { animation:skillFloat 3s ease-in-out infinite .8s; }
.skill-card:nth-child(4) .skill-icon-wrap { animation:skillFloat 3s ease-in-out infinite 1.2s; }
.skill-card:nth-child(5) .skill-icon-wrap { animation:skillFloat 3s ease-in-out infinite 1.6s; }
.skill-card:nth-child(6) .skill-icon-wrap { animation:skillFloat 3s ease-in-out infinite 2s; }

/* Hover — unique animation per icon */
.skill-card:nth-child(1):hover .skill-icon-wrap svg { animation:skillSpin   .6s ease forwards; }
.skill-card:nth-child(2):hover .skill-icon-wrap svg { animation:skillPulse  .5s ease infinite; }
.skill-card:nth-child(3):hover .skill-icon-wrap svg { animation:skillBounce .6s ease forwards; }
.skill-card:nth-child(4):hover .skill-icon-wrap svg { animation:skillWobble .5s ease forwards; }
.skill-card:nth-child(5):hover .skill-icon-wrap svg { animation:skillSpin   .8s linear forwards; }
.skill-card:nth-child(6):hover .skill-icon-wrap svg { animation:skillShake  .4s ease infinite; }

/* Glow on hover */
.skill-card:hover .skill-icon-wrap {
  background:rgba(79,127,111,.18);
  box-shadow:0 0 22px rgba(79,127,111,.25);
  transform:scale(1.1);
  animation:none;
}
.skill-title { font-size:1.05rem; font-weight:700; margin-bottom:16px; color:var(--primary); }
.skill-perspective { display:flex; flex-direction:column; gap:10px; }
.perspective-item { background:var(--light); border-radius:var(--radius-sm); padding:12px; }
.perspective-label { display:block; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; margin-bottom:4px; }
.perspective-label.parent { color:var(--primary); }
.perspective-label.child  { color:var(--sage); }
.perspective-item p { font-size:.85rem; color:var(--text-muted); line-height:1.55; }
.outcomes-banner { background:linear-gradient(135deg,var(--primary),var(--primary-dark)); border-radius:var(--radius-xl); padding:40px 48px; color:#fff; }
.outcomes-banner h3 { font-size:1.3rem; margin-bottom:24px; color:#fff; }
.outcomes-list { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.outcome-item { display:flex; align-items:center; gap:8px; font-size:.9rem; color:rgba(255,255,255,.85); }

/* ══════════════════════════════
   PRINCIPLE
══════════════════════════════ */
.principle-section { background:linear-gradient(135deg,var(--light),var(--beige-warm)); }
.principle-wrap { max-width:800px; margin:0 auto; text-align:center; }
.principle-header { margin-bottom:56px; }
.principle-timeline { display:flex; align-items:center; justify-content:center; gap:0; margin-bottom:48px; flex-wrap:wrap; }
.timeline-item { text-align:center; flex:1; min-width:120px; }
.timeline-dot { width:20px; height:20px; border-radius:50%; margin:0 auto 12px; }
.dot-1 { background:rgba(79,127,111,.3); border:3px solid var(--primary); }
.dot-2 { background:rgba(127,175,155,.4); border:3px solid var(--sage); }
.dot-3 { background:rgba(168,197,184,.4); border:3px solid var(--sage-light); }
.dot-4 { background:var(--primary-dark); border:3px solid var(--primary-dark); }
.timeline-connector { flex:1; height:2px; max-width:80px; background:linear-gradient(90deg,var(--primary),var(--sage)); }
.timeline-days { display:block; font-family:'Poppins',sans-serif; font-size:1.1rem; font-weight:800; color:var(--primary); margin-bottom:4px; }
.timeline-content p { font-size:.85rem; color:var(--text-muted); }
.principle-quote { background:#fff; border-radius:var(--radius-lg); padding:32px 40px; box-shadow:var(--shadow-md); text-align:left; position:relative; }
.principle-quote p { font-size:1.1rem; color:var(--text); line-height:1.7; font-style:italic; }

/* ══════════════════════════════
   PRICING
══════════════════════════════ */
.pricing-section {
  background:linear-gradient(135deg,#1A3328 0%,#243D32 40%,#1E3D33 70%,#162C24 100%);
  position:relative; overflow:hidden;
}
.pricing-section::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(127,175,155,.12),transparent),
             radial-gradient(ellipse 50% 50% at 10% 80%,rgba(79,127,111,.1),transparent);
}
/* Section header overrides for dark bg */
.pricing-section .section-tag { color:rgba(255,255,255,.55); border-color:rgba(255,255,255,.15); background:rgba(255,255,255,.07); }
.pricing-section .section-heading { color:#fff; }
.pricing-section .section-sub { color:rgba(255,255,255,.55); }
/* ══════════════════════════════
   PRICING
══════════════════════════════ */
/* ── Glassmorphism grid ── */
.pricing-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px; margin-bottom:40px; align-items:stretch;
  background:none; border:none; box-shadow:none; overflow:visible;
}

/* Glass card */
.pricing-card {
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px; padding:30px 24px 26px;
  position:relative; transition:var(--transition);
  display:flex; flex-direction:column;
  box-shadow:0 8px 32px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.12);
}
.pricing-card:hover {
  background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.25);
  transform:translateY(-8px);
  box-shadow:0 20px 48px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.18);
}

/* Popular — brighter glass */
.pricing-card-popular {
  background:rgba(255,255,255,.14);
  border:1px solid rgba(168,197,184,.5);
  box-shadow:0 8px 40px rgba(0,0,0,.25), 0 0 0 1px rgba(127,175,155,.2), inset 0 1px 0 rgba(255,255,255,.2);
}
.pricing-card-popular:hover {
  background:rgba(255,255,255,.19); border-color:rgba(168,197,184,.7);
  transform:translateY(-8px);
  box-shadow:0 24px 60px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.25);
}

/* Badges */
.popular-badge,.best-value-badge {
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  padding:5px 18px; border-radius:50px;
  font-size:.74rem; font-weight:700; white-space:nowrap; letter-spacing:.04em;
  display:flex; align-items:center; gap:5px;
}
.popular-badge    { background:linear-gradient(135deg,#FF6B35,#e8521a); color:#fff; box-shadow:0 4px 14px rgba(255,107,53,.5); }
.best-value-badge { background:rgba(255,255,255,.15); color:#fff; border:1px solid rgba(255,255,255,.3); backdrop-filter:blur(8px); }

/* Plan icon */
.plan-icon-wrap {
  width:48px; height:48px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px; transition:.25s;
  background:rgba(255,255,255,.1); color:rgba(255,255,255,.8);
}
.plan-icon-blue,.plan-icon-teal,.plan-icon-orange,.plan-icon-green { background:rgba(255,255,255,.1); color:rgba(255,255,255,.8); }
.pricing-card:hover .plan-icon-wrap { transform:scale(1.1); background:rgba(255,255,255,.16); }

/* Savings chips */
.plan-savings-chip { display:inline-block; padding:3px 12px; border-radius:50px; font-size:.73rem; font-weight:700; background:rgba(255,107,53,.2); color:#FF6B35; margin-bottom:8px; border:1px solid rgba(255,107,53,.25); }
.savings-chip-orange { background:rgba(168,197,184,.2); color:#A8C5B8; border-color:rgba(168,197,184,.25); }
.savings-chip-green  { background:rgba(68,207,108,.2);  color:#7FEBA0; border-color:rgba(68,207,108,.25); }

/* Card header */
.pricing-card-header { margin-bottom:10px; }
.plan-name  { font-size:1.1rem; font-weight:800; margin-bottom:3px; color:#fff; }
.plan-desc  { font-size:.8rem; color:rgba(255,255,255,.5); }

/* Price */
.plan-price-wrap { display:flex; align-items:baseline; gap:3px; margin:12px 0 4px; }
.plan-price  { font-family:'Poppins',sans-serif; font-size:2.8rem; font-weight:900; color:#fff; line-height:1; }
.plan-period { font-size:.84rem; color:rgba(255,255,255,.45); }
.plan-total  { font-size:.77rem; color:rgba(255,255,255,.4); margin-bottom:4px; }
.popular-price { color:#fff; }
.plan-savings  { display:none; }
.savings-big   { display:none; }

/* Divider */
.plan-divider { height:1px; background:rgba(255,255,255,.1); margin:16px 0; }
.popular-divider { background:rgba(255,255,255,.15); }

/* Features */
.plan-features { margin-bottom:22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.plan-features li { display:flex; align-items:center; gap:9px; font-size:.85rem; color:rgba(255,255,255,.75); }
.pricing-card .btn { margin-top:auto; }

/* Feature checks */
.feat-check {
  width:17px; height:17px; border-radius:50%; flex-shrink:0;
  background:rgba(68,207,108,.25); border:1px solid rgba(68,207,108,.4);
  display:inline-flex; align-items:center; justify-content:center;
}
.feat-check::after { content:''; display:block; width:4px; height:7px; border:1.5px solid #7FEBA0; border-top:none; border-left:none; transform:rotate(45deg) translateY(-1px); }
.feat-check-orange { background:rgba(168,197,184,.2); border-color:rgba(168,197,184,.35); }
.feat-check-orange::after { border-color:#A8C5B8; }

/* Enroll buttons */
.btn-enroll-outline {
  display:flex; align-items:center; justify-content:center; gap:7px;
  width:100%; padding:12px 20px; border-radius:10px;
  border:1px solid rgba(255,255,255,.25); color:#fff;
  font-family:'Poppins',sans-serif; font-weight:700; font-size:.88rem;
  transition:var(--transition); cursor:pointer; margin-top:auto; text-decoration:none;
  background:rgba(255,255,255,.08); backdrop-filter:blur(8px);
}
.btn-enroll-outline:hover {
  background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.4);
  transform:translateY(-1px); box-shadow:0 6px 20px rgba(0,0,0,.2);
}
.btn-enroll-primary {
  display:flex; align-items:center; justify-content:center; gap:7px;
  width:100%; padding:13px 20px; border-radius:10px;
  background:linear-gradient(135deg,#FF6B35,#e8521a); color:#fff; border:none;
  font-family:'Poppins',sans-serif; font-weight:700; font-size:.9rem;
  transition:var(--transition); cursor:pointer; margin-top:auto; text-decoration:none;
  box-shadow:0 4px 18px rgba(68,207,108,.4);
}
.btn-enroll-primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(255,107,53,.55); }
.popular-note { text-align:center; font-size:.73rem; color:rgba(255,255,255,.4); font-weight:500; margin-top:10px; }

/* School pricing */
.school-pricing { background:linear-gradient(135deg,var(--light),var(--beige-warm)); border:1px solid var(--border); border-radius:var(--radius-xl); padding:36px; margin-bottom:32px; }
.school-pricing-inner { display:flex; align-items:center; gap:28px; flex-wrap:wrap; }
.school-icon { width:64px; height:64px; border-radius:var(--radius-md); background:rgba(79,127,111,.1); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.school-pricing h3 { font-size:1.15rem; color:var(--primary); margin-bottom:6px; }
.school-pricing p { font-size:.9rem; color:var(--text-muted); margin-bottom:16px; }
.school-options { display:flex; flex-direction:column; gap:8px; }
.school-option { display:flex; align-items:center; gap:16px; font-size:.88rem; }
.school-range { color:var(--text-muted); min-width:180px; }
.school-price { font-weight:700; color:var(--primary); }
.school-contact-btn { margin-left:auto; flex-shrink:0; }

/* Guarantee */
.guarantee-banner {
  background:rgba(255,255,255,.07); backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.15); border-radius:var(--radius-xl); padding:32px 40px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
}
.guarantee-inner { display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.guarantee-icon { flex-shrink:0; }
.guarantee-banner h3 { font-size:1.2rem; color:#fff; margin-bottom:6px; }
.guarantee-banner p { color:rgba(255,255,255,.6); font-size:.95rem; }

/* ══════════════════════════════
   FAQ
══════════════════════════════ */
.faq-list { max-width:760px; margin:0 auto; }
.faq-item { border:1px solid var(--border); border-radius:var(--radius-md); margin-bottom:12px; overflow:hidden; background:#fff; box-shadow:var(--shadow-sm); }
.faq-question { width:100%; display:flex; justify-content:space-between; align-items:center; padding:20px 24px; font-size:.97rem; font-weight:600; color:var(--text); text-align:left; gap:12px; transition:var(--transition); }
.faq-question:hover { color:var(--primary); }
.faq-question.open { color:var(--primary); }
.faq-chevron { flex-shrink:0; transition:transform .3s ease; }
.faq-question.open .faq-chevron { transform:rotate(180deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height .4s ease, padding .3s ease; padding:0 24px; }
.faq-answer.open { max-height:300px; padding:0 24px 20px; }
.faq-answer p { color:var(--text-muted); font-size:.93rem; line-height:1.7; }

/* ══════════════════════════════
   CONTACT
══════════════════════════════ */
.contact-section { background:linear-gradient(135deg,var(--primary-deep),var(--primary-dark)); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.contact-info .section-tag { background:rgba(255,255,255,.1); color:rgba(255,255,255,.8); border-color:rgba(255,255,255,.2); }
.contact-info .section-heading { color:#fff; }
.contact-info .section-heading .text-gradient { background:none; -webkit-text-fill-color:#fff; color:#fff; }
.contact-info > p { color:rgba(255,255,255,.7); margin-bottom:32px; font-size:1rem; }
.contact-features { display:flex; flex-direction:column; gap:12px; margin-bottom:32px; }
.contact-feature { display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.8); font-size:.93rem; }
.closing-quote { margin-top:24px; font-style:italic; color:rgba(255,255,255,.5); font-size:.88rem; border-left:3px solid rgba(127,175,155,.4); padding-left:14px; line-height:1.65; }
.contact-form-card { background:#fff; border-radius:var(--radius-xl); padding:36px; box-shadow:var(--shadow-xl); }
.contact-form-card h3 { font-size:1.2rem; color:var(--primary); margin-bottom:24px; font-family:'Poppins',sans-serif; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:.85rem; font-weight:600; color:var(--text); margin-bottom:6px; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:11px 16px; border:2px solid var(--border);
  border-radius:var(--radius-sm); font-size:.95rem; color:var(--text);
  transition:border-color var(--transition); outline:none; background:#fff;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus {
  border-color:var(--primary); box-shadow:0 0 0 3px rgba(79,127,111,.1);
}
.form-group textarea { resize:vertical; min-height:80px; }
.form-success { text-align:center; padding:32px; display:flex; flex-direction:column; align-items:center; gap:14px; }
.form-success p { color:var(--text); font-weight:600; font-size:1rem; }

/* ══════════════════════════════
   FOOTER
══════════════════════════════ */
.footer { background:#0B2119; padding:64px 0 0; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer-brand p { color:rgba(255,255,255,.4); font-size:.88rem; margin:12px 0 18px; }
.footer-wa { display:inline-flex; align-items:center; gap:8px; background:#25D366; color:#fff; padding:8px 18px; border-radius:50px; font-size:.85rem; font-weight:600; transition:var(--transition); }
.footer-wa:hover { background:#1EBE5A; transform:translateY(-2px); }
.footer-links h4 { color:#fff; font-size:.9rem; margin-bottom:16px; cursor:pointer; display:flex; align-items:center; justify-content:space-between; }
.footer-links h4::after { content:''; display:none; }
.footer-links li { margin-bottom:10px; }
.footer-links a { color:rgba(255,255,255,.45); font-size:.88rem; transition:color var(--transition); }
.footer-links a:hover { color:#fff; }
.footer-contact h4 { color:#fff; font-size:.9rem; margin-bottom:16px; }
.footer-contact p { color:rgba(255,255,255,.45); font-size:.88rem; margin-bottom:8px; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:20px 0; flex-wrap:wrap; gap:12px; }
.footer-bottom p { color:rgba(255,255,255,.3); font-size:.82rem; }

/* ══════════════════════════════
   WHATSAPP FLOAT
══════════════════════════════ */
.wa-float {
  position:fixed; bottom:28px; left:28px; z-index:900;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,.45); transition:var(--transition);
}
.wa-float:hover { transform:scale(1.1); box-shadow:0 10px 36px rgba(37,211,102,.55); }
.wa-pulse { position:absolute; width:100%; height:100%; border-radius:50%; background:#25D366; animation:waPulse 2.5s infinite; }
@keyframes waPulse {
  0% { transform:scale(1); opacity:.7; }
  70% { transform:scale(1.5); opacity:0; }
  100% { transform:scale(1.5); opacity:0; }
}
.wa-tooltip { position:absolute; left:calc(100% + 12px); background:#333; color:#fff; font-size:.8rem; font-weight:600; padding:5px 12px; border-radius:6px; white-space:nowrap; opacity:0; transition:opacity .2s; pointer-events:none; }
.wa-float:hover .wa-tooltip { opacity:1; }

/* ══════════════════════════════
   CHATBOT
══════════════════════════════ */
.chatbot-wrap { position:fixed; bottom:28px; right:28px; z-index:900; }
.chatbot-toggle {
  width:58px; height:58px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(79,127,111,.4); transition:var(--transition); position:relative;
}
.chatbot-toggle:hover { transform:scale(1.08); box-shadow:0 10px 36px rgba(79,127,111,.5); }
.chatbot-badge {
  position:absolute; top:-4px; right:-4px;
  width:20px; height:20px; border-radius:50%;
  background:var(--primary-dark); color:#fff;
  font-size:.72rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; border:2px solid #fff;
}
.chatbot-panel {
  position:absolute; bottom:72px; right:0;
  width:340px; max-height:520px;
  background:#fff; border-radius:var(--radius-xl); box-shadow:var(--shadow-xl);
  display:flex; flex-direction:column; overflow:hidden;
  transform:scale(.9) translateY(20px); opacity:0; pointer-events:none;
  transition:transform .3s cubic-bezier(.4,0,.2,1), opacity .3s ease;
  transform-origin:bottom right;
}
.chatbot-panel.open { transform:scale(1) translateY(0); opacity:1; pointer-events:all; }
.chatbot-header { background:linear-gradient(135deg,var(--primary),var(--primary-dark)); padding:16px 18px; display:flex; align-items:center; gap:12px; }
.chatbot-avatar { width:36px; height:36px; border-radius:50%; background:var(--sage); color:#fff; display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:800; flex-shrink:0; }
.chatbot-name { color:#fff; font-weight:700; font-size:.9rem; }
.chatbot-status { display:flex; align-items:center; gap:5px; color:rgba(255,255,255,.6); font-size:.75rem; }
.online-dot { width:7px; height:7px; border-radius:50%; background:var(--green-ok); flex-shrink:0; box-shadow:0 0 0 2px rgba(68,207,108,.3); }
.chatbot-close-btn { margin-left:auto; color:rgba(255,255,255,.7); padding:4px; border-radius:6px; transition:var(--transition); }
.chatbot-close-btn:hover { color:#fff; background:rgba(255,255,255,.1); }
.chatbot-messages { flex:1; padding:16px; overflow-y:auto; display:flex; flex-direction:column; gap:12px; max-height:280px; scrollbar-width:thin; scrollbar-color:var(--border) transparent; }
.chatbot-messages::-webkit-scrollbar { width:4px; }
.chatbot-messages::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
.msg-bot,.msg-user { max-width:88%; padding:10px 14px; border-radius:14px; font-size:.88rem; line-height:1.55; animation:msgIn .25s ease; }
@keyframes msgIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }
.msg-bot { background:var(--light); color:var(--text); border-radius:4px 14px 14px 14px; align-self:flex-start; }
.msg-user { background:linear-gradient(135deg,var(--primary),var(--primary-dark)); color:#fff; border-radius:14px 4px 14px 14px; align-self:flex-end; }
.msg-typing { display:flex; gap:4px; align-items:center; padding:12px 16px; }
.msg-typing span { width:7px; height:7px; border-radius:50%; background:var(--text-muted); animation:typingDot 1.2s infinite; }
.msg-typing span:nth-child(2) { animation-delay:.2s; }
.msg-typing span:nth-child(3) { animation-delay:.4s; }
@keyframes typingDot { 0%,60%,100% { transform:translateY(0); } 30% { transform:translateY(-6px); } }
.chatbot-quick-replies { padding:8px 14px; display:flex; flex-wrap:wrap; gap:6px; border-top:1px solid var(--border); }
.qr-btn { background:transparent; border:1px solid var(--primary); color:var(--primary); font-size:.78rem; font-weight:600; padding:5px 12px; border-radius:50px; transition:var(--transition); cursor:pointer; }
.qr-btn:hover { background:var(--primary); color:#fff; }
.chatbot-input-wrap { display:flex; gap:8px; padding:12px 14px; border-top:1px solid var(--border); }
.chatbot-input { flex:1; padding:9px 14px; border:2px solid var(--border); border-radius:50px; font-size:.88rem; outline:none; transition:border-color var(--transition); }
.chatbot-input:focus { border-color:var(--primary); }
.chatbot-send { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--primary-dark)); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--transition); }
.chatbot-send:hover { transform:scale(1.1); }

/* ══════════════════════════════
   RESPONSIVE
══════════════════════════════ */
@media (max-width: 1100px) {
  .problems-grid { grid-template-columns:repeat(2,1fr); }
  .pricing-grid { grid-template-columns:repeat(2,1fr); }
  .hiw-steps { grid-template-columns:repeat(2,1fr); gap:20px; }
  .step-num-wrap { display:none; }
  .step-card { margin:0; }
}
@media (max-width: 900px) {
  .hero { padding-top:90px; }
  .brand-icon { width:150px; }
  .brand-icon img { width:150px; }
  .hero-container { grid-template-columns:1fr; gap:24px; }
  .phone-wrap { display:none; }
  .hero-visual { padding:0; }
  .hero-visual .hero-stats { display:flex; }
  .about-grid { grid-template-columns:1fr; gap:40px; }
  .skills-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; gap:32px; }
  .outcomes-list { grid-template-columns:repeat(2,1fr); }
  .contact-grid { grid-template-columns:1fr; gap:40px; }
  .hero-stats { flex-wrap:wrap; justify-content:center; margin-top:8px; }
}
@media (max-width: 768px) {
  .nav-links {
    position:fixed; top:0; right:-100%; width:75%; max-width:320px;
    height:100vh; background:var(--primary-dark);
    flex-direction:column; justify-content:center;
    padding:60px 32px 80px; gap:24px;
    transition:right .35s ease; z-index:999;
  }
  .nav-links.open { right:0; }
  .nav-links .nav-link { font-size:1.1rem; }
  .mobile-menu-logo { display:flex; justify-content:center; margin-bottom:8px; }
  .mobile-menu-logo img { width:160px; height:auto; object-fit:contain; }
  .hamburger { display:flex; z-index:1000; }
  .section { padding:64px 0; }
  .hiw-steps { grid-template-columns:1fr; }
  .problems-grid { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; }
  .pricing-card-popular { transform:none; border-width:2px; }
  .school-pricing-inner { flex-direction:column; }
  .school-contact-btn { margin:0; }
  .principle-timeline { gap:8px; }
  .timeline-connector { max-width:30px; }
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .chatbot-wrap { bottom:16px; right:16px; }
  .chatbot-panel {
    position:fixed;
    bottom:80px;
    right:12px;
    left:12px;
    width:auto;
    max-height:70vh;
  }
  .guarantee-inner { flex-direction:column; text-align:center; }
  .solution-banner-inner { flex-direction:column; text-align:center; }
  .footer-links h4::after { display:inline-block; content:'+'; font-size:1.1rem; color:rgba(255,255,255,.5); }
  .footer-links.open h4::after { content:'−'; }
  .footer-links ul { display:none; margin-bottom:8px; }
  .footer-links.open ul { display:block; }
}
@media (max-width: 540px) {
  .hero-ctas { flex-direction:column; }
  .hero-stats { gap:0; padding:12px; }
  .stat-item { padding:8px 12px; }
  .stat-number { font-size:1.3rem; }
  .outcomes-list { grid-template-columns:1fr; }
  .skills-grid { grid-template-columns:1fr; }
  .compare-row { grid-template-columns:1fr 1fr 1fr; font-size:.78rem; }
}

/* ═══ PAYMENT POPUP ═══ */
.pay-overlay {
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.6); backdrop-filter:blur(4px);
  align-items:center; justify-content:center; padding:16px;
}
.pay-overlay.open { display:flex; }
.pay-modal {
  background:#fff; border-radius:20px; padding:32px 28px;
  width:100%; max-width:400px; position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,.25);
  animation:paySlideUp .35s cubic-bezier(.4,0,.2,1);
}
@keyframes paySlideUp {
  from { transform:translateY(40px); opacity:0; }
  to   { transform:translateY(0);    opacity:1; }
}
.pay-close {
  position:absolute; top:14px; right:16px;
  background:none; border:none; font-size:1.3rem;
  color:#999; cursor:pointer; line-height:1;
}
.pay-close:hover { color:#333; }
.pay-header { text-align:center; margin-bottom:20px; }
.pay-logo { width:48px; height:48px; object-fit:contain; margin-bottom:10px; }
.pay-header h3 { font-size:1.2rem; font-weight:700; color:#1E3D33; margin-bottom:4px; }
.pay-header p { color:#888; font-size:.88rem; }
.pay-icon-wrap { width:60px; height:60px; border-radius:50%; background:#f0f7f4; display:flex; align-items:center; justify-content:center; margin:0 auto 12px; }
.pay-qr-wrap { text-align:center; margin-bottom:20px; }
.pay-qr-box { display:inline-block; padding:12px; border:2px solid #e8f0ed; border-radius:12px; margin-bottom:12px; }
.pay-upi { font-size:.88rem; color:#555; margin-bottom:4px; }
.pay-amount { font-size:1rem; color:#1E3D33; margin-bottom:0; }
.pay-amount strong { font-size:1.2rem; }
.pay-form { display:flex; flex-direction:column; gap:12px; }
.pay-txn-input {
  width:100%; padding:12px 16px; border:2px solid #e0e0e0;
  border-radius:10px; font-size:1rem; outline:none;
  transition:border-color .2s; box-sizing:border-box;
}
.pay-txn-input:focus { border-color:#4F7F6F; }
.pay-txn-hint { font-size:.78rem; color:#aaa; margin:0; }
.pay-back-btn { background:none; border:none; color:#4F7F6F; font-size:.88rem; cursor:pointer; text-align:center; padding:4px; }
.pay-back-btn:hover { text-decoration:underline; }
.pay-modal-success { text-align:center; }
.pay-success-icon {
  width:72px; height:72px; border-radius:50%;
  background:linear-gradient(135deg,#4F7F6F,#2D5048);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 16px; box-shadow:0 8px 24px rgba(79,127,111,.35);
}
.pay-modal-success h3 { font-size:1.3rem; font-weight:800; color:#1E3D33; margin-bottom:8px; }
.pay-success-msg { color:#666; font-size:.95rem; line-height:1.6; margin-bottom:16px; }
.pay-success-details { background:#f0f7f4; border-radius:8px; padding:10px 14px; font-size:.85rem; color:#555; margin-bottom:20px; }
.w-full { width:100%; }

/* ═══ PLAN SELECTION ═══ */
.pay-logo-full { width:160px; height:auto; object-fit:contain; margin:0 auto 12px; display:block; border-radius:8px; }
.plan-select-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:16px; }
.plan-select-card {
  border:2px solid #e0e0e0; border-radius:12px; padding:14px 12px;
  cursor:pointer; transition:all .2s; position:relative; text-align:center;
}
.plan-select-card:hover { border-color:#4F7F6F; background:#f0f7f4; }
.plan-select-card.selected { border-color:#4F7F6F; background:#f0f7f4; box-shadow:0 0 0 3px rgba(79,127,111,.2); }
.plan-select-card.popular { border-color:#4F7F6F; }
.plan-select-badge { position:absolute; top:-10px; left:50%; transform:translateX(-50%); background:#4F7F6F; color:#fff; font-size:.68rem; font-weight:700; padding:2px 10px; border-radius:50px; white-space:nowrap; }
.plan-select-name { font-weight:700; font-size:.9rem; color:#1E3D33; margin-bottom:4px; }
.plan-select-price { font-size:1.2rem; font-weight:800; color:#4F7F6F; }
.plan-select-price span { font-size:.75rem; font-weight:500; color:#888; }
.plan-select-desc { font-size:.75rem; color:#888; margin-top:4px; }
#planNextBtn:disabled { opacity:.4; cursor:not-allowed; transform:none !important; }
