/* MyIT Global — Design System
   DO NOT EDIT. All content changes go in index.html.
   See README.txt for guidance. */

/* ── TOKENS ─────────────────────────────────────────────── */
:root{
  --navy:#1B3A6B;--cyan:#4DC8E8;--coral:#F0564A;--yellow:#F5B731;
  --ink:#0D1B2E;--off-white:#F6F5F1;--white:#fff;--grey:#78818F;--rule:#DDD9D2;
  --fD:'Raleway',sans-serif;--fB:'Lato',sans-serif;
  --r4:4px;--r8:8px;--r14:14px;--rpill:100px;
  --max:1160px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:76px}
body{font-family:var(--fB);background:var(--off-white);color:var(--ink);font-size:17px;line-height:1.72;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{display:block;max-width:100%}

/* ── NAV ─────────────────────────────────────────────────── */
.site-nav{position:sticky;top:0;z-index:200;background:#fff;box-shadow:0 1px 0 var(--rule)}
.nav-bar{height:68px;display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 48px;width:100%}
.nav-logo{display:flex;align-items:center;gap:13px;flex-shrink:0;text-decoration:none}
.logo-img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0}
.nav-wordmark{font-family:var(--fD);font-weight:800;font-size:21px;letter-spacing:-0.025em;line-height:1;white-space:nowrap}
.wm-my{color:var(--cyan)}.wm-it{color:var(--ink)}.wm-gl{color:var(--grey);font-weight:400;font-size:19px}
/* desktop nav links */
.nav-links{display:flex;align-items:center;gap:0;flex:1;justify-content:center}
.nav-item{position:relative}
.nav-link{font-family:var(--fD);font-size:13.5px;font-weight:600;color:var(--ink);opacity:.58;padding:8px 14px;display:flex;align-items:center;gap:4px;transition:opacity .18s;white-space:nowrap;cursor:pointer;text-decoration:none}
.nav-link:hover{opacity:1}
.has-drop::after{content:"▾";font-size:9px;opacity:.5;margin-top:1px}
.nav-drop{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid var(--rule);border-radius:var(--r8);min-width:200px;box-shadow:0 10px 32px rgba(13,27,46,.09);opacity:0;pointer-events:none;transform:translateY(-5px);transition:opacity .15s,transform .15s;z-index:300}
.nav-item:hover .nav-drop{opacity:1;pointer-events:auto;transform:translateY(0)}
.drop-label{display:block;padding:9px 16px 3px;font-family:var(--fD);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan)}
.drop-link{display:block;padding:9px 16px;font-family:var(--fB);font-size:13px;color:var(--ink);opacity:.68;border-bottom:1px solid var(--rule);transition:background .1s,opacity .1s;text-decoration:none}
.drop-link:last-child{border-bottom:none}
.drop-link:hover{background:var(--off-white);opacity:1}
/* hamburger — hidden on desktop */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--r4);flex-shrink:0}
.nav-hamburger span{display:block;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s,width .25s}
.nav-hamburger span:nth-child(1){width:22px}
.nav-hamburger span:nth-child(2){width:16px}
.nav-hamburger span:nth-child(3){width:22px}
.nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);width:22px}
.nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);width:22px}
/* mobile drawer */
.nav-mobile{display:none;background:#fff;border-top:1px solid var(--rule);overflow-y:auto;max-height:calc(100vh - 76px)}
.nav-mobile.is-open{display:block}
.mob-link{display:block;font-family:var(--fD);font-size:15px;font-weight:600;color:var(--ink);opacity:.75;padding:14px 24px;border-bottom:1px solid var(--rule);text-decoration:none;transition:opacity .15s,background .15s}
.mob-link:hover{opacity:1;background:var(--off-white)}
.mob-section{padding:10px 24px 4px;font-family:var(--fD);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);background:#fff}
.mob-sublink{display:block;font-family:var(--fB);font-size:14px;color:var(--ink);opacity:.6;padding:11px 24px 11px 36px;border-bottom:1px solid var(--rule);text-decoration:none;transition:opacity .15s,background .15s}
.mob-sublink:hover{opacity:1;background:var(--off-white)}
.mob-cta{display:block;margin:20px 24px;padding:14px;background:var(--navy);color:#fff;font-family:var(--fD);font-size:15px;font-weight:700;text-align:center;border-radius:var(--r4);text-decoration:none;transition:background .18s}
.mob-cta:hover{background:var(--cyan);color:var(--navy)}
.mob-wa{display:flex;align-items:center;justify-content:center;gap:10px;margin:0 24px 24px;padding:13px;border:2px solid #25D366;color:#1a7a3f;font-family:var(--fD);font-size:14px;font-weight:700;border-radius:var(--r4);text-decoration:none;transition:background .18s}
.mob-wa:hover{background:#f0faf3}
/* colour bar */
.colour-bar{height:8px;background:linear-gradient(to right,var(--navy) 0% 25%,var(--cyan) 25% 50%,var(--coral) 50% 75%,var(--yellow) 75% 100%)}
/* ── RESPONSIVE — hide desktop nav, show hamburger ────────── */
@media(max-width:900px){
  .nav-bar{padding:0 20px}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
}

/* ── HERO v1.4 — SCRIM WITH BACKGROUND IMAGE ─────────────── */
.hero-wrap{min-height:calc(100vh - 76px);display:flex;flex-direction:column;position:relative;overflow:hidden}
/* LICENSEE: hero background image is set via inline style on the .hero-bg div in the HTML */
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:100% 39%;z-index:0}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(27,58,107,.05) 0%,rgba(27,58,107,.15) 40%,rgba(27,58,107,.88) 68%,rgba(27,58,107,.96) 100%);z-index:1}
.hero-inner{flex:1;max-width:var(--max);margin:0 auto;padding:0 48px;width:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;position:relative;z-index:2;padding-top:clamp(40vh,48vh,55vh)}
.hero-content{padding:0 0 52px;max-width:800px;width:100%}
.hero-eyebrow{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6);display:block;margin-bottom:20px}
.hero-h1{font-family:var(--fD);font-size:clamp(52px,6.8vw,92px);font-weight:900;line-height:.97;letter-spacing:-.05em;color:#fff;margin-bottom:0}
.hero-h1-accent{color:var(--cyan);white-space:nowrap}
.hero-sub{font-family:var(--fB);font-size:19px;font-weight:400;line-height:1.70;color:rgba(255,255,255,.85);margin:12px auto 32px;max-width:580px}
/* CTA row */
.hero-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:0}
.btn-primary{background:var(--cyan);color:var(--navy);padding:15px 32px;border-radius:var(--r4);font-family:var(--fD);font-size:15px;font-weight:700;letter-spacing:.02em;border:none;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;transition:background .2s,transform .15s;text-decoration:none}
.btn-primary:hover{background:#fff;color:var(--navy);transform:translateY(-1px)}
.btn-contact{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:var(--r4);border:none;background:var(--coral);font-family:var(--fD);font-size:14px;font-weight:700;color:#fff;text-decoration:none;white-space:nowrap;transition:background .2s,transform .15s;cursor:pointer}
.btn-contact:hover{background:#d94438;transform:translateY(-1px)}
.btn-cyan{background:var(--cyan);color:var(--navy);padding:12px 26px;border-radius:var(--r4);font-family:var(--fD);font-size:14px;font-weight:700;letter-spacing:.02em;border:none;cursor:pointer;display:inline-block;white-space:nowrap;transition:background .2s,transform .15s;text-decoration:none}
.btn-cyan:hover{background:#fff;color:var(--navy);transform:translateY(-1px)}
/* octa frame kept for section 7 */
.octa-frame{width:min(480px,100%);aspect-ratio:1/1;clip-path:polygon(30% 0%,70% 0%,100% 30%,100% 70%,70% 100%,30% 100%,0% 70%,0% 30%);overflow:hidden}
.octa-frame img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
/* hero responsive */
@media(max-width:900px){
  .hero-inner{padding-top:clamp(34vh,42vh,48vh);padding-left:32px;padding-right:32px}
  .hero-sub{font-size:17px}
  .hero-bg{background-position:100% 39%}
}
@media(max-width:600px){
  .hero-inner{padding-top:clamp(44vh,50vh,56vh);padding-left:20px;padding-right:20px}
  .hero-eyebrow{display:none}
  .hero-h1{font-size:clamp(38px,9vw,58px)}
  .hero-sub{font-size:15px;max-width:100%;margin:8px auto 20px}
  .hero-content{padding-bottom:24px}
  .hero-actions{flex-direction:column;gap:10px;width:100%}
  .btn-primary,.btn-contact{width:100%;justify-content:center}
  .hero-bg{background-position:68% 39%}
}

/* ── TRUST BAR ───────────────────────────────────────────── */
.trust-bar{background:var(--navy);padding:20px 48px;position:relative;z-index:3}
.trust-inner{max-width:var(--max);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px}
.trust-label{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);white-space:nowrap}
.trust-pills-row{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.trust-pill{font-family:var(--fD);font-size:12px;font-weight:700;padding:6px 16px;border-radius:var(--rpill);white-space:nowrap;letter-spacing:.01em}
.trust-pill-cyan{background:var(--cyan);color:var(--navy)}
.trust-pill-coral{background:var(--coral);color:#fff}
.trust-pill-yellow{background:var(--yellow);color:var(--navy)}
.trust-pill-navy{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25)}

/* ── SHARED SECTION STYLES ───────────────────────────────── */
.section-white{padding:88px 0;background:#fff}
.section-light{padding:88px 0;background:var(--off-white)}
.section-dark{padding:88px 0;background:var(--navy);color:#fff}
.wrap{max-width:var(--max);margin:0 auto;padding:0 48px}
.section-head{margin-bottom:40px}
.eyebrow{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--grey);display:block;margin-bottom:14px}
.eyebrow-cyan{color:var(--cyan)}
.section-h2{font-family:var(--fD);font-size:clamp(30px,3.2vw,44px);font-weight:800;line-height:1.1;letter-spacing:-.025em;color:var(--ink);margin-top:4px}
.section-h2-white{color:#fff}
.section-intro{font-family:var(--fB);font-size:17px;opacity:.72;margin-top:14px;line-height:1.72}
.content-h3{font-family:var(--fD);font-size:clamp(20px,2vw,26px);font-weight:800;line-height:1.22;letter-spacing:-.01em;color:var(--ink);margin-bottom:10px}

/* ── SECTION 2 — SOCIAL PROOF ────────────────────────────── */
.rating-block{margin-bottom:48px}
.stars{color:var(--yellow);font-size:20px;letter-spacing:3px;display:inline}
.grid-testi{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:44px}
.card-testi{background:#fff;border:1px solid var(--rule);border-left:4px solid var(--cyan);border-radius:var(--r8);padding:32px;display:flex;flex-direction:column;justify-content:space-between;min-height:280px}
.card-testi-cyan{border-left-color:var(--cyan)}
.card-testi-coral{border-left-color:var(--coral)}
.card-testi-yellow{border-left-color:var(--yellow)}
.result-tag{display:inline-block;background:rgba(77,200,232,.15);color:var(--cyan);font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.04em;padding:4px 13px;border-radius:var(--rpill);margin-bottom:18px}
.testi-qmark{font-family:var(--fD);font-size:44px;font-weight:900;color:var(--cyan);opacity:.35;line-height:.85;display:block;margin-bottom:12px}
.testi-body{font-family:var(--fB);font-size:15px;font-style:italic;line-height:1.72;margin-bottom:26px;flex-grow:1}
.testi-name{font-family:var(--fD);font-size:13px;font-weight:700;letter-spacing:.03em;color:var(--ink)}
.testi-role{font-family:var(--fD);font-size:11px;opacity:.42;margin-top:3px}
/* S2 stars row */
.s2-stars-row{display:flex;align-items:center;gap:10px;margin-top:18px}
.stars-label{font-family:var(--fD);font-size:13px;font-weight:700;color:var(--ink);opacity:.7}
/* S2 YouTube embed — responsive 16:9 */
.s2-youtube{width:100%;margin-bottom:28px}
.s2-youtube-frame{position:relative;width:100%;padding-bottom:56.25%;border-radius:var(--r8);overflow:hidden;background:var(--ink)}
.s2-youtube-frame iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
/* S2 portrait video cards */
.s2-portraits{display:flex;justify-content:center;gap:0;margin-bottom:44px;flex-wrap:nowrap;width:100%}
.portrait-card{flex:1 1 50%;min-width:0}
/* portrait video embed — 9:16 responsive iframe */
.portrait-card-embed{position:relative;width:100%;padding-bottom:177.78%;border-radius:var(--r8);overflow:hidden;background:var(--ink)}
.portrait-card-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
/* lesson report mock */
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.feature-h2{font-family:var(--fD);font-size:clamp(30px,3.2vw,44px);font-weight:800;line-height:1.1;letter-spacing:-.025em;margin-bottom:20px;margin-top:4px;color:#fff}
.feature-h2-italic{font-style:italic;font-weight:300;color:var(--yellow)}
.feature-body{font-family:var(--fB);font-size:16px;opacity:.75;line-height:1.78;margin-bottom:28px;max-width:440px}
.feature-bullets{display:flex;flex-direction:column;gap:13px}
.feature-bullets li{display:flex;align-items:flex-start;gap:12px;font-family:var(--fB);font-size:15px;opacity:.82;line-height:1.65}
.feature-bullets li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cyan);margin-top:8px;flex-shrink:0}
.report-mock{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:var(--r8);padding:30px;width:100%}
.rm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08)}
.rm-badge{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan)}
.rm-date{font-family:var(--fD);font-size:11px;opacity:.3}
.rm-row{display:grid;grid-template-columns:76px 1fr;gap:10px;margin-bottom:14px;line-height:1.55}
.rm-key{font-family:var(--fD);font-weight:700;font-size:10px;letter-spacing:.08em;text-transform:uppercase;opacity:.34;padding-top:2px}
.rm-val{font-family:var(--fB);font-size:13px;opacity:.84}
.rm-prog{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}
.rm-prog-lbl{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.35;display:flex;justify-content:space-between;margin-bottom:8px}
.rm-prog-lbl span{opacity:1;color:var(--cyan)}
.rm-track{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.rm-fill{height:100%;background:linear-gradient(to right,var(--cyan),var(--yellow));border-radius:2px}

/* ── SECTION 3 — STUDENT SUPPORT ────────────────────────── */
.grid-usp{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:44px}
.card-usp{background:#fff;border-radius:var(--r8);padding:32px 28px;border-left:4px solid transparent;transition:transform .15s;min-height:200px}
.card-usp:hover{transform:translateY(-2px)}
.card-usp-navy{border-color:var(--navy)}.card-usp-cyan{border-color:var(--cyan)}.card-usp-coral{border-color:var(--coral)}.card-usp-yellow{border-color:var(--yellow)}
.card-usp-h3{font-family:var(--fD);font-size:20px;font-weight:800;letter-spacing:-.01em;line-height:1.22;margin-bottom:12px;color:var(--ink)}
.card-usp-body{font-family:var(--fB);font-size:15px;opacity:.72;line-height:1.75}
.card-blog{background:#fff;border-radius:var(--r8);overflow:hidden;border:1px solid var(--rule);transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;color:inherit;text-decoration:none}
.card-blog:hover{transform:translateY(-2px);box-shadow:0 2px 12px rgba(13,27,46,.08)}
.card-blog-img{height:160px;overflow:hidden;flex-shrink:0;background:var(--navy)}
.card-blog-img img{width:100%;height:100%;object-fit:cover;display:block}
.card-blog-body{padding:22px;display:flex;flex-direction:column;flex:1}
.blog-tag{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:8px}
.card-blog-h4{font-family:var(--fD);font-size:15px;font-weight:800;letter-spacing:-.01em;line-height:1.3;margin-bottom:6px;color:var(--ink)}
.card-blog-excerpt{font-family:var(--fB);font-size:13px;opacity:.65;line-height:1.65;margin-bottom:12px;flex:1}
.blog-meta{font-family:var(--fD);font-size:11px;opacity:.38;margin-bottom:14px}
.blog-read-more{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:color .15s}
.blog-read-more:hover{color:var(--cyan)}
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:44px}
.section-cta-centre{text-align:center;margin-top:8px}
.competence-ph{background:#fff;border-left:4px solid var(--cyan);border-radius:var(--r8);padding:32px;display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:44px;border-top:1px solid var(--rule);border-right:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.competence-ph-left{display:flex;flex-direction:column;gap:8px}
.competence-ph-label{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan)}
.competence-ph-title{font-family:var(--fD);font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.competence-ph-desc{font-family:var(--fB);font-size:15px;color:var(--ink);opacity:.7;line-height:1.6}

/* ── SECTION 4 — HOW WE TEACH ────────────────────────────── */
.section-s4{padding:80px 0;background:#fff}
/* zone 1 — heyzine + partner cards */
.s4-zone1{display:grid;grid-template-columns:1.2fr 0.8fr;gap:56px;align-items:start;margin-bottom:72px}
.s4-flipbook-col{display:flex;flex-direction:column}
.s4-partner-col{display:flex;flex-direction:column;gap:18px}
/* partner cards */
.partner-box{background:var(--off-white);border-radius:var(--r8);padding:26px 24px;border-left:4px solid var(--navy)}
.partner-box-cyan{border-left-color:var(--cyan)}
.partner-box-yellow{border-left-color:var(--yellow)}
.partner-h4{font-family:var(--fD);font-size:16px;font-weight:800;color:var(--ink);margin-bottom:10px;letter-spacing:-.01em;line-height:1.2}
.partner-body{font-family:var(--fB);font-size:14px;opacity:.72;line-height:1.72;margin-bottom:16px}
.partner-btn{font-family:var(--fD);font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--navy);text-decoration:none;display:inline-flex;align-items:center;gap:5px;transition:color .15s}
.partner-btn:hover{color:var(--cyan)}
.partner-btn::after{content:"→"}
/* heyzine embed */
.embed-flipbook{position:relative;width:100%;border-radius:var(--r8);overflow:hidden;display:block;border:1px solid var(--rule)}
.embed-flipbook img{width:100%;height:auto;display:block}
.embed-flipbook-cta{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:11px 24px;border-radius:var(--r4);font-family:var(--fD);font-size:14px;font-weight:700;letter-spacing:.02em;white-space:nowrap;border:2px solid rgba(255,255,255,.25);transition:background .2s,color .2s;z-index:2;text-decoration:none}
.embed-flipbook-cta:hover{background:var(--cyan);color:var(--navy);border-color:var(--cyan)}
.flipbook-caption{font-family:var(--fB);font-size:13px;color:var(--grey);margin-top:10px;text-align:center}
/* zone 2 — learning cycle */
.cycle-strip{background:var(--off-white);padding:56px 48px;margin:0 -48px;border-radius:0;margin-bottom:72px}
.cycle-heading{font-family:var(--fD);font-size:clamp(22px,2.4vw,32px);font-weight:800;color:var(--ink);margin-bottom:8px;text-align:center}
.cycle-subhead{font-family:var(--fB);font-size:15px;color:var(--ink);opacity:.6;text-align:center;margin-bottom:44px}
.cycle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}
.cycle-step{text-align:center;padding:20px 16px;position:relative}
.cycle-step:not(:last-child)::after{content:"→";position:absolute;right:-4px;top:28px;font-size:18px;color:var(--cyan);opacity:.4;font-family:var(--fD);font-weight:700}
.cycle-num{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:8px}
.cycle-title{font-family:var(--fD);font-size:14px;font-weight:800;color:var(--ink);margin-bottom:6px;line-height:1.25}
.cycle-body{font-family:var(--fB);font-size:12.5px;color:var(--ink);opacity:.6;line-height:1.6}
/* zone 3 — programme cards */
.s4-programmes{margin-bottom:0}
.s4-prog-head{margin-bottom:28px}
.grid-5{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.card-service{border:1px solid var(--rule);border-radius:var(--r8);padding:26px 20px;background:#fff;transition:border-color .2s,transform .15s,box-shadow .2s}
.card-service:hover{border-color:var(--cyan);box-shadow:0 2px 16px rgba(77,200,232,.12);transform:translateY(-2px)}
.card-service-accent{width:28px;height:3px;border-radius:2px;margin-bottom:14px}
.card-service-h4{font-family:var(--fD);font-size:17px;font-weight:800;letter-spacing:-.01em;margin-bottom:5px;color:var(--ink)}
.card-service-desc{font-family:var(--fB);font-size:13px;opacity:.55;line-height:1.5}
/* zone 4 — podcast dark strip */
.section-s4-podcast{background:var(--navy);padding:72px 0;margin-top:0}
.podcast-intro{max-width:640px;margin-bottom:48px}
.podcast-h2{font-family:var(--fD);font-size:clamp(24px,2.8vw,36px);font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.025em;margin-bottom:18px}
.podcast-body{font-family:var(--fB);font-size:16px;color:rgba(255,255,255,.72);line-height:1.75}
/* podcast player cards */
.podcast-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.podcast-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r8);padding:28px}
.podcast-card-label{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:8px}
.podcast-card-title{font-family:var(--fD);font-size:16px;font-weight:800;color:#fff;margin-bottom:20px;line-height:1.3}
/* branded audio player */
.audio-player{width:100%}
.audio-player audio{display:none}
.ap-controls{display:flex;align-items:center;gap:12px}
.ap-btn{width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;flex-shrink:0}
.ap-btn-play{background:var(--cyan)}
.ap-btn-play:hover{background:#fff;transform:scale(1.05)}
.ap-btn-stop{background:rgba(255,255,255,.12)}
.ap-btn-stop:hover{background:rgba(255,255,255,.22)}
.ap-btn svg{pointer-events:none}
.ap-scrub{flex:1;display:flex;flex-direction:column;gap:5px}
.ap-track{width:100%;height:4px;background:rgba(255,255,255,.15);border-radius:2px;position:relative;cursor:pointer;overflow:hidden}
.ap-fill{height:100%;background:var(--cyan);border-radius:2px;width:0%;transition:width .1s linear;pointer-events:none}
.ap-time{font-family:var(--fD);font-size:10px;color:rgba(255,255,255,.4);letter-spacing:.06em;display:flex;justify-content:space-between}
/* responsive */
@media(max-width:900px){
  .podcast-cards{grid-template-columns:1fr}
}
@media(max-width:600px){
  .section-s4-podcast{padding:52px 0}
  .podcast-intro{margin-bottom:36px}
}
/* ── S4 RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:900px){
  .s4-zone1{grid-template-columns:1fr;gap:40px}
  .s4-flipbook-col{order:1}
  .s4-partner-col{order:2}
  .cycle-strip{padding:48px 24px;margin:0 -24px;margin-bottom:56px}
  .podcast-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:600px){
  .section-s4{padding:52px 0}
  .cycle-strip{padding:40px 20px;margin:0 -20px;margin-bottom:48px}
  .cycle-step:not(:last-child)::after{display:none}
  .cycle-grid{gap:4px}
  .cycle-step{padding:16px 12px}
  .section-s4-podcast{padding:52px 0}
}
/* ── SECTION 5 — PRICE CALCULATOR ───────────────────────── */
.calc-outer{background:#fff;border:1px solid var(--rule);border-radius:var(--r8);padding:40px;box-shadow:0 2px 16px rgba(13,27,46,.06)}
.calc-step-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.calc-eyebrow{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--navy)}
.calc-currency{display:flex;gap:6px}
.calc-pill{font-family:var(--fD);font-size:12px;font-weight:700;padding:5px 14px;border-radius:var(--rpill);border:1.5px solid var(--rule);cursor:pointer}
.calc-pill-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.calc-pill-inactive{background:transparent;color:var(--ink);opacity:.5}
.calc-step-label{font-family:var(--fD);font-size:12px;font-weight:600;color:var(--grey);text-align:right;display:block;margin-bottom:16px}
.calc-heading{font-family:var(--fD);font-size:28px;font-weight:800;color:var(--ink);margin-bottom:6px}
.calc-progress{width:100%;height:4px;background:var(--rule);border-radius:2px;margin-bottom:20px;overflow:hidden}
.calc-progress-fill{height:100%;width:12.5%;background:linear-gradient(to right,var(--navy),var(--cyan));border-radius:2px}
.calc-instruction{font-family:var(--fB);font-size:15px;color:var(--ink);opacity:.6;margin-bottom:6px}
.calc-sub-instruction{font-family:var(--fD);font-size:13px;font-weight:700;color:var(--navy);margin-bottom:16px}
.calc-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}
.calc-card{border:1.5px solid var(--rule);border-radius:var(--r8);padding:20px 22px;display:flex;justify-content:space-between;align-items:flex-start;transition:border-color .18s}
.calc-card:hover{border-color:var(--navy)}
.calc-card-selected{border-color:var(--navy);background:rgba(27,58,107,.04)}
.calc-card-left h4{font-family:var(--fD);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px}
.calc-card-left p{font-family:var(--fB);font-size:13px;color:var(--ink);opacity:.6;line-height:1.5;max-width:280px}
.calc-card-price{font-family:var(--fD);font-size:13px;font-weight:700;color:var(--cyan);white-space:nowrap;margin-left:16px;flex-shrink:0}
.calc-footer{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
.calc-back{font-family:var(--fD);font-size:14px;font-weight:600;color:var(--grey);background:none;border:none;cursor:pointer}
.calc-next{background:var(--navy);color:#fff;padding:14px 52px;border-radius:var(--rpill);font-family:var(--fD);font-size:15px;font-weight:700;border:none;cursor:pointer;transition:background .2s}
.calc-next:hover{background:var(--cyan)}
.calc-below{text-align:center;margin-top:32px}
.calc-below-text{font-family:var(--fB);font-size:15px;color:var(--ink);opacity:.55;margin-bottom:16px}

/* ── SECTION 6 — ABOUT ───────────────────────────────────── */
.section-about{background:var(--off-white);padding:88px 0 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.about-panels{display:flex;flex-direction:column;gap:0}
.about-panel{display:flex;gap:18px;padding:28px 0;border-bottom:1px solid var(--rule)}
.about-panel:first-child{padding-top:0}
.about-panel:last-child{border-bottom:none}
.about-panel-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.ap-icon-cyan{background:rgba(77,200,232,.12)}
.ap-icon-coral{background:rgba(240,86,74,.10)}
.ap-icon-yellow{background:rgba(255,193,7,.12)}
.about-panel-title{font-family:var(--fD);font-size:15px;font-weight:800;color:var(--ink);margin-bottom:7px;letter-spacing:-.01em}
.about-panel-body{font-family:var(--fB);font-size:15px;line-height:1.72;color:var(--grey)}
.about-social{display:flex;gap:10px;margin-top:32px}
.markets-strip{background:var(--navy);padding:36px 48px;margin-top:72px}
.markets-inner{max-width:var(--max);margin:0 auto;text-align:center}
.markets-label{display:block;font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:20px}
.markets-grid{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:14px 40px;flex-wrap:wrap}
.market-item-full{justify-content:center}
.market-item{font-family:var(--fD);font-size:13px;font-weight:600;color:#fff;display:flex;align-items:center;gap:10px}
.market-flag{width:30px;height:30px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
@media(max-width:900px){
  .section-about{padding:72px 0 0}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .markets-strip{padding:32px 32px;margin-top:52px}
}
@media(max-width:600px){
  .section-about{padding:52px 0 0}
  .markets-strip{padding:24px 20px;margin-top:40px}
  .markets-grid{display:inline-grid;grid-template-columns:1fr 1fr;gap:12px 32px}
  .market-item-full{grid-column:1 / -1;justify-content:center}
  .about-panel{gap:14px}
  .about-panel-icon{width:34px;height:34px}
}

/* ── SECTION 7 — TUTOR ───────────────────────────────────── */
.tutor-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.btn-coral{background:var(--coral);color:#fff;padding:15px 32px;border-radius:var(--r4);font-family:var(--fD);font-size:15px;font-weight:700;letter-spacing:.02em;border:none;cursor:pointer;display:inline-block;white-space:nowrap;transition:background .2s,transform .15s;text-decoration:none}
.btn-coral:hover{background:var(--navy);transform:translateY(-1px)}
/* S7 tutor image — use <img src="assets/images/tutor-team.jpg"> in production; swap src only, no CSS change needed */
.tutor-img-wrap{border-radius:var(--r8);overflow:hidden;width:100%;flex-shrink:0}
.tutor-img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;min-height:360px}
@media(max-width:900px){
  .tutor-grid{grid-template-columns:1fr;gap:36px}
  .tutor-img-wrap{order:-1}
  .tutor-img{min-height:260px}
}
@media(max-width:600px){
  .tutor-img{min-height:200px}
}

/* ── CTA BAND ────────────────────────────────────────────── */
.cta-section{padding:96px 48px;background:var(--navy);color:#fff}
.cta-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:nowrap}
.cta-h2{font-family:var(--fD);font-size:clamp(32px,3.5vw,52px);font-weight:900;letter-spacing:-.035em;line-height:1.04;margin-bottom:12px}
.cta-sub{font-family:var(--fB);font-size:17px;opacity:.72;line-height:1.68;max-width:480px}
.cta-buttons{display:flex;gap:14px;flex-shrink:0;align-items:center}
.btn-white{background:#fff;color:var(--navy);padding:15px 32px;border-radius:var(--r4);font-family:var(--fD);font-size:15px;font-weight:800;letter-spacing:.02em;border:none;cursor:pointer;display:inline-block;white-space:nowrap;transition:transform .15s,box-shadow .15s;text-decoration:none}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(13,27,46,.15)}
.btn-outline-white{border:2px solid rgba(255,255,255,.35);color:#fff;padding:13px 28px;border-radius:var(--r4);font-family:var(--fD);font-size:15px;font-weight:700;background:none;cursor:pointer;display:inline-block;white-space:nowrap;transition:border-color .2s,background .2s;text-decoration:none}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* ── FOOTER ──────────────────────────────────────────────── */
footer{background:var(--ink);color:#fff;padding:72px 48px 36px}
.footer-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1.3fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-brand-name{font-family:var(--fD);font-size:21px;font-weight:800;letter-spacing:-.02em;margin-bottom:10px;white-space:nowrap}
.fbn-my{color:var(--cyan)}.fbn-gl{font-weight:400;color:var(--grey);margin-left:4px;font-size:19px}
.footer-desc{font-family:var(--fB);font-size:14px;opacity:.42;line-height:1.72;max-width:260px;margin-bottom:4px}
.footer-social{display:flex;gap:8px;margin-top:20px;flex-wrap:wrap}
.footer-soc-btn{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);transition:background .18s,color .18s,border-color .18s;text-decoration:none}
.footer-soc-btn:hover{background:var(--cyan);color:var(--ink);border-color:var(--cyan)}
.footer-col-heading{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-link{font-family:var(--fB);font-size:14px;opacity:.48;display:block;transition:opacity .2s;text-decoration:none}
.footer-link:hover{opacity:1}
.footer-link-primary{font-family:var(--fD);font-size:14px;font-weight:700;color:var(--cyan);opacity:1;display:block;text-decoration:none;transition:opacity .2s,color .2s;letter-spacing:.01em}
.footer-link-primary:hover{opacity:.8;color:#fff}
.footer-contact{display:flex;flex-direction:column;gap:0}
.footer-contact-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05);text-decoration:none;transition:opacity .2s;color:inherit;opacity:.55}
.footer-contact-row:last-child{border-bottom:none}
.footer-contact-row:hover{opacity:1}
.footer-contact-row-static{cursor:default}
.fc-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-wa{background:rgba(37,211,102,.15)}.fc-ph{background:rgba(77,200,232,.12)}.fc-em{background:rgba(240,86,74,.12)}.fc-wc{background:rgba(255,255,255,.08)}
.footer-contact-text{font-family:var(--fB);font-size:13px;line-height:1.35}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:28px}
.footer-copy{font-family:var(--fD);font-size:12px;opacity:.24;text-align:center}
@media(max-width:900px){
  footer{padding:56px 32px 28px}
  /* brand row spans full width, then company + contact sit side by side below */
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px 48px}
  .footer-grid>div:first-child{grid-column:1/-1}
}
@media(max-width:600px){
  footer{padding:48px 20px 24px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-grid>div:first-child{grid-column:auto}
}

/* ── ANIMATION ───────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.anim-left{animation:fadeUp .6s ease both}
.anim-right{animation:fadeUp .6s .13s ease both}

/* ── S2 RESPONSIVE ─────────────────────────────────────── */
@media(max-width:900px){
  .grid-testi{grid-template-columns:repeat(2,1fr)}
  .grid-testi .card-testi:last-child{grid-column:1/-1}
  .portrait-card{flex:1 1 50%;min-width:0}
}
@media(max-width:600px){
  .grid-testi{grid-template-columns:1fr}
  .grid-testi .card-testi:last-child{grid-column:auto}
  .card-testi{min-height:0}
  .s2-portraits{gap:16px}
  .portrait-card{flex:1 1 50%;min-width:0}
  .section-white{padding:56px 0}
  .wrap{padding:0 20px}
  .s2-youtube-frame{border-radius:var(--r4)}
  .feature-grid{grid-template-columns:1fr;gap:40px}
}

/* ── LESSON REPORT SECTION ──────────────────────────────── */
.section-lr-dark{padding:88px 0;background:var(--navy);color:#fff}
.lr-content{width:100%}
.lr-h2{font-family:var(--fD);font-size:clamp(28px,3vw,42px);font-weight:800;line-height:1.1;letter-spacing:-.025em;color:#fff;margin:8px 0 20px}
.lr-h2-accent{color:var(--cyan)}

.lr-body{font-family:var(--fB);font-size:17px;opacity:.75;line-height:1.78;margin-bottom:0;max-width:640px}
.lr-features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px;padding-top:40px;border-top:1px solid rgba(255,255,255,.1)}
.lr-feature{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:24px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r8)}
.lr-icon{color:var(--cyan);flex-shrink:0;line-height:1}
.lr-feature-label{font-family:var(--fD);font-size:13px;font-weight:700;color:#fff;letter-spacing:.02em}
.lr-feature-text{font-family:var(--fB);font-size:14px;color:rgba(255,255,255,.7);line-height:1.6}
/* ── REPORT SAMPLE CARDS ─────────────────────────────────── */
.section-report-cards{padding:80px 0;background:var(--off-white)}
.report-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.report-card{background:#fff;border:1px solid var(--rule);border-radius:var(--r8);display:flex;flex-direction:column;overflow:hidden}
.rc-header{padding:24px 24px 20px;border-bottom:1px solid var(--rule)}
.rc-meta-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.rc-level{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:var(--rpill)}
.rc-level-cyan{background:var(--cyan);color:var(--navy)}
.rc-level-coral{background:var(--coral);color:#fff}
.rc-level-yellow{background:var(--yellow);color:var(--navy)}
.rc-lang{font-family:var(--fD);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);opacity:.6}
.rc-title{font-family:var(--fD);font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-bottom:8px}
.rc-subject{font-family:var(--fB);font-size:12px;color:var(--grey);display:flex;align-items:flex-start;gap:6px;line-height:1.5;margin-bottom:14px}
.rc-subject svg{flex-shrink:0;margin-top:2px;opacity:.5}
.rc-tags{display:flex;flex-wrap:wrap;gap:6px}
.rc-tag{font-family:var(--fD);font-size:11px;font-weight:600;color:var(--ink);opacity:.65;background:var(--off-white);border:1px solid var(--rule);border-radius:var(--rpill);padding:3px 10px}
.rc-preview{padding:20px 24px;flex:1}
.rc-preview-text{font-family:var(--fB);font-size:13.5px;line-height:1.72;color:var(--ink);opacity:.72}
.rc-read-link{display:block;padding:14px 24px;font-family:var(--fD);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);text-decoration:none;border-top:1px solid var(--rule);transition:background .15s,color .15s}
.rc-read-link:hover{background:var(--navy);color:#fff}
.rc-cta-row{text-align:center;padding-top:8px}
/* equal preview height on desktop so cards align at footer */
.rc-preview{padding:20px 24px;flex:1;min-height:120px}
/* report mock responsive padding */
.rc-section-head{margin-bottom:36px}
/* ── LESSON REPORT RESPONSIVE ────────────────────────────── */
@media(max-width:900px){
  .lr-features{grid-template-columns:repeat(2,1fr)}
  .lr-features .lr-feature:last-child{grid-column:1/-1}
  .report-card-grid{grid-template-columns:repeat(2,1fr)}
  .report-card-grid .report-card:last-child{grid-column:1/-1}
}
@media(max-width:600px){
  .section-lr-dark{padding:52px 0}
  .section-report-cards{padding:52px 0}
  .lr-features{grid-template-columns:1fr;margin-top:32px;padding-top:28px}
  .lr-features .lr-feature:last-child{grid-column:auto}
  .lr-feature{padding:18px}
  .lr-h2{font-size:clamp(24px,7vw,34px)}
  .lr-body{font-size:16px}
  .report-card-grid{grid-template-columns:1fr}
  .report-card-grid .report-card:last-child{grid-column:auto}
}

/* ── S3 RESPONSIVE ──────────────────────────────────────── */
@media(max-width:900px){
  .grid-usp{grid-template-columns:repeat(2,1fr)}
  .grid-usp .card-usp:last-child{grid-column:1/-1}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .competence-ph{flex-direction:column;align-items:flex-start}
}
@media(max-width:600px){
  .section-light{padding:52px 0}
  .grid-usp{grid-template-columns:1fr}
  .grid-usp .card-usp:last-child{grid-column:auto}
  .card-usp{min-height:0}
  .blog-grid{grid-template-columns:1fr}
  .competence-ph{padding:24px}
}

/* ── S5 BOOK A LESSON ──────────────────────────────────── */
.section-book{background:var(--white);padding:96px 0;position:relative;overflow:hidden}
.section-book::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(to right,var(--navy) 0%,var(--cyan) 55%,var(--yellow) 100%)}
.book-inner{max-width:var(--max);margin:0 auto;padding:0 48px;text-align:center}
.book-eyebrow{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--grey);display:block;margin-bottom:16px}
.book-h2{font-family:var(--fD);font-size:clamp(32px,4vw,56px);font-weight:900;letter-spacing:-.04em;line-height:1.05;color:var(--ink);margin-bottom:16px}
.book-body{font-family:var(--fB);font-size:18px;color:var(--grey);max-width:560px;margin:0 auto 40px;line-height:1.7}
.book-btn{display:inline-flex;align-items:center;gap:10px;background:var(--navy);color:#fff;font-family:var(--fD);font-size:17px;font-weight:700;letter-spacing:.02em;padding:18px 52px;border-radius:var(--r4);text-decoration:none;transition:background .2s,transform .15s;margin-bottom:72px}
.book-btn:hover{background:var(--cyan);color:var(--navy);transform:translateY(-2px)}
.book-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:0}
.book-step{padding:24px;text-align:left;background:var(--white);border:1px solid var(--rule);border-radius:var(--r8);border-top:4px solid var(--cyan);transition:transform .18s,box-shadow .18s}
.book-step:nth-child(2){border-top-color:var(--coral)}
.book-step:nth-child(3){border-top-color:var(--yellow)}
.book-step:hover{transform:translateY(-3px);box-shadow:0 6px 24px rgba(13,27,46,.08)}
.book-step-num{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:10px}
.book-step:nth-child(2) .book-step-num{color:var(--coral)}
.book-step:nth-child(3) .book-step-num{color:var(--yellow)}
.book-step-title{font-family:var(--fD);font-size:16px;font-weight:800;color:var(--ink);margin-bottom:7px}
.book-step-body{font-family:var(--fB);font-size:14px;color:var(--grey);line-height:1.65}

/* ── CONTACT HUB ───────────────────────────────────────── */
.contact-hub{display:grid;grid-template-columns:1fr 1fr}
.ch-left{background:var(--navy);padding:88px 48px 88px max(48px,calc((100vw - 1160px) / 2 + 48px));color:#fff}
.ch-right{background:var(--white);padding:88px max(48px,calc((100vw - 1160px) / 2 + 48px)) 88px 48px}
.ch-h2{font-family:var(--fD);font-size:clamp(26px,2.8vw,38px);font-weight:900;letter-spacing:-.03em;line-height:1.1;color:#fff;margin-bottom:12px}
.ch-body{font-family:var(--fB);font-size:16px;color:rgba(255,255,255,.65);line-height:1.72;margin-bottom:36px;max-width:360px}
.ch-book-btn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--navy);font-family:var(--fD);font-size:15px;font-weight:800;letter-spacing:.02em;padding:15px 36px;border-radius:var(--r4);text-decoration:none;transition:background .2s,transform .15s;margin-bottom:44px;white-space:nowrap}
.ch-book-btn:hover{background:var(--cyan);transform:translateY(-1px)}
.ch-divider{height:1px;background:rgba(255,255,255,.1);margin-bottom:32px}
.ch-channels{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.ch-channel{display:flex;align-items:center;gap:14px;font-family:var(--fB);font-size:15px;color:rgba(255,255,255,.75);text-decoration:none;transition:color .18s}
.ch-channel:hover{color:#fff}
.ch-channel-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ch-icon-wa{background:#25D366}
.ch-icon-wc{background:rgba(255,255,255,.12)}
.ch-icon-ph{background:rgba(255,255,255,.12)}
.ch-icon-em{background:rgba(255,255,255,.12)}
.ch-social{display:flex;gap:10px;margin-top:4px}
.ch-soc-btn{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);transition:background .18s,color .18s,border-color .18s;text-decoration:none}
.ch-soc-btn:hover{background:var(--cyan);color:var(--navy);border-color:var(--cyan)}
.ch-form-h2{font-family:var(--fD);font-size:clamp(26px,2.8vw,38px);font-weight:800;letter-spacing:-.025em;color:var(--ink);margin-bottom:10px}
.ch-form-sub{font-family:var(--fB);font-size:17px;color:var(--grey);margin-bottom:36px;line-height:1.72;max-width:480px}

/* ── SVG SOCIAL ICONS (About section) ──────────────────── */
.social-icon-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;color:var(--grey);transition:background .18s,color .18s,border-color .18s;text-decoration:none}
.social-icon-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.social-icons{display:flex;gap:10px;margin-top:24px}

/* ── RESPONSIVE: CONTACT HUB & BOOK ────────────────────── */
@media(max-width:900px){
  .contact-hub{grid-template-columns:1fr}
  .ch-left,.ch-right{padding:64px 32px}
  .ch-body{max-width:100%}
  .book-steps{grid-template-columns:1fr;gap:14px}
  .section-book{padding:72px 0}
  .book-inner{padding:0 32px}
}
@media(max-width:600px){
  .ch-left,.ch-right{padding:52px 20px}
  .book-inner{padding:0 20px}
  .book-btn{padding:16px 28px;font-size:15px;width:100%;justify-content:center;margin-bottom:48px}
  .book-body{font-size:16px}
  .ch-book-btn{width:100%;justify-content:center}
  .book-h2{letter-spacing:-.03em}
  .ch-channels{gap:12px}
}

/* ── FORMS (design system) ─────────────────────────────── */
.form-group{margin-bottom:22px}
.form-label{font-family:var(--fD);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:.55;display:block;margin-bottom:7px}
.form-input,.form-textarea,.form-select{width:100%;padding:13px 16px;font-family:var(--fB);font-size:15px;font-weight:400;color:var(--ink);background:var(--off-white);border:1px solid var(--rule);border-radius:var(--r4);transition:border-color .2s,background .2s;outline:none;-webkit-appearance:none;appearance:none;display:block}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--cyan);background:var(--white)}
.form-textarea{min-height:130px;resize:vertical}
.form-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='%2378818F' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}
.form-submit{width:100%;padding:15px;background:var(--navy);color:#fff;font-family:var(--fD);font-size:15px;font-weight:700;letter-spacing:.02em;border:none;border-radius:var(--r4);cursor:pointer;transition:background .2s,transform .15s;margin-top:4px}
.form-submit:hover{background:var(--cyan);color:var(--navy);transform:translateY(-1px)}

/* ── MOBILE FIXES (comprehensive) ───────────────────────── */

/* Trust bar — reduce side padding on mobile */
@media(max-width:900px){
  .trust-bar{padding:20px 24px}
  .trust-pills-row{gap:6px}
}
@media(max-width:600px){
  .trust-bar{padding:16px 16px}
  .trust-pill{font-size:11px;padding:5px 12px;flex:0 0 calc(50% - 4px);text-align:center;justify-content:center;display:inline-flex;align-items:center}
  .trust-pills-row{flex-wrap:wrap;justify-content:center;gap:8px}
}

/* Section dark — missing mobile padding reduction */
@media(max-width:900px){
  .section-dark{padding:64px 0}
}
@media(max-width:600px){
  .section-dark{padding:48px 0}
}

/* CTA band — fix nowrap overflow, reduce padding, stack on mobile */
@media(max-width:900px){
  .cta-section{padding:72px 32px}
  .cta-inner{flex-wrap:wrap;gap:32px}
  .cta-buttons{flex-shrink:1}
}
@media(max-width:600px){
  .cta-section{padding:52px 20px}
  .cta-inner{flex-direction:column;align-items:flex-start;gap:24px}
  .cta-buttons{flex-direction:column;width:100%}
  .btn-white,.btn-outline-white{width:100%;text-align:center;justify-content:center}
}

/* Price calculator — reduce padding, stack cards on small screens */
@media(max-width:900px){
  .calc-outer{padding:28px}
}
@media(max-width:600px){
  .calc-outer{padding:20px 16px;border-radius:var(--r4)}
  .calc-cards{grid-template-columns:1fr}
  .calc-footer{flex-direction:column;gap:14px;align-items:stretch}
  .calc-next{padding:14px;width:100%}
  .calc-back{text-align:center}
  .calc-heading{font-size:22px}
}

/* Section white — ensure consistent padding on mobile */
@media(max-width:900px){
  .section-white{padding:64px 0}
}

/* Wrap — ensure correct padding at 900px breakpoint */
@media(max-width:900px){
  .wrap{padding:0 32px}
}

/* Portrait cards — override old fixed-width rules */
@media(max-width:900px){
  .s2-portraits{gap:0;flex-wrap:nowrap;width:100%}
  .portrait-card{flex:1 1 50%;min-width:0;width:auto;max-width:none}
}
@media(max-width:600px){
  .s2-portraits{gap:0}
  .portrait-card{flex:1 1 50%;min-width:0;width:auto;max-width:none}
}

/* Section head — reduce bottom margin on mobile */
@media(max-width:600px){
  .section-head{margin-bottom:28px}
  .section-h2{font-size:clamp(24px,7vw,34px)}
  .section-intro{font-size:15px}
}

/* USP cards — ensure no overflow on small screens */
@media(max-width:600px){
  .card-usp-h3{font-size:17px}
}

/* Cycle strip — fix margin on mobile wrap */
@media(max-width:900px){
  .cycle-strip{margin:0 -32px;margin-bottom:56px}
}
@media(max-width:600px){
  .cycle-strip{margin:0 -20px;margin-bottom:48px}
}
