
:root{
  --cream:#FAF6EE;
  --cream-2:#F3EDDF;
  --ink:#1E3A2B;
  --ink-soft:#3D5747;
  --leaf:#7FB069;
  --leaf-deep:#3E7C4F;
  --sun:#FFC83D;
  --clay:#FF7A3C;
  --brand:#E3102D;
  --white:#FFFEFA;
  --radius:28px;
  --font-display:"Fraunces",serif;
  --font-body:"Sora",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overscroll-behavior:none}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--sun);color:var(--ink)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- grain ---------- */
.grain{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:999;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(10) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)}10%{transform:translate(-5%,-5%)}30%{transform:translate(3%,-2%)}
  50%{transform:translate(-2%,4%)}70%{transform:translate(4%,2%)}90%{transform:translate(-3%,3%)}
}

/* ---------- preloader ---------- */
#preloader{position:fixed;inset:0;background:var(--ink);z-index:2000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px}
#preloader .sprout{width:64px;height:64px}
#preLogo{width:min(220px,55vw);height:auto;opacity:0;transform:translateY(20px);filter:brightness(0) invert(.96)}

/* ---------- cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:12px;height:12px;border-radius:50%;background:var(--clay);pointer-events:none;z-index:1500;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s;mix-blend-mode:multiply}
.cursor.is-hover{width:56px;height:56px;background:var(--sun)}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- nav ---------- */
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 32px));z-index:1000;
  display:flex;align-items:center;justify-content:space-between;padding:10px 14px 10px 22px;
  background:rgba(255,254,250,.75);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(30,58,43,.08);border-radius:100px;box-shadow:0 8px 30px rgba(30,58,43,.07);
}
.nav__logo{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:1.3rem;letter-spacing:-.01em}
.nav__logo svg{width:28px;height:28px}
.nav__logo img{height:38px;width:auto;display:block}
.nav__logo--light img{height:46px;filter:brightness(0) invert(.96)}
.nav__links{display:flex;gap:6px;list-style:none}
.nav__links a{font-size:.86rem;font-weight:500;padding:9px 16px;border-radius:100px;transition:background .25s}
.nav__links a:hover{background:var(--cream-2)}
.nav__cta{background:var(--ink);color:var(--cream);border:none;border-radius:100px;padding:12px 22px;font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:background .3s,transform .3s}
.nav__cta:hover{background:var(--leaf-deep);transform:scale(1.04)}
.nav__burger{display:none;background:none;border:none;width:42px;height:42px;border-radius:50%;position:relative}
.nav__burger span{position:absolute;left:10px;right:10px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,top .3s,opacity .3s}
.nav__burger span:nth-child(1){top:16px}
.nav__burger span:nth-child(2){top:24px}
.menu-open .nav__burger span:nth-child(1){top:20px;transform:rotate(45deg)}
.menu-open .nav__burger span:nth-child(2){top:20px;transform:rotate(-45deg)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:900;display:flex;flex-direction:column;justify-content:center;padding:32px;
  clip-path:circle(0% at calc(100% - 50px) 50px);transition:clip-path .6s cubic-bezier(.7,0,.3,1);visibility:hidden}
