:root{
  --bg:#0A0D12;
  --bg-2:#0F141B;
  --bg-3:#1A2230;
  --panel: rgba(255,255,255,0.035);
  --panel-2: rgba(255,255,255,0.05);
  --hair: rgba(236,234,228,0.10);
  --hair-strong: rgba(236,234,228,0.18);
  --ink:#ECEAE4;
  --ink-soft: rgba(236,234,228,0.66);
  /* --ink-muted: accessible muted label tone (>=4.5:1 on the dark bg); use for small UPPERCASE labels + legal text */
  --ink-muted: rgba(236,234,228,0.62);
  --ink-faint: rgba(236,234,228,0.42);
  /* Warm accent system — ONE hue family (gold-brass).
     --copper / --copper-2: solid accent (eyebrows, CTA, lines, hero, hover).
     --copper-tint / --copper-tint-line: low-alpha washes for frames, icon chips, highlighted cards. */
  --copper:#C7A867;
  --copper-2:#B0904E;
  --copper-rgb:199,168,103;
  --copper-tint: rgba(199,168,103,0.16);
  --copper-tint-line: rgba(199,168,103,0.34);
  --copper-glow: rgba(199,168,103,0.40);
  /* Radius scale — deliberate ramp (no per-component drift).
     --r-card: every content card shares this — feature/benefit cards (.card)
       AND comparison cards (.tl-col).
     --r-panel: larger surfaces (asides, member cards, avatars, how-viz).
     --r-band: the largest, reserved for full-width bands (contact CTA, gate, cgt). */
  --r-card:16px;
  --r-panel:20px;
  --r-band:24px;
  --display:'Inter Tight', system-ui, sans-serif;
  --sans:'Inter', system-ui, -apple-system, sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:75px}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

/* ---------- A11Y: focus rings + skip link ---------- */
/* on-brand copper focus ring for every keyboard-focusable element */
.skip-link:focus-visible,
.nav-links a.lnk:focus-visible,
.brand:focus-visible,
.hamburger:focus-visible,
.mobile-menu a:focus-visible,
.faq-q:focus-visible,
.footer-nav a:focus-visible,
.footer-cta a.brand:focus-visible,
.footer-bottom a:focus-visible{
  outline:2px solid var(--copper);
  outline-offset:3px;
  border-radius:4px;
}
/* keep the underline link's ring hugging the text */
.nav-links a.lnk:focus-visible{outline-offset:5px}
.faq-q:focus-visible{outline-offset:-2px}

/* visually-hidden (kept in the a11y tree / heading outline, hidden on screen) */
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}

/* skip to content — visually hidden until focused */
.skip-link{
  position:fixed;top:14px;left:14px;z-index:300;
  transform:translateY(-150%);
  padding:12px 20px;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:14px;
  background:linear-gradient(135deg,var(--copper),var(--copper-2));
  color:#0A0D12;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 6px 24px -8px var(--copper-glow), inset 0 1px 0 rgba(255,255,255,.35);
  transition:transform .25s var(--ease);
}
.skip-link:focus{transform:translateY(0)}
main:focus{outline:none}
@media (prefers-reduced-motion:reduce){.skip-link{transition:none}}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--copper);color:#0A0D12}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* film grain overlay */
body::after{
  content:"";
  position:fixed;inset:0;z-index:1;pointer-events:none;
  opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}
.eyebrow{
  font-family:var(--sans);
  font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper-2);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--copper),transparent)}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.05;letter-spacing:-.02em}
.section{padding:120px 0;position:relative}
/* --- vertical rhythm between adjacent sections --- */
/* credentials strip already carries its own 46px band + hairlines; pull the team in */
#team{padding-top:84px}
/* FAQ closes into the CTA band; collapse the stacked section paddings */
#faq{padding-bottom:88px}
#contact{padding-top:64px;padding-bottom:104px}
.section-head{max-width:760px;margin-bottom:56px}
.section-head h2{font-size:clamp(2rem,4.4vw,3.3rem);margin-top:18px;color:var(--ink)}
.lead{color:var(--ink-soft);font-size:1.18rem;margin-top:20px;max-width:640px}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,13,18,0.6);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--hair);
}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:600;font-size:1.05rem;letter-spacing:-.01em}
.brand .brand-logo{height:38px;width:auto;flex:none}
.brand b{font-weight:600}
.brand span.sub{color:var(--ink-soft);font-weight:500;letter-spacing:.04em}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.lnk{font-size:14px;color:var(--ink-soft);transition:color .25s;position:relative}
.nav-links a.lnk:hover{color:var(--ink)}
.nav-links a.lnk::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--copper);transition:width .3s var(--ease)}
.nav-links a.lnk:hover::after{width:100%}

.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.01em;
  padding:12px 22px;border-radius:999px;cursor:pointer;
  background:linear-gradient(135deg,var(--copper),var(--copper-2));
  color:#0A0D12;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 6px 24px -8px var(--copper-glow), inset 0 1px 0 rgba(255,255,255,.35);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 34px -8px var(--copper-glow), inset 0 1px 0 rgba(255,255,255,.4)}
.btn:focus-visible{outline:2px solid var(--copper);outline-offset:3px}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
.btn.lg{padding:16px 30px;font-size:15px}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--hair-strong);box-shadow:none}
.btn.ghost:hover{border-color:var(--copper);box-shadow:0 0 0 1px var(--copper-glow)}
.btn.sm{padding:9px 16px;font-size:13px}

/* Mobile/tablet header actions (hamburger + compact CTA) */
.nav-mobile-actions{display:none;align-items:center;gap:12px}
.nav-tablet-cta{display:none}

.hamburger{display:none;width:44px;height:44px;border-radius:10px;border:1px solid var(--hair);background:var(--panel);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;flex:none}
.hamburger span{width:18px;height:1.5px;background:var(--ink);transition:.3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:0;z-index:49;background:rgba(10,13,18,0.95);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  display:flex;flex-direction:column;justify-content:center;gap:24px;
  padding:96px 36px calc(40px + env(safe-area-inset-bottom));
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .4s var(--ease), visibility 0s linear .4s;
}
.mobile-menu.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .4s var(--ease)}
.mobile-menu-links{display:flex;flex-direction:column}
.mobile-menu-links a{font-family:var(--display);font-size:1.7rem;font-weight:500;color:var(--ink-soft);padding:16px 0;border-bottom:1px solid var(--hair);transition:color .25s}
.mobile-menu-links a:hover{color:var(--ink)}
.mobile-menu .mobile-menu-cta{align-self:flex-start}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding-top:74px}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 80% at 70% 10%, transparent 38%, rgba(10,13,18,.40) 100%),
    linear-gradient(180deg, rgba(10,13,18,.35) 0%, transparent 22%, transparent 60%, rgba(10,13,18,.92) 100%);
}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%}
.hero h1{font-size:clamp(2.7rem,7.4vw,5.6rem);max-width:14ch;line-height:1.0;margin:26px 0 0}
.hero h1 .accent{
  background:linear-gradient(100deg,var(--copper) 0%,var(--copper-2) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-sub{font-size:clamp(1.1rem,1.9vw,1.4rem);color:var(--ink-soft);max-width:38ch;margin:28px 0 40px;line-height:1.5}
/* hero CTA: only shown once the nav minimises (<=768px), where the header
   Book button is collapsed behind the hamburger. Hidden on desktop. */
.hero-cta{display:none;flex-wrap:wrap;gap:16px;align-items:center}
.hero-scroll{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:3;color:var(--ink-faint);font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}
.hero-scroll .line{margin-left:1px}
.hero-scroll .line{width:1px;height:40px;background:linear-gradient(var(--copper),transparent);position:relative;overflow:hidden}
.hero-scroll .line::after{content:"";position:absolute;top:-40px;left:0;width:1px;height:40px;background:var(--copper);animation:drop 2.4s var(--ease) infinite}
@keyframes drop{0%{top:-40px}60%,100%{top:40px}}

/* ---------- CREDENTIAL STRIP ---------- */
.cred{padding:46px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:rgba(15,20,27,.4)}
.cred-inner{display:flex;align-items:center;gap:48px;flex-wrap:wrap;justify-content:center}
.cred-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);font-weight:600}
.cred-logos{display:flex;align-items:center;gap:40px;flex-wrap:wrap;justify-content:center}
.cred-logos .lg{font-family:var(--display);font-size:1.35rem;font-weight:600;letter-spacing:.01em;color:var(--ink-soft);opacity:.85;transition:color .3s,opacity .3s;display:flex;align-items:center;gap:10px}
.cred-logos .lg:hover{color:var(--ink);opacity:1}
.cred-logos .dot{width:4px;height:4px;border-radius:50%;background:var(--copper);opacity:.6}