.menu-open .mobile-menu{clip-path:circle(150% at calc(100% - 50px) 50px);visibility:visible}
.mobile-menu a{font-family:var(--font-display);font-size:clamp(2.2rem,9vw,3.4rem);color:var(--cream);padding:10px 0;border-bottom:1px solid rgba(250,246,238,.12);display:flex;justify-content:space-between;align-items:center}
.mobile-menu a em{font-family:var(--font-body);font-style:normal;font-size:.8rem;opacity:.5}
.mobile-menu__phone{margin-top:28px;color:var(--sun);font-size:1rem;font-family:var(--font-body)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:140px 5vw 0;overflow:hidden}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.hero__inner{position:relative;z-index:2;max-width:1180px;margin:0 auto;width:100%}
.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;background:var(--white);border:1px solid rgba(30,58,43,.1);padding:9px 18px;border-radius:100px;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:28px}
.hero__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--leaf);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(127,176,105,.5)}50%{box-shadow:0 0 0 8px rgba(127,176,105,0)}}
.hero__title{font-family:var(--font-display);font-weight:600;font-size:clamp(3rem,9.5vw,7.6rem);line-height:1.02;letter-spacing:-.025em}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line>span{display:inline-block}
.hero__title .accent{color:var(--leaf-deep);font-style:italic;font-weight:500;position:relative;margin-right:.12em}
.hero__title .accent::after{content:"";position:absolute;left:0;bottom:.06em;width:100%;height:.1em;background:var(--sun);z-index:-1;border-radius:4px;transform:scaleX(0);transform-origin:left}
.hero__sub{max-width:540px;margin-top:30px;font-size:clamp(1rem,1.4vw,1.15rem);color:var(--ink-soft)}
.hero__actions{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;border-radius:100px;padding:17px 32px;font-size:.95rem;font-weight:600;border:none;transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .3s,color .3s}
.btn:hover{transform:translateY(-3px) scale(1.02)}
.btn--primary{background:var(--ink);color:var(--cream)}
.btn--primary:hover{background:var(--leaf-deep)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid rgba(30,58,43,.25)}
.btn--ghost:hover{border-color:var(--ink);background:var(--white)}
.hero__scroll{position:absolute;left:5vw;bottom:4vh;display:flex;align-items:center;gap:10px;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);z-index:3}
.hero__scroll .bar{width:1px;height:44px;background:rgba(30,58,43,.25);position:relative;overflow:hidden}
.hero__scroll .bar::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--ink);animation:scrolldrop 1.8s ease-in-out infinite}
@keyframes scrolldrop{to{top:110%}}

/* ---------- marquee ---------- */
.marquee{background:var(--ink);color:var(--cream);padding:20px 0;overflow:hidden;transform:rotate(-1.2deg) scale(1.02);margin:4vh 0}
.marquee__track{display:flex;gap:48px;width:max-content;animation:marquee 28s linear infinite}
.marquee__track span{font-family:var(--font-display);font-size:1.25rem;font-weight:500;white-space:nowrap;display:flex;align-items:center;gap:48px}
.marquee__track .sep{color:var(--sun)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- sections base ---------- */
.section{padding:13vh 5vw;position:relative}
.section__inner{max-width:1180px;margin:0 auto}
.section__label{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--leaf-deep);margin-bottom:18px}
.section__label::before{content:"";width:26px;height:2px;background:var(--leaf);border-radius:2px}
.section__title{font-family:var(--font-display);font-weight:600;font-size:clamp(2.1rem,5vw,3.8rem);line-height:1.08;letter-spacing:-.02em;max-width:14em}
.section__title em{font-style:italic;color:var(--leaf-deep);font-weight:500}

/* ---------- stats ---------- */
.stats{padding:9vh 5vw 4vh}
.stats__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:var(--white);border:1px solid rgba(30,58,43,.08);border-radius:var(--radius);padding:34px 28px;transition:transform .35s,box-shadow .35s}
.stat:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(30,58,43,.1)}
.stat__num{font-family:var(--font-display);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:600;line-height:1;color:var(--ink)}
.stat__num .plus{color:var(--brand)}
.stat__label{margin-top:10px;font-size:.88rem;color:var(--ink-soft)}

/* ---------- awards ---------- */
.awards{padding:6vh 5vw 2vh}
.awards__inner{max-width:1180px;margin:0 auto}
.awards__label{display:block;text-align:center;font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:26px}
.awards__row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.award{background:var(--cream-2);border:1px solid rgba(30,58,43,.08);border-radius:18px;padding:20px 22px;text-align:center;transition:transform .3s,background .3s}
.award:hover{transform:translateY(-4px);background:var(--white)}
.award strong{display:block;font-family:var(--font-display);font-size:1rem;font-weight:600;line-height:1.3;margin-bottom:6px}
.award span{font-size:.76rem;color:var(--ink-soft)}