/* ---------- CREDENTIAL LOGOS ---------- */
/* optically normalized: same greyscale treatment + opacity, cap-heights tuned so no mark dominates */
.cred-logos .cred-logo{width:auto;opacity:.62;filter:brightness(0) invert(1);transition:opacity .3s var(--ease)}
.cred-logos .cred-logo:hover{opacity:.95}
.cred-logo--oxford{height:30px}
.cred-logo--imperial{height:15px}
.cred-logo--nhs{height:26px}
.cred-logo--roche{height:34px}
@media(max-width:560px){.cred-logo--oxford{height:24px}.cred-logo--imperial{height:12px}.cred-logo--nhs{height:21px}.cred-logo--roche{height:28px}}

/* ---------- PROBLEM ---------- */
.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.problem-body p{color:var(--ink-soft);font-size:1.15rem;margin-bottom:22px;max-width:54ch}
.problem-body p:last-child{margin-bottom:0}
.problem-aside{
  position:relative;border-radius:var(--r-panel);padding:40px;
  background:var(--panel);border:1px solid var(--hair);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);overflow:hidden;
}
.problem-aside::before{content:"";position:absolute;top:-40%;right:-30%;width:80%;height:120%;background:radial-gradient(circle,var(--copper-glow),transparent 70%);opacity:.5;filter:blur(20px)}
.problem-aside .big{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;line-height:1.04;position:relative;letter-spacing:-.02em}
.problem-aside .cap{color:var(--ink-faint);font-size:14px;margin-top:18px;position:relative}

/* ---------- CARDS GRID ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.card{
  position:relative;border-radius:var(--r-card);padding:22px 20px 24px;
  background:var(--panel);border:1px solid var(--hair);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  transition:transform .4s var(--ease), border-color .4s var(--ease), background .4s var(--ease);
  overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0;border-radius:var(--r-card);padding:1px;background:linear-gradient(135deg,var(--copper-glow),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s var(--ease);pointer-events:none}
.card:hover{transform:translateY(-5px);border-color:var(--hair-strong);background:var(--panel-2)}
.card:hover::before{opacity:1}
.card .num{font-family:var(--display);font-size:13px;font-weight:600;color:var(--copper-2);letter-spacing:.05em;margin-bottom:16px;display:block}
.card h3{font-size:1.04rem;margin-bottom:8px;color:var(--ink);letter-spacing:-.01em}
.card p{color:var(--ink-soft);font-size:.9rem;line-height:1.5}
#deliver{padding:84px 0}

/* ---------- HOW WE WORK (showpiece) ---------- */
#how{background:linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 50%, var(--bg) 100%)}
.how-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.how-body p{color:var(--ink-soft);font-size:1.16rem;margin-bottom:22px;max-width:52ch}
.how-viz{
  position:relative;border-radius:var(--r-panel);padding:42px 38px;
  background:linear-gradient(160deg,rgba(26,34,48,.6),rgba(15,20,27,.4));
  border:1px solid var(--hair);overflow:hidden;
  box-shadow:0 30px 80px -40px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.06);
}
.how-viz::after{content:"";position:absolute;bottom:-50%;left:-20%;width:90%;height:120%;background:radial-gradient(circle,var(--copper-glow),transparent 65%);opacity:.4;filter:blur(30px)}
.split{position:relative;z-index:2}
.split-row{margin-bottom:26px}
.split-row .tag{font-family:var(--display);font-size:13px;letter-spacing:.05em;color:var(--ink-faint);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.split-row .tag b{color:var(--ink);font-weight:600}
.bar{height:14px;border-radius:8px;background:rgba(236,234,228,.07);overflow:hidden;position:relative}
.bar i{position:absolute;left:0;top:0;bottom:0;width:0;border-radius:8px;transition:width 1.3s var(--ease)}
.bar.mech i{background:linear-gradient(90deg,var(--copper),var(--copper-2));box-shadow:0 0 18px var(--copper-glow)}
.bar.judge i{background:linear-gradient(90deg,rgba(236,234,228,.5),rgba(236,234,228,.85))}
.split.in .bar.mech i{width:80%}
.split.in .bar.judge i{width:20%}
.split-foot{font-size:13px;color:var(--ink-faint);margin-top:22px;padding-top:22px;border-top:1px solid var(--hair);line-height:1.5}

/* pull quote */
.quote{
  position:relative;margin:64px auto 0;max-width:860px;text-align:center;padding:48px 20px 0;
}
.quote q{font-family:var(--display);font-size:clamp(1.4rem,3vw,2.1rem);font-weight:500;line-height:1.3;letter-spacing:-.01em;color:var(--ink);quotes:none;display:block}
.quote .mark{font-family:var(--display);font-size:4rem;color:var(--copper);line-height:0;opacity:.5;margin-bottom:8px}
.quote cite{display:block;margin-top:26px;font-style:normal;color:var(--ink-soft);font-size:.98rem}
.quote cite b{color:var(--ink)}

/* ---------- TEAM (showpiece) ---------- */
.team-stat{
  text-align:center;margin:0 auto 56px;max-width:720px;
}
.team-stat .figure{font-family:var(--display);font-size:clamp(3rem,8vw,5.5rem);font-weight:600;line-height:1;letter-spacing:-.03em;
  background:linear-gradient(120deg,var(--ink),var(--copper) 140%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.team-stat .cap{color:var(--ink-soft);font-size:1.1rem;margin-top:14px}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.member{
  position:relative;border-radius:var(--r-panel);padding:38px 34px;
  background:linear-gradient(165deg,rgba(26,34,48,.5),rgba(15,20,27,.35));
  border:1px solid var(--hair);overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .4s var(--ease),border-color .4s var(--ease);
}
.member:hover{transform:translateY(-5px);border-color:var(--hair-strong)}
.member::before{content:"";position:absolute;top:-30%;right:-20%;width:60%;height:80%;background:radial-gradient(circle,var(--copper-glow),transparent 70%);opacity:.35;filter:blur(24px)}
.member-head{display:flex;align-items:center;gap:18px;margin-bottom:22px;position:relative}
.avatar{
  width:92px;height:92px;aspect-ratio:1/1;border-radius:var(--r-panel);flex:none;display:grid;place-items:center;overflow:hidden;box-sizing:border-box;
  font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--ink);
  background:linear-gradient(150deg,rgba(var(--copper-rgb),.28),rgba(26,34,48,.6));
  border:1px solid var(--hair-strong);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 8px 24px -10px rgba(0,0,0,.7);
}
.member-head h3{font-size:1.22rem;letter-spacing:-.01em;margin-bottom:4px}
.member-head .role{color:var(--copper-2);font-size:.9rem;font-weight:500;font-family:var(--sans)}
.member p{color:var(--ink-soft);font-size:1rem;line-height:1.6;position:relative}
.avatar img{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;object-position:50% 22%;filter:grayscale(1) contrast(1.05);display:block}
.member-bio{list-style:none;margin-top:4px}
.member-bio li{color:var(--ink-soft);font-size:.96rem;line-height:1.5;padding-left:18px;position:relative;margin-bottom:9px}
.member-bio li:last-child{margin-bottom:0}
.member-bio li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:1.5px;background:var(--copper-2)}

/* team avatars — both variants share one consistent frame + box */
.avatar--light,.avatar--frame{background:#fff;border:1px solid var(--hair-strong)}
.member h3{font-size:1.22rem;letter-spacing:-.01em;margin:0}
.member-bio{margin-top:18px}
/* team head now has only the eyebrow (h2 is visually hidden), so tighten the
   gap to the 40+ years stat — some space, not the full 56px section gap. */
#team .section-head{margin-bottom:24px}
#deliver .section-head{text-align:center;margin-left:auto;margin-right:auto}
#deliver .section-head .eyebrow{justify-content:center}
#deliver .lead{margin-left:auto;margin-right:auto}
/* deliver timeline */
.timeline{display:grid;grid-template-columns:1fr auto 1fr;gap:26px;align-items:stretch;max-width:840px;margin:0 auto 22px;text-align:center}
.timeline-note{max-width:840px;margin:0 auto;text-align:center;font-style:italic;color:var(--ink-faint);font-size:.85rem;line-height:1.45}
.tl-col{display:flex;flex-direction:column;padding:30px 26px;border-radius:var(--r-card);background:var(--panel);border:1px solid var(--hair)}
.tl-col--new{background:linear-gradient(160deg,var(--copper-tint),rgba(26,34,48,.4));border-color:var(--copper-tint-line)}
.tl-tag{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);font-weight:600}
.tl-fig{font-family:var(--display);font-size:clamp(2.6rem,6vw,4rem);font-weight:600;line-height:1;margin:12px 0 14px;letter-spacing:-.02em;color:var(--ink);white-space:nowrap}
.tl-col--new .tl-fig{background:linear-gradient(120deg,var(--ink),var(--copper) 150%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.tl-col p{color:var(--ink-soft);font-size:.95rem;line-height:1.5}
.tl-sep{display:flex;align-items:center;justify-content:center}
.tl-sep span{display:block;width:30px;height:1px;background:var(--copper);position:relative}
.tl-sep span::after{content:"";position:absolute;right:-1px;top:-3px;width:7px;height:7px;border-top:1px solid var(--copper);border-right:1px solid var(--copper);transform:rotate(45deg)}
#deliver .cards{grid-template-columns:repeat(3,1fr)}
@media(max-width:780px){.timeline{grid-template-columns:1fr;gap:14px}.tl-sep span{transform:rotate(90deg)}#deliver .cards{grid-template-columns:1fr}}

/* ---------- CGT ---------- */
#cgt{position:relative;overflow:hidden}
.cgt-wrap{position:relative;border-radius:var(--r-band);padding:clamp(40px,6vw,80px);overflow:hidden;
  background:linear-gradient(150deg,var(--bg-3),var(--bg-2));border:1px solid var(--hair);
  box-shadow:0 40px 100px -50px rgba(0,0,0,.9)}
.cgt-wrap::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 85% 0%,var(--copper-glow),transparent 55%);opacity:.5}
.cgt-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.cgt-grid h2{font-size:clamp(2rem,4.6vw,3.4rem);margin-top:18px}
.cgt-body p{color:var(--ink-soft);font-size:1.16rem;margin-bottom:20px;max-width:50ch}
.cgt-mark{display:flex;align-items:center;justify-content:center}
.cgt-mark svg{width:min(320px,80%);height:auto;opacity:.9}

/* ---------- TRUST ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.trust-card{
  position:relative;border-radius:var(--r-card);padding:26px 22px 28px;
  background:var(--panel);border:1px solid var(--hair);overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease);
}
.trust-card:hover{transform:translateY(-4px);border-color:var(--hair-strong);background:var(--panel-2)}
.trust-card .ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(150deg,rgba(var(--copper-rgb),.22),transparent);border:1px solid var(--hair);}
.trust-card .ic svg{width:18px;height:18px;stroke:var(--copper-2)}
.trust-card h3{font-size:1.02rem;margin-bottom:10px;letter-spacing:-.01em}
.trust-card p{color:var(--ink-soft);font-size:.9rem;line-height:1.5}
.trust-foot{margin-top:28px;font-size:12.5px;color:var(--ink-faint)}

/* ---------- FAQ ---------- */
.faq-list{max-width:860px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--hair)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;color:var(--ink);
  font-family:var(--display);font-size:clamp(1.1rem,2.2vw,1.45rem);font-weight:500;letter-spacing:-.01em;
  padding:28px 50px 28px 0;position:relative;display:block;transition:color .3s}
.faq-q:hover{color:var(--copper-2)}
.faq-q::after{content:"";position:absolute;right:6px;top:50%;width:14px;height:14px;
  background:
   linear-gradient(var(--ink),var(--ink)) center/14px 1.5px no-repeat,
   linear-gradient(var(--ink),var(--ink)) center/1.5px 14px no-repeat;
  transform:translateY(-50%);transition:opacity .3s}
.faq-item.open .faq-q::after{
  background:linear-gradient(var(--copper),var(--copper)) center/14px 1.5px no-repeat}
.faq-a{display:grid;grid-template-rows:0fr;visibility:hidden;
  transition:grid-template-rows .5s var(--ease),visibility 0s linear .5s,opacity .4s}
.faq-a-inner{overflow:hidden;padding:0 50px 0 0;color:var(--ink-soft);font-size:1.05rem;line-height:1.65;max-width:64ch}
.faq-item.open .faq-a{grid-template-rows:1fr;visibility:visible;
  transition:grid-template-rows .5s var(--ease),visibility 0s,opacity .4s}
.faq-item.open .faq-a-inner{padding-bottom:30px}

/* ---------- CLOSING CTA ---------- */
#contact{position:relative;overflow:hidden}
.cta-band{position:relative;border-radius:var(--r-band);padding:clamp(50px,8vw,96px) clamp(32px,5vw,60px);text-align:left;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:56px;
  background:linear-gradient(150deg,var(--bg-3),var(--bg));border:1px solid var(--hair-strong);
  box-shadow:0 40px 120px -50px rgba(0,0,0,.9)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 100% at 50% 120%,var(--copper-glow),transparent 60%);opacity:.6}