/* ---------- programmes ---------- */
.programmes{background:var(--cream)}
.prog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;margin-bottom:54px}
.prog-head p{max-width:380px;color:var(--ink-soft);font-size:.98rem}
.prog-list{display:flex;flex-direction:column;gap:16px}
.prog-card{display:grid;grid-template-columns:90px 1.1fr 1.6fr auto;gap:28px;align-items:center;background:var(--white);border:1px solid rgba(30,58,43,.08);border-radius:var(--radius);padding:38px 40px;position:relative;overflow:hidden;transition:transform .4s cubic-bezier(.34,1.2,.64,1),box-shadow .4s}
.prog-card::before{content:"";position:absolute;inset:0;background:var(--card-tint,var(--cream-2));transform:scaleY(0);transform-origin:bottom;transition:transform .45s cubic-bezier(.7,0,.3,1);z-index:0}
.prog-card:hover::before{transform:scaleY(1)}
.prog-card:hover{transform:scale(1.012);box-shadow:0 20px 50px rgba(30,58,43,.12)}
.prog-card>*{position:relative;z-index:1}
.prog-card__num{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--ink-soft);opacity:.55}
.prog-card__title{font-family:var(--font-display);font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:600;letter-spacing:-.01em;line-height:1.15}
.prog-card__title small{display:block;font-family:var(--font-body);font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf-deep);margin-bottom:8px}
.prog-card__desc{color:var(--ink-soft);font-size:.94rem}
.prog-card__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.prog-card__tags span{font-size:.74rem;font-weight:600;padding:6px 12px;border-radius:100px;background:rgba(30,58,43,.06);color:var(--ink-soft)}
.prog-card__arrow{width:58px;height:58px;border-radius:50%;border:1.5px solid rgba(30,58,43,.2);display:grid;place-items:center;font-size:1.25rem;transition:background .3s,color .3s,transform .4s}
.prog-card:hover .prog-card__arrow{background:var(--ink);color:var(--cream);transform:rotate(-45deg)}

/* ---------- workshops ---------- */
.workshops{background:var(--cream-2);border-radius:48px;margin:0 12px}
.ws-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.ws-card{background:var(--white);border:1px solid rgba(30,58,43,.08);border-radius:var(--radius);padding:30px 26px;position:relative;transition:transform .35s,box-shadow .35s}
.ws-card:hover{transform:translateY(-6px) rotate(-.4deg);box-shadow:0 18px 40px rgba(30,58,43,.1)}
.ws-card__icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;font-size:1.5rem;background:var(--icon-bg,var(--cream-2));margin-bottom:20px}
.ws-card h3{font-family:var(--font-display);font-size:1.35rem;font-weight:600;margin-bottom:8px}
.ws-card>p{font-size:.86rem;color:var(--ink-soft);margin-bottom:16px}
.ws-card__list{list-style:none;display:flex;flex-direction:column;gap:8px}
.ws-card__list li{font-size:.82rem;font-weight:500;padding-left:18px;position:relative}
.ws-card__list li::before{content:"✦";position:absolute;left:0;color:var(--clay);font-size:.7rem;top:2px}
.ws-card__list em{font-style:normal;color:var(--ink-soft);font-weight:400}
.ws-card--seniors{background:var(--ink);color:var(--cream)}
.ws-card--seniors>p{color:rgba(250,246,238,.75)}
.ws-card--seniors .ws-card__list li::before{color:var(--sun)}
.ws-card--seniors .ws-card__list em{color:rgba(250,246,238,.6)}
.ws-card__badge{position:absolute;top:-12px;right:18px;background:var(--sun);color:var(--ink);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:100px}
.ws-note{text-align:center;margin-top:40px;font-size:.94rem;color:var(--ink-soft)}
.ws-note a{font-weight:600;color:var(--leaf-deep);border-bottom:1.5px solid var(--leaf);padding-bottom:2px;transition:color .25s}
.ws-note a:hover{color:var(--clay)}

/* ---------- learn@home ---------- */
.lh-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,6vw,80px);align-items:center}
.lh-sub{margin-top:22px;color:var(--ink-soft);max-width:480px}
.lh-points{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:14px}
.lh-points li{display:flex;gap:14px;align-items:flex-start;font-size:.92rem;max-width:480px}
.lh-points span{flex:0 0 auto;font-size:1.2rem}
.lh-prices{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.lh-price{background:var(--white);border:1.5px solid rgba(30,58,43,.12);border-radius:20px;padding:18px 26px}
.lh-price strong{font-family:var(--font-display);font-size:1.9rem;font-weight:600}
.lh-price strong span{font-size:.85rem;font-family:var(--font-body);color:var(--ink-soft);font-weight:500}
.lh-price small{display:block;font-size:.76rem;color:var(--ink-soft);margin-top:2px}
.lh-price--hot{border-color:var(--sun);background:#FFF7E0;position:relative}
.lh-mock__card{background:var(--white);border:1px solid rgba(30,58,43,.1);border-radius:var(--radius);padding:30px;box-shadow:0 30px 70px rgba(30,58,43,.13);transform:rotate(1.5deg)}
.lh-mock__head{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.lh-mock__avatar{width:44px;height:44px;border-radius:50%;background:var(--leaf);color:var(--white);display:grid;place-items:center;font-weight:700;font-family:var(--font-display)}
.lh-mock__head small{display:block;color:var(--ink-soft);font-size:.74rem}
.lh-mock__streak{margin-left:auto;font-size:.74rem;font-weight:600;background:var(--cream-2);padding:6px 12px;border-radius:100px}
.lh-mock__row{display:grid;grid-template-columns:1fr 90px 38px;gap:12px;align-items:center;font-size:.8rem;font-weight:500;padding:11px 0;border-bottom:1px dashed rgba(30,58,43,.12)}
.lh-bar{height:8px;background:var(--cream-2);border-radius:10px;overflow:hidden}
.lh-bar i{display:block;height:100%;background:var(--leaf);border-radius:10px}
.lh-mock__row b{text-align:right;font-size:.78rem}
.lh-mock__quiz{margin-top:20px;background:var(--cream-2);border-radius:14px;padding:14px 16px;font-size:.8rem}

/* ---------- approach ---------- */
.approach{background:var(--ink);color:var(--cream);border-radius:48px 48px 0 0;margin-top:6vh}
.approach .section__label{color:var(--sun)}
.approach .section__label::before{background:var(--sun)}
.approach .section__title{color:var(--cream)}
.approach .section__title em{color:var(--sun)}
.approach__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px}
.approach__card{background:rgba(250,246,238,.05);border:1px solid rgba(250,246,238,.12);border-radius:var(--radius);padding:40px 32px;transition:background .35s,transform .35s}
.approach__card:hover{background:rgba(250,246,238,.1);transform:translateY(-6px)}
.approach__icon{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-size:1.6rem;margin-bottom:24px;background:var(--icon-bg,var(--sun))}
.approach__card h3{font-family:var(--font-display);font-size:1.45rem;font-weight:600;margin-bottom:12px}
.approach__card p{font-size:.92rem;color:rgba(250,246,238,.72)}
.approach__steps{display:flex;justify-content:center;gap:clamp(20px,6vw,80px);margin-top:80px;flex-wrap:wrap}
.gstep{text-align:center}
.gstep__emoji{font-size:clamp(2.4rem,5vw,3.6rem);display:block;margin-bottom:12px}
.gstep__name{font-family:var(--font-display);font-style:italic;font-size:1.2rem;color:var(--sun)}
.gstep__desc{font-size:.8rem;color:rgba(250,246,238,.6);max-width:170px;margin:6px auto 0}

/* ---------- testimonials ---------- */
.stories{background:var(--ink);padding-top:0}
.stories__track-wrap{overflow:hidden;margin-top:56px}
.stories__track{display:flex;gap:20px;will-change:transform}
.story{flex:0 0 min(420px,82vw);background:var(--cream);color:var(--ink);border-radius:var(--radius);padding:40px 36px;display:flex;flex-direction:column;gap:22px}
.story__stars{color:var(--clay);letter-spacing:3px;font-size:.95rem}
.story__quote{font-family:var(--font-display);font-size:1.22rem;line-height:1.45;font-weight:500}
.story__who{display:flex;align-items:center;gap:14px;margin-top:auto}
.story__avatar{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-family:var(--font-display);color:var(--ink);background:var(--av,var(--sun))}
.story__who small{display:block;color:var(--ink-soft);font-size:.78rem}
.story__who strong{font-size:.92rem}

/* ---------- CTA ---------- */
.cta{background:var(--ink);padding-bottom:0}
.cta__panel{background:linear-gradient(135deg,var(--leaf-deep),#2C5E3C 55%,#234D31);border-radius:48px;padding:clamp(48px,7vw,90px) clamp(28px,6vw,80px);position:relative;overflow:hidden;text-align:center}
.cta__panel::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,200,61,.22),transparent 65%);top:-200px;right:-130px}
.cta__panel::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,60,.18),transparent 65%);bottom:-180px;left:-110px}
.cta__panel>*{position:relative;z-index:1}
.cta__title{font-family:var(--font-display);font-weight:600;font-size:clamp(2.2rem,5.5vw,4.2rem);color:var(--cream);line-height:1.08;letter-spacing:-.02em}
.cta__title em{font-style:italic;color:var(--sun);font-weight:500}
.cta__sub{color:rgba(250,246,238,.8);max-width:520px;margin:22px auto 0}
.cta__actions{display:flex;gap:14px;justify-content:center;margin-top:38px;flex-wrap:wrap}
.btn--sun{background:var(--sun);color:var(--ink)}
.btn--sun:hover{background:var(--cream)}
.btn--outline{background:transparent;color:var(--cream);border:1.5px solid rgba(250,246,238,.4)}
.btn--outline:hover{border-color:var(--cream);background:rgba(250,246,238,.08)}
.cta__phones{display:flex;gap:clamp(20px,5vw,64px);justify-content:center;margin-top:46px;flex-wrap:wrap}
.cta__phone small{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(250,246,238,.6);margin-bottom:6px}
.cta__phone a{font-family:var(--font-display);font-size:clamp(1.3rem,3vw,1.8rem);color:var(--cream);font-weight:600;transition:color .3s}
.cta__phone a:hover{color:var(--sun)}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:var(--cream);padding:11vh 5vw 32px}
.footer__inner{max-width:1180px;margin:0 auto}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:64px;border-bottom:1px solid rgba(250,246,238,.12)}
.footer__brand p{color:rgba(250,246,238,.65);font-size:.9rem;max-width:300px;margin-top:16px}
.footer h4{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sun);margin-bottom:18px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer ul a{color:rgba(250,246,238,.75);font-size:.92rem;transition:color .25s}
.footer ul a:hover{color:var(--cream)}
.footer__word{font-family:var(--font-display);font-weight:600;font-size:clamp(4rem,16vw,13rem);line-height:.95;letter-spacing:-.03em;text-align:center;margin:60px 0 30px;color:rgba(250,246,238,.95)}
.footer__word .leaf-i{color:var(--brand)}
.footer__bottom{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap;font-size:.78rem;color:rgba(250,246,238,.5)}
.footer__signoff{font-family:var(--font-display);font-style:italic;font-size:1.05rem;color:var(--sun)}