.cta-band-text{position:relative;flex:1 1 auto;min-width:0}
.cta-band h2{position:relative;font-size:clamp(2.2rem,5.5vw,4rem);margin:0}
.cta-band h2 .cta-q{display:block;margin-top:.5em}
.cta-band p{position:relative;color:var(--ink-soft);font-size:1.18rem;margin:24px 0 0;max-width:48ch}
.cta-band .btn{position:relative;flex:0 0 auto}
@media (max-width:760px){.cta-band{flex-direction:column;align-items:flex-start;gap:32px}}

/* ---------- FOOTER ---------- */
.footer{border-top:1px solid var(--hair);padding:64px 0 44px;background:var(--bg-2)}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px 56px;flex-wrap:wrap;margin-bottom:36px}
.footer-cta{display:flex;flex-direction:column;align-items:flex-start;gap:16px}
.footer-nav{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.footer-nav a{color:var(--ink-soft);font-size:.96rem;transition:color .25s}
.footer-nav a:hover{color:var(--copper-2)}
.footer-book{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:.96rem;color:var(--copper-2);transition:color .25s,transform .3s var(--ease)}
.footer-book:hover{color:var(--copper)}
.footer-book .arr{transition:transform .3s var(--ease)}
.footer-book:hover .arr{transform:translateX(3px)}
.footer-bottom{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center;padding-top:28px;border-top:1px solid var(--hair);color:var(--ink-muted);font-size:.86rem}
.footer-bottom a{color:var(--ink-soft);transition:color .25s}
.footer-bottom a:hover{color:var(--copper-2)}
.footer-contact{display:flex;gap:22px;flex-wrap:wrap;align-items:center}

/* ---------- REVEAL ----------
   Fail-safe: default resting state is VISIBLE so content shows even if JS or
   the IntersectionObserver never runs. The hidden/animated start state is only
   applied once JS confirms it can run (html.js) and is skipped under
   prefers-reduced-motion. Only transform/opacity/filter animate, so the reveal
   never changes document height (no layout jank). */
.reveal{opacity:1;transform:none;filter:none;transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
html.js .reveal{opacity:0;transform:translateY(26px);filter:blur(6px)}
html.js .reveal.in{opacity:1;transform:none;filter:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}.reveal.d6{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;filter:none;transition:none}
  .hero-scroll .line::after{animation:none}}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .problem-grid,.how-grid,.team-grid,.cgt-grid{grid-template-columns:1fr;gap:40px}
  .cgt-mark{order:-1}
}
@media (max-width:768px){
  body{font-size:16px}
  .section{padding:84px 0}
  /* keep the tightened rhythm proportional on mobile */
  #team{padding-top:60px}
  #faq{padding-bottom:64px}
  #contact{padding-top:48px;padding-bottom:72px}
  .nav-links{display:none}
  .nav-mobile-actions{display:flex}
  .nav-tablet-cta{display:inline-flex}
  .hamburger{display:flex}
  .hero h1{font-size:clamp(2.4rem,11vw,3.4rem)}
  .hero-cta{display:flex}
}
/* Below the tablet CTA's comfortable width, drop the compact header CTA
   (still reachable inside the menu) */