/* ---------- reveal utility (hidden states applied via JS only) ---------- */

/* ---------- responsive ---------- */
@media (max-width:960px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:block}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .prog-card{grid-template-columns:1fr;gap:16px;padding:30px 26px}
  .prog-card__num{order:-1}
  .prog-card__arrow{display:none}
  .approach__grid{grid-template-columns:1fr}
  .awards__row{grid-template-columns:repeat(2,1fr)}
  .ws-grid{grid-template-columns:repeat(2,1fr)}
  .lh-grid{grid-template-columns:1fr}
  .lh-mock__card{transform:none}
  .footer__top{grid-template-columns:1fr;gap:36px}
  .hero__scroll{display:none}
  .hero{padding-top:120px;padding-bottom:60px}
}
@media (max-width:640px){
  .awards__row{grid-template-columns:1fr}
  .ws-grid{grid-template-columns:1fr}
  .ws-card--seniors{order:-1}
  .workshops{margin:0;border-radius:32px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .stories__track-wrap{overflow-x:auto;padding-bottom:12px}
}

/* ---------- programme detail pages ---------- */
.dhero{padding:168px 5vw 30px}
.dhero__inner{max-width:1180px;margin:0 auto}
.dhero .crumb{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;color:var(--ink-soft);background:var(--white);border:1px solid rgba(30,58,43,.1);padding:8px 16px;border-radius:100px;margin-bottom:26px;transition:background .25s}
.dhero .crumb:hover{background:var(--cream-2)}
.dhero__kicker{display:block;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--leaf-deep);margin-bottom:14px}
.dhero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.6rem,6.5vw,4.8rem);line-height:1.05;letter-spacing:-.02em;max-width:13em}
.dhero h1 em{font-style:italic;color:var(--leaf-deep);font-weight:500}
.dhero__sub{max-width:560px;margin-top:24px;color:var(--ink-soft);font-size:1.05rem}
.dhero__actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}