@media (max-width:420px){
  .nav-tablet-cta{display:none}
}
/* LOCKOUT GUARD: force-hide the mobile menu on desktop regardless of state */
@media (min-width:769px){
  .mobile-menu,
  .mobile-menu.open{
    display:none !important;visibility:hidden !important;
    opacity:0 !important;pointer-events:none !important;
  }
  .nav-mobile-actions{display:none}
}
@media (max-width:560px){
  .wrap{padding:0 20px}
  .cards{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .cred-inner{gap:24px}
  .cred-logos{gap:20px}
  .nav-inner{padding:0 20px}
  /* team: stack avatar above name so names read cleanly without cramped wrapping */
  .member-head{flex-direction:column;align-items:flex-start;gap:14px}
  .member-head h3{width:100%}
}

/* ---------- PASSWORD GATE ---------- */
.cmc-gate{display:none}
html.cmc-locked .cmc-page{display:none !important}
html.cmc-locked .cmc-gate{display:flex}
.cmc-gate{position:fixed;inset:0;z-index:200;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 90% at 70% 0%, var(--bg-3), var(--bg) 72%)}
.cmc-gate__card{width:100%;max-width:390px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;
  padding:46px 38px;border-radius:var(--r-band);
  background:linear-gradient(165deg,rgba(26,34,48,.6),rgba(15,20,27,.5));
  border:1px solid var(--hair);box-shadow:0 40px 100px -50px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.06)}
.cmc-gate__brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:600;font-size:1.05rem;margin-bottom:4px}
.cmc-gate__brand img{height:34px;width:auto}
.cmc-gate__brand span{color:var(--ink-soft);font-weight:500;letter-spacing:.04em}
.cmc-gate__title{font-family:var(--display);font-size:1.5rem;font-weight:600;letter-spacing:-.01em;color:var(--ink);margin:0}
.cmc-gate__sub{color:var(--ink-soft);font-size:.95rem;margin:-4px 0 4px}
.cmc-gate__input{width:100%;padding:14px 16px;border-radius:12px;background:rgba(10,13,18,.6);
  border:1px solid var(--hair-strong);color:var(--ink);font-family:var(--sans);font-size:1rem;text-align:center;letter-spacing:.04em;
  transition:border-color .25s, box-shadow .25s}
.cmc-gate__input:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 3px var(--copper-glow)}
.cmc-gate__btn{width:100%;justify-content:center;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:600;font-size:14px;padding:13px 22px;border-radius:999px;cursor:pointer;
  background:linear-gradient(135deg,var(--copper),var(--copper-2));color:#0A0D12;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 6px 24px -8px var(--copper-glow), inset 0 1px 0 rgba(255,255,255,.35);transition:transform .3s var(--ease)}
.cmc-gate__btn:hover{transform:translateY(-2px)}
.cmc-gate__btn:focus-visible{outline:2px solid var(--copper);outline-offset:3px}
.cmc-gate__error{color:#E2917A;font-size:.85rem;margin:2px 0 0}
.cmc-gate__card.shake{animation:cmcShake .42s}
@keyframes cmcShake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-7px)}40%,60%{transform:translateX(7px)}}