.facts{padding:5vh 5vw}
.facts__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.fact{background:var(--white);border:1px solid rgba(30,58,43,.08);border-radius:20px;padding:22px 24px}
.fact small{display:block;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.fact strong{font-family:var(--font-display);font-size:1.15rem;font-weight:600;line-height:1.3}

.dsection{padding:7vh 5vw}
.dsection--tint{background:var(--cream-2);border-radius:40px;margin:0 12px}
.dsection__inner{max-width:980px;margin:0 auto}
.dsection h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-.015em;margin-bottom:14px}
.dsection h2 em{font-style:italic;color:var(--leaf-deep);font-weight:500}
.dsection .lede{color:var(--ink-soft);max-width:640px;margin-bottom:40px}

.week{display:flex;flex-direction:column}
.week-row{display:grid;grid-template-columns:150px 1fr;gap:24px;align-items:baseline;padding:20px 4px;border-bottom:1px dashed rgba(30,58,43,.15)}
.week-row:last-child{border-bottom:none}
.week-row .day{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:var(--leaf-deep)}
.week-row .what strong{display:block;font-size:1rem;margin-bottom:2px}
.week-row .what span{font-size:.88rem;color:var(--ink-soft)}

.fee-card{background:var(--white);border:1px solid rgba(30,58,43,.1);border-radius:var(--radius);padding:36px 38px;max-width:560px}
.fee-row{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px dashed rgba(30,58,43,.15);font-size:.95rem}
.fee-row:last-of-type{border-bottom:none}
.fee-row b{font-family:var(--font-display);font-size:1.05rem;white-space:nowrap}
.fee-note{font-size:.78rem;color:var(--ink-soft);margin-top:16px}

.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.benefit{background:var(--white);border:1px solid rgba(30,58,43,.08);border-radius:20px;padding:26px 24px}
.benefit .ic{font-size:1.6rem;display:block;margin-bottom:12px}
.benefit h3{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:6px}
.benefit p{font-size:.85rem;color:var(--ink-soft)}

.eblock{display:grid;grid-template-columns:84px 1fr;gap:26px;padding:36px 0;border-bottom:1px solid rgba(30,58,43,.1)}
.eblock:last-of-type{border-bottom:none}
.eblock__icon{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;font-size:1.8rem;background:var(--icon-bg,var(--cream-2))}
.eblock h3{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin-bottom:4px}
.eblock .who{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf-deep);margin-bottom:10px;display:block}
.eblock p{font-size:.92rem;color:var(--ink-soft);max-width:620px}
.eblock .prog-card__tags{margin-top:14px}

@media (max-width:960px){
  .facts__grid{grid-template-columns:repeat(2,1fr)}
  .benefit-grid{grid-template-columns:1fr}
  .week-row{grid-template-columns:1fr;gap:4px}
  .eblock{grid-template-columns:1fr;gap:14px}
  .dsection--tint{margin:0}
}

/* ---------- forms (register page) ---------- */
.form{max-width:680px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .field{margin-bottom:18px}
.form label{display:block;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;padding:15px 18px;border:1.5px solid rgba(30,58,43,.15);border-radius:14px;background:var(--white);font-family:inherit;font-size:.95rem;color:var(--ink);transition:border-color .25s,box-shadow .25s;box-sizing:border-box}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--leaf-deep);box-shadow:0 0 0 4px rgba(127,176,105,.18)}
.form textarea{min-height:120px;resize:vertical}
.form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231E3A2B' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center}
.form__note{font-size:.82rem;color:var(--ink-soft);margin-top:14px}
.form .btn{border:none}

/* ---------- news page ---------- */
.news-item{display:grid;grid-template-columns:150px 1fr;gap:28px;padding:32px 4px;border-bottom:1px dashed rgba(30,58,43,.15);align-items:baseline}
.news-item:last-of-type{border-bottom:none}
.news-item .date{font-family:var(--font-display);font-style:italic;color:var(--leaf-deep);font-size:1rem}
.news-item h3{font-family:var(--font-display);font-size:1.4rem;font-weight:600;margin-bottom:6px}
.news-item p{font-size:.92rem;color:var(--ink-soft);max-width:620px}
.news-item .tag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--sun);color:var(--ink);padding:5px 12px;border-radius:100px;margin-bottom:10px}

/* ---------- awards page ---------- */
.award-big{display:grid;grid-template-columns:96px 1fr;gap:28px;padding:36px 0;border-bottom:1px solid rgba(30,58,43,.1);align-items:start}
.award-big:last-of-type{border-bottom:none}
.award-big__medal{width:76px;height:76px;border-radius:50%;display:grid;place-items:center;font-size:2rem;background:var(--cream-2);border:2px solid var(--sun)}
.award-big h3{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin-bottom:6px}
.award-big .by{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf-deep);margin-bottom:10px;display:block}
.award-big p{font-size:.92rem;color:var(--ink-soft);max-width:620px}

/* ---------- payment methods ---------- */
.pay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pay-card{background:var(--white);border:1px solid rgba(30,58,43,.08);border-radius:var(--radius);padding:32px 28px}
.pay-card .ic{font-size:2rem;display:block;margin-bottom:16px}
.pay-card h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin-bottom:10px}
.pay-card p{font-size:.88rem;color:var(--ink-soft)}
.pay-card .steps{margin-top:14px;padding-left:18px;font-size:.85rem;color:var(--ink-soft);display:flex;flex-direction:column;gap:6px}

@media (max-width:960px){
  .form .row{grid-template-columns:1fr}
  .news-item{grid-template-columns:1fr;gap:6px}
  .award-big{grid-template-columns:1fr;gap:14px}
  .pay-grid{grid-template-columns:1fr}
}

/* ---------- since badge + form success ---------- */
.nav__since{font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);border-left:1.5px solid rgba(30,58,43,.18);padding-left:10px;margin-left:10px;white-space:nowrap;align-self:center}
.form-success{display:none;background:var(--white);border:1.5px solid var(--leaf);border-radius:var(--radius);padding:36px;text-align:center;max-width:680px}
.form-success.is-visible{display:block}
.form-success .big{font-size:2.2rem;display:block;margin-bottom:12px}
.form-success h3{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin-bottom:8px}
.form-success p{font-size:.92rem;color:var(--ink-soft)}
