:root {
  --ink: #173645;
  --muted: #667b84;
  --paper: #f8faf8;
  --line: rgba(22, 59, 72, .13);
  --mint: #c6f3e6;
  --blue: #bfdff1;
  --lavender: #d8d1f2;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

/* ── 1. Hero entrance ── */
@keyframes heroFadeUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
.hero .eyebrow { animation: heroFadeUp .7s ease .1s both; }
.hero h1 { animation: heroFadeUp .9s cubic-bezier(.2,.7,.2,1) .25s both; }
.hero-copy { animation: heroFadeUp .7s ease .5s both; }
.hero-actions { animation: heroFadeUp .7s ease .65s both; }
.page-hero .eyebrow { animation: heroFadeUp .7s ease .1s both; }
.page-hero h1 { animation: heroFadeUp .9s cubic-bezier(.2,.7,.2,1) .25s both; }
.page-hero .lead { animation: heroFadeUp .7s ease .5s both; }


/* ── 5. Proof strip stagger ── */
.proof-item:nth-child(1) { transition-delay: 0s; }
.proof-item:nth-child(2) { transition-delay: .12s; }
.proof-item:nth-child(3) { transition-delay: .24s; }
.proof-item:nth-child(4) { transition-delay: .36s; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "DM Sans", sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 68% 52% at 6% 10%, rgba(198,243,230,.3) 0%, transparent 68%),
    radial-gradient(ellipse 58% 48% at 94% 6%, rgba(216,209,242,.22) 0%, transparent 62%),
    radial-gradient(ellipse 62% 54% at 90% 96%, rgba(191,223,241,.2) 0%, transparent 66%),
    radial-gradient(ellipse 52% 44% at 10% 90%, rgba(216,209,242,.18) 0%, transparent 60%),
    radial-gradient(ellipse 44% 40% at 52% 48%, rgba(191,223,241,.08) 0%, transparent 58%);
}
a { color: inherit; text-decoration: none; }
.skip-link { position: fixed; top: -60px; left: 20px; z-index: 100; padding: 12px 18px; background: white; transition: top .2s; }
.skip-link:focus { top: 20px; }

.ribbon-stage {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 1;
  mix-blend-mode: multiply;
  overflow: clip;
  contain: strict;
}
.ribbon-stage svg { position:absolute; inset:0; width:100%; max-width:100%; height:100%; transform:none; overflow:hidden; }
#ribbonLines path {
  fill: none;
  stroke: url(#ribbonGradient);
  stroke-width: 1;
  opacity: .7;
  vector-effect: non-scaling-stroke;
  stroke-linecap: round;
}

.site-header {
  position: fixed;
  z-index: 20;
  top: 18px;
  left: 2.5vw;
  right: 2.5vw;
  min-height: 62px;
  padding: 8px 9px 8px 19px;
  display: flex;
  align-items: center;
  gap: 28px;
  border: 1px solid rgba(255,255,255,.8);
  border-radius: 18px;
  background: rgba(250,252,251,.68);
  box-shadow: 0 14px 45px rgba(49, 81, 90, .07);
  backdrop-filter: blur(28px);
}
.brand { display: flex; align-items: center; gap: 10px; text-transform: uppercase; letter-spacing: .14em; font-size: 11px; font-weight: 600; white-space: nowrap; }
.brand-logo { width: 22px; height: 22px; display: block; flex-shrink: 0; }
.header-context { margin-left:auto; display:flex; align-items:center; gap:15px; font-size:8px; text-transform:uppercase; letter-spacing:.15em; color:#718991; }
.header-context i { width:26px; height:1px; background:#a5b8bd; }
.header-briefings{font-size:8px;text-transform:uppercase;letter-spacing:.14em;color:#526f78}.header-briefings:after{content:"";display:block;width:100%;height:1px;margin-top:5px;background:#84b9b5;transform:scaleX(.25);transform-origin:left}
.header-assessment{padding:10px 14px;border:1px solid rgba(42,76,87,.14);border-radius:100px;background:rgba(255,255,255,.42);font-size:8px;text-transform:uppercase;letter-spacing:.12em;color:#526f78;transition:border-color .25s,box-shadow .25s,transform .2s,color .2s}.header-assessment:hover{border-color:rgba(117,223,196,.5);box-shadow:0 0 0 3px rgba(117,223,196,.1),0 4px 14px rgba(117,223,196,.15);transform:translateY(-1px);color:#0b2d3a}
.header-cta { padding: 12px 18px; border-radius: 100px; background: linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%); background-size:280% 280%; animation:iridescent 8s ease infinite; color: white; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; transition: box-shadow .3s ease, transform .2s ease; }
.header-cta:hover { box-shadow: 0 0 0 1.5px rgba(117,223,196,.6), 0 8px 28px rgba(117,223,196,.3); transform: translateY(-1px); }
.header-cta span { margin-left: 10px; }
.menu-toggle { width:82px;height:44px;padding:0 13px;display:grid;grid-template-columns:15px 1fr;grid-template-rows:1fr 1fr;column-gap:10px;align-items:center;border:1px solid rgba(42,76,87,.13);border-radius:100px;background:rgba(255,255,255,.62);color:var(--ink);cursor:pointer;position:relative;z-index:31; }
.menu-toggle span { width:15px;height:1px;background:var(--ink);transition:transform .35s, width .35s;align-self:end;margin-bottom:2px; }
.menu-toggle span:nth-child(2){align-self:start;margin-top:2px;width:10px}
.menu-toggle em { grid-column:2;grid-row:1/3;font-style:normal;font-size:8px;text-transform:uppercase;letter-spacing:.13em; }
.menu-toggle.active span:first-child { transform:translateY(3px) rotate(45deg); }
.menu-toggle.active span:nth-child(2) { width:15px;transform:translateY(-3px) rotate(-45deg); }
.menu-toggle.active em{font-size:0}.menu-toggle.active em:after{content:"Close";font-size:8px}
.mobile-menu { position:fixed;z-index:15;inset:0;padding:105px 2.5vw 2.5vw;opacity:0;visibility:hidden;transform:translateY(-16px);transition:opacity .45s,visibility .45s,transform .45s;background:rgba(245,251,249,.97);backdrop-filter:blur(8px);overflow:auto;touch-action:pan-y; }
.mobile-menu a { touch-action:manipulation; }
.mobile-menu::before { content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 14% 88%,rgba(94,217,181,.38),transparent 40%),radial-gradient(circle at 90% 10%,rgba(129,118,210,.28),transparent 38%),radial-gradient(circle at 60% 45%,rgba(104,175,213,.14),transparent 32%); }
.mobile-menu.open { opacity:1;visibility:visible;transform:none; }
.menu-shell{position:relative;min-height:calc(100vh - 130px);padding:4vh 4vw;border:1px solid rgba(255,255,255,.9);border-radius:25px;background:rgba(255,255,255,.55);display:grid;grid-template-columns:.35fr 1fr;grid-template-rows:1fr auto;gap:3vw;box-shadow:inset 0 1px rgba(255,255,255,.9),0 2px 40px rgba(94,180,170,.08)}
.menu-heading{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;gap:0;padding-bottom:3vh;border-bottom:1px solid var(--line)}.menu-heading>span,.menu-secondary>div>span{font-size:8px;text-transform:uppercase;letter-spacing:.17em;color:#789198}.menu-heading strong{position:relative;z-index:2;font-family:"Manrope";font-size:clamp(35px,4vw,65px);font-weight:300;letter-spacing:-.06em;margin-top:auto;padding-top:2vh}
@keyframes iridescent{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.menu-pull-quote{margin:0;padding:3vh 0 0;border:none;flex:1;display:flex;align-items:center;font-family:"Manrope",sans-serif;font-size:clamp(18px,2vw,32px);font-weight:300;line-height:1.4;letter-spacing:-.025em;font-style:italic;background:linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%);background-size:280% 280%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:iridescent 8s ease infinite}
.briefing-intro h2 em{background:linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%);background-size:280% 280%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:iridescent 8s ease infinite;font-style:inherit}
.menu-primary{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
.menu-primary a{position:relative;overflow:hidden;min-height:145px;padding:20px;display:grid;grid-template-columns:38px 1fr;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .3s,transform .25s}
.menu-primary a::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--ma,#75dfc4);opacity:.5;z-index:2;transform:scaleX(.3);transform-origin:left;transition:transform .35s ease,opacity .35s}
.menu-primary a::after{content:"";position:absolute;inset:0;background:var(--ma,#75dfc4);opacity:0;transition:opacity .35s;pointer-events:none}
.menu-primary a:hover::before{transform:scaleX(1);opacity:.8}
.menu-primary a:hover::after{opacity:.08}
.menu-primary a:hover{background:rgba(255,255,255,.55)}
.menu-primary a[aria-current="page"]::after{opacity:.11}
.menu-primary a[aria-current="page"] strong{background:linear-gradient(110deg,var(--ma,#75dfc4) 10%,#2a464d 70%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.menu-primary span,.menu-primary small{position:relative;z-index:1}.menu-primary span{font-size:8px;color:#789198}.menu-primary strong{position:relative;z-index:1;font-family:"Manrope";font-size:clamp(27px,3vw,47px);font-weight:300;letter-spacing:-.055em}.menu-primary small{grid-column:2;font-size:10px;color:#6d838b}
@keyframes menuItemIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.mobile-menu .menu-primary a{opacity:0}
.mobile-menu.open .menu-primary a{animation:menuItemIn .42s ease both;animation-delay:var(--d,0s)}
.menu-secondary{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr 1.3fr;gap:5vw;padding-top:3vh}.menu-secondary>div{display:flex;flex-direction:column;gap:9px}.menu-secondary a{font-size:10px;color:#516c76;transition:color .2s,transform .2s}.menu-secondary a:hover{color:#0b2d3a;transform:translateX(3px)}
.menu-tool-badge{display:inline-flex;align-items:center;margin-left:6px;padding:2px 7px;border:1px solid rgba(83,181,174,.3);border-radius:100px;background:rgba(117,223,196,.1);font:500 7px "DM Sans";letter-spacing:.1em;text-transform:uppercase;color:#53b5ae;font-style:normal;vertical-align:middle}
.menu-featured-col{display:flex;flex-direction:column;gap:10px}
.menu-featured-card{display:flex;flex-direction:column;gap:6px;padding:16px;border:1px solid rgba(255,255,255,.88);border-radius:16px;background:linear-gradient(125deg,rgba(117,223,196,.35) 0%,rgba(104,175,213,.25) 50%,rgba(83,181,174,.32) 100%);background-size:200% 200%;animation:iridescent 9s ease infinite;transition:transform .25s}
.menu-featured-card:hover{transform:translateY(-2px)}
.menu-featured-card em{font:400 8px "DM Sans";letter-spacing:.12em;text-transform:uppercase;color:#789198;font-style:normal}
.menu-featured-card strong{font:300 15px/1.25 "Manrope";letter-spacing:-.03em;color:#2a464d}
.menu-featured-card b{font:500 8px "DM Sans";letter-spacing:.1em;text-transform:uppercase;color:#53b5ae;margin-top:4px}
.menu-contact{margin-top:auto;padding:16px;border-radius:14px;background:linear-gradient(125deg,rgba(135,123,208,.32) 0%,rgba(155,130,220,.22) 50%,rgba(104,175,213,.28) 100%);background-size:200% 200%;animation:iridescent 11s ease infinite reverse;display:flex;flex-direction:column;gap:9px}.menu-contact a:first-of-type{font-family:"Manrope";font-size:22px;letter-spacing:-.04em}
body.menu-open{overflow:hidden}

main, footer { position: relative; z-index: 1; }
.hero {
  min-height: 100svh;
  padding: 20vh 7vw 7vh;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  position: relative;
}
.eyebrow, .section-number {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #54737d;
}
.eyebrow::before, .section-number::before { content:""; width: 25px; height: 1px; background: var(--page-accent-1, #74aeb2); }
h1, h2, h3, p { margin-top: 0; }
h1, h2, blockquote { font-family: "Manrope", sans-serif; font-weight: 300; letter-spacing: -.065em; }
h1 { margin: 3vh 0 2vh; font-size: clamp(74px, 10.8vw, 170px); line-height: .83; }
h1 em { font-style: normal; background: linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%); background-size:280% 280%; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; animation:iridescent 8s ease infinite; }
.hero-copy { max-width: 530px; margin-left: 1vw; font-size: 16px; line-height: 1.75; color: #334d58; }
.hero-actions { margin: 22px 0 0 1vw; display: flex; align-items: center; gap: 28px; }
.button { display: inline-flex; justify-content: space-between; align-items: center; gap: 34px; padding: 16px 20px; border: none; border-radius: 100px; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.button.primary { background: linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%); background-size:280% 280%; animation:iridescent 8s ease infinite; color: white; box-shadow: 0 12px 30px rgba(117,223,196,.25); transition: box-shadow .3s ease, transform .2s ease; }
.button.primary:hover { box-shadow: 0 0 0 1.5px rgba(117,223,196,.6), 0 16px 40px rgba(117,223,196,.3); transform: translateY(-2px); }
.text-link { padding: 10px 2px; border-bottom: 1px solid #9eb3ba; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; transition: border-color .3s ease, color .2s ease; }
.text-link:hover { border-bottom-color: var(--page-accent-1, #9eb3ba); color: var(--page-accent-2, var(--ink)); }
.text-link span { margin-left: 16px; }
.hero-note {
  position: absolute;
  right: 7vw;
  bottom: 9vh;
  width: 300px;
  padding: 20px 22px;
  border: 1px solid rgba(255,255,255,.85);
  background: rgba(255,255,255,.36);
  backdrop-filter: blur(14px);
  border-radius: 18px;
}
.hero-note span { display: block; margin-bottom: 8px; text-transform: uppercase; letter-spacing: .14em; font-size: 9px; color: #62808a; }
.hero-note strong { font-size: 12px; line-height: 1.55; font-weight: 400; }
.scroll-cue { position: absolute; left: 3vw; bottom: 5vh; transform: rotate(-90deg) translateX(100%); transform-origin: left bottom; font-size: 9px; text-transform: uppercase; letter-spacing: .16em; color: #779099; }
.scroll-cue span { display: inline-block; width: 38px; height: 1px; margin-right: 9px; vertical-align: middle; background: #8aa1a8; }

.proof-strip {
  margin: 2vw;
  padding: 45px 5vw;
  min-height: 260px;
  border: 1px solid rgba(255,255,255,.8);
  border-radius: 28px;
  background: linear-gradient(118deg, rgba(198,243,230,.7) 0%, rgba(212,228,252,.62) 48%, rgba(228,218,248,.68) 100%);
  backdrop-filter: blur(18px);
  display: grid;
  grid-template-columns: repeat(3, 1fr) 1.5fr;
  align-items: center;
  gap: 3vw;
  box-shadow: inset 0 1px rgba(255,255,255,.9), 0 2px 60px rgba(54,178,160,.07);
}
.proof-item { border-left: 1px solid rgba(44,80,90,.16); padding-left: 24px; }
.proof-item strong { display: block; font-family: "Manrope"; font-size: clamp(40px, 5.5vw, 88px); font-weight: 300; letter-spacing: -.06em; background: linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%); background-size:280% 280%; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; animation:iridescent 8s ease infinite; }
.proof-item strong i { font-size: .36em; font-style: normal; letter-spacing: 0; }
.proof-item span { font-size: 10px; text-transform: uppercase; letter-spacing: .16em; color: #567380; }
.proof-statement { margin: 0; padding-left: 3vw; font-family: "Manrope"; font-size: clamp(20px, 2.3vw, 36px); line-height: 1.15; letter-spacing: -.04em; }

.section { padding: 18vh 7vw; }
.section-intro { max-width: 620px; margin-bottom: 10vh; }
.section-intro h2, .method-heading h2, .contact h2 { margin: 24px 0; font-size: clamp(56px, 7.7vw, 116px); line-height: .94; }
.section-intro p { max-width: 480px; font-size: 15px; line-height: 1.8; color: #3a5260; }
.lens-grid { margin-left: 18vw; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.lens-card {
  min-height: 270px;
  padding: 26px;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255,255,255,.8);
  border-radius: 20px;
  background: rgba(255,255,255,.45);
  backdrop-filter: blur(14px);
  transition: transform .3s, background .3s;
}
.lens-card:hover { background: rgba(255,255,255,.7); }
.lens-card span, .case-top, .method-row > span { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: #769098; }
.lens-card h3 { margin: auto 0 8px; font-family: "Manrope"; font-size: 32px; font-weight: 300; letter-spacing: -.05em; }
.lens-card p { max-width: 320px; margin-bottom: 0; font-size: 13px; line-height: 1.65; color: #334d58; }

.work { padding-top: 12vh; }
.compact { margin-left: auto; }
.case-grid { display: grid; grid-template-columns: 1.25fr 1fr 1fr; gap: 14px; }
.case-card {
  min-height: 490px;
  padding: 25px;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255,255,255,.8);
  border-radius: 22px;
  background: rgba(249,252,251,.62);
  backdrop-filter: blur(14px);
  overflow: hidden;
  position: relative;
}
.case-card::before { content:""; position:absolute; width: 240px; height:240px; right:-100px; top:-100px; border-radius:50%; background: radial-gradient(circle, rgba(151,217,210,.27), transparent 68%); }
.case-card.featured { background: linear-gradient(155deg, rgba(216,246,239,.76), rgba(238,241,250,.6)); }
.case-top { display: flex; justify-content: space-between; }
.case-metric { margin: auto 0 5px; font-family: "Manrope"; font-size: clamp(50px, 6.6vw, 100px); font-weight: 300; letter-spacing: -.075em; }
.case-metric small { font-size: .28em; letter-spacing: -.02em; }
.case-card h3 { margin: 8px 0; font-family: "Manrope"; font-size: 21px; font-weight: 400; letter-spacing: -.04em; }
.case-card p { max-width: 300px; font-size: 13px; line-height: 1.65; color: #334d58; }
.case-card a { margin-top: 22px; padding-top: 16px; display:flex; justify-content:space-between; border-top: 1px solid var(--line); font-size: 9px; text-transform:uppercase; letter-spacing:.12em; }

.method { display: grid; grid-template-columns: .8fr 1.2fr; gap: 9vw; align-items: start; }
.method-heading { position: sticky; top: 22vh; }
.method-heading h2 { font-size: clamp(50px, 6.6vw, 98px); }
.method-list { border-top: 1px solid var(--line); }
.method-row { padding: 32px 0 42px; display: grid; grid-template-columns: 50px 1fr; gap: 8px; border-bottom: 1px solid var(--line); }
.method-row h3 { margin: 0; font-family: "Manrope"; font-weight: 300; font-size: 28px; letter-spacing: -.04em; }
.method-row p { grid-column: 2; max-width: 380px; margin: 8px 0 0; font-size: 13px; line-height: 1.7; color: #334d58; }

.quote-section { min-height: 80vh; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; }
.quote-section blockquote { max-width: 1060px; margin: 0 0 40px; font-size: clamp(48px, 7vw, 112px); line-height: 1.02; background: linear-gradient(128deg, var(--ink) 15%, var(--page-accent-2, #19bce7) 52%, var(--page-accent-3, #6c42ed) 88%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.quote-section span { font-size: 9px; text-transform: uppercase; letter-spacing: .18em; color: #708890; }
.quote-section.quote-secondary { min-height: 52vh; padding: 10vh 7vw; }
.quote-section.quote-secondary blockquote { max-width: 820px; font-size: clamp(32px, 4.8vw, 76px); background: linear-gradient(128deg, var(--page-accent-2, #19bce7) 5%, var(--ink) 45%, var(--page-accent-3, #6c42ed) 95%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

.contact {
  margin: 0 2vw;
  padding: 8vh 7vw 10vh;
  border-top: 1px solid var(--line);
  overflow: hidden;
  position: relative;
  background: transparent;
}
.contact-orb { display: none; }
.contact-content { position: relative; display: grid; grid-template-columns: .55fr .45fr; gap: 0 6vw; align-items: end; }
.contact-content > .section-number { grid-column: 1 / -1; margin-bottom: 4vh; }
.contact h2 { grid-column: 1; grid-row: 2; margin: 0; font-size: clamp(38px, 5vw, 78px); }
.contact p { grid-column: 2; grid-row: 2; max-width: 380px; line-height: 1.75; color: #334d58; padding-bottom: 4px; }
.contact .button { grid-column: 1 / -1; grid-row: 3; display: inline-block; width: fit-content; white-space: nowrap; margin-top: 6vh; padding: 0; background: none; animation: none; box-shadow: none; color: var(--ink); font-family: "Manrope", sans-serif; font-size: clamp(36px, 5.5vw, 88px); font-weight: 300; letter-spacing: -.055em; text-transform: none; gap: 0; -webkit-text-fill-color: var(--ink); text-decoration: none; }
.contact .button::after { content: ""; display: block; width: 100%; height: 1px; margin-top: 5px; background: #84b9b5; transform: scaleX(.25); transform-origin: left; transition: transform .4s ease; }
.contact .button:hover::after { transform: scaleX(1); }
.contact .button:hover { transform: none; box-shadow: none; }
.contact .button span { font-size: inherit; margin-left: 12px; }
.contact-details { position: absolute; right: 7vw; bottom: 5vw; display: flex; gap: 30px; font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }

footer { padding: 35px 4vw; display:flex; align-items:center; justify-content:space-between; font-size: 9px; text-transform:uppercase; letter-spacing:.13em; color:#667c85; }
footer a { transition: color .2s ease; }
footer a:hover { color: var(--page-accent-1, var(--ink)); }
.cookie-panel{position:fixed;z-index:40;left:22px;bottom:22px;width:min(390px,calc(100vw - 44px));padding:20px;border:1px solid rgba(255,255,255,.88);border-radius:18px;background:rgba(249,252,250,.88);backdrop-filter:blur(24px);box-shadow:0 18px 55px rgba(40,74,83,.13);display:grid;grid-template-columns:1fr 1fr;gap:9px}.cookie-panel strong,.cookie-panel p,.cookie-panel a{grid-column:1/-1}.cookie-panel strong{font-family:"Manrope";font-size:20px;font-weight:300;letter-spacing:-.04em}.cookie-panel p{margin:0;font-size:10px;line-height:1.6;color:#647b83}.cookie-panel a{font-size:9px;text-decoration:underline}.cookie-panel button{padding:11px 16px;border:1px solid rgba(42,76,87,.14);border-radius:100px;background:rgba(255,255,255,.42);font:500 9px "DM Sans";text-transform:uppercase;letter-spacing:.12em;color:#526f78;transition:border-color .25s,box-shadow .25s,transform .2s,color .2s}.cookie-panel button:hover{border-color:rgba(117,223,196,.5);box-shadow:0 0 0 3px rgba(117,223,196,.1),0 4px 14px rgba(117,223,196,.15);transform:translateY(-1px);color:#0b2d3a}.cookie-panel button:last-child{border:none;background:linear-gradient(120deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%);background-size:280% 280%;animation:iridescent 8s ease infinite;color:white;box-shadow:0 8px 22px rgba(117,223,196,.25);transition:box-shadow .3s ease,transform .2s ease}.cookie-panel button:last-child:hover{box-shadow:0 0 0 1.5px rgba(117,223,196,.6),0 12px 32px rgba(117,223,196,.3);transform:translateY(-1px)}.cookie-panel[hidden]{display:none}
.back-to-clarity{--p:var(--page-progress,0);position:fixed;z-index:18;right:22px;bottom:22px;width:62px;height:62px;padding:0;border:1.5px solid rgba(117,223,196,.3);border-radius:50%;background:rgba(249,252,250,.92);backdrop-filter:blur(18px);box-shadow:0 0 calc(var(--p)*32px) calc(var(--p)*5px) rgba(117,223,196,calc(var(--p)*.45)),0 0 calc(var(--p)*55px) calc(var(--p)*2px) rgba(135,123,208,calc(var(--p)*.28)),0 6px 24px rgba(43,73,81,.09);cursor:pointer;opacity:0;visibility:hidden;transform:translateY(12px) scale(.9);transition:opacity .4s ease,visibility .4s ease,transform .45s cubic-bezier(.2,.7,.2,1);display:flex;align-items:center;justify-content:center}.back-to-clarity span{display:none}.back-to-clarity i{position:relative;z-index:1;font:300 18px/1 "Manrope";color:#55727a;transition:color .3s ease}.back-to-clarity:before{display:none}.back-to-clarity:after{content:"BACK TO CLARITY";position:absolute;z-index:1;bottom:calc(100% + 10px);right:0;font:500 7.5px/1 "DM Sans";text-transform:uppercase;letter-spacing:.13em;color:#55727a;white-space:nowrap;opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease}.back-to-clarity.visible{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.back-to-clarity:hover{transform:translateY(-3px) scale(1);border-color:rgba(117,223,196,.7)}.back-to-clarity:hover i{color:var(--ink)}.back-to-clarity:hover:after{opacity:1;transform:translateY(0)}.back-to-clarity:focus-visible{outline:2px solid #84b9b5;outline-offset:4px}
.home-complete{display:grid;grid-template-columns:.55fr 1.45fr;gap:8vw;border-top:1px solid var(--line)}.home-complete .section-intro{position:sticky;top:18vh;align-self:start}.home-complete .prose{display:grid;grid-template-columns:1fr 1fr;gap:14px}.home-complete .prose>*{margin:0;padding:22px;border:1px solid rgba(255,255,255,.8);border-radius:18px;background:rgba(255,255,255,.43);backdrop-filter:blur(14px)}.home-complete .prose h2{grid-column:1/-1;margin-top:55px;padding:45px 0 12px;border:0;border-radius:0;border-bottom:1px solid var(--line);background:transparent;font-size:clamp(38px,5vw,72px)}.home-complete .prose h3{min-height:160px;display:flex;align-items:flex-end;font-family:"Manrope";font-size:27px;font-weight:300;letter-spacing:-.045em}.home-complete .prose p{font-size:12px;line-height:1.7;color:#607780}
.assessment-promo{min-height:85vh;margin:2vw;padding:9vw;border-radius:28px;position:relative;overflow:hidden;display:flex;align-items:center;background:linear-gradient(135deg,rgba(216,247,236,.82),rgba(249,232,216,.76),rgba(229,217,246,.8))}.assessment-promo-copy{position:relative;z-index:2;max-width:850px}.assessment-promo h2{margin:24px 0;font-family:"Manrope";font-size:clamp(60px,8vw,125px);font-weight:300;line-height:.92;letter-spacing:-.07em}.assessment-promo p{max-width:580px;line-height:1.7;color:#5c747d}.assessment-promo-facts{position:absolute;right:8vw;bottom:8vw;display:grid;grid-template-columns:auto auto;gap:5px 14px;align-items:end}.assessment-promo-facts strong{font:300 58px "Manrope";letter-spacing:-.07em}.assessment-promo-facts span{font-size:8px;text-transform:uppercase;letter-spacing:.14em;padding-bottom:10px}.assessment-promo-orbit{position:absolute;width:60vw;height:60vw;right:-15vw;top:-22vw;border:1px solid rgba(255,255,255,.6);border-radius:50%}.assessment-promo-orbit i{position:absolute;inset:15%;border:1px solid rgba(255,255,255,.55);border-radius:50%}.assessment-promo-orbit i:nth-child(2){inset:30%}.assessment-promo-orbit i:nth-child(3){inset:44%}
.home-briefings{padding:14vh 7vw;border-top:1px solid var(--line);position:relative;overflow:hidden}.home-briefings-heading{display:grid;grid-template-columns:.35fr 1fr .42fr;gap:4vw;align-items:end;margin-bottom:8vh}.home-briefings-heading h2{margin:0;font:300 clamp(64px,8vw,122px)/.86 "Manrope";letter-spacing:-.075em}.home-briefings-heading p{font-size:12px;line-height:1.75;color:#607982}.home-briefings-heading a{font-size:9px;text-transform:uppercase;letter-spacing:.13em}.home-briefings-grid{display:grid;grid-template-columns:1.25fr .75fr .75fr;gap:15px;align-items:stretch}.home-briefing{min-height:410px;padding:27px;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.85);border-radius:4px 55px 4px 4px;background:rgba(255,255,255,.54);backdrop-filter:blur(16px);transition:background .35s}.home-briefing:first-child{min-height:580px;background:linear-gradient(145deg,rgba(211,244,234,.8),rgba(234,228,248,.66))}.home-briefing:hover{background:rgba(255,255,255,.78)}.home-briefing span,.home-briefing em,.home-briefing b{font-size:8px;text-transform:uppercase;letter-spacing:.13em;color:#718b92}.home-briefing em{margin:14px 0 auto;font-style:normal}.home-briefing h3{margin:0 0 18px;font:300 clamp(30px,3.2vw,56px)/1 "Manrope";letter-spacing:-.055em}.home-briefing:not(:first-child) h3{font-size:31px}.home-briefing p{font-size:11px;line-height:1.7;color:#617981}.home-briefing b{margin-top:28px;text-align:right}

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .ribbon-stage{display:none}
  .site-header { left: 14px; right: 14px; }
  .header-context, .header-cta, .header-assessment, .header-briefings { display:none; }
  .menu-toggle { margin-left:auto;width:78px; }
  .mobile-menu{padding:94px 14px 14px}
  .menu-shell{display:block;padding:0;min-height:calc(100vh - 108px);background:transparent;border:none;box-shadow:none;border-radius:0}
  .menu-heading{height:auto;background:linear-gradient(120deg,#0d3d30 0%,#0e1f45 22%,#2a1245 45%,#0b3040 68%,#093825 85%,#0d3d30 100%);background-size:280% 280%;animation:iridescent 10s ease infinite;border-radius:16px;padding:22px 20px 18px;margin-bottom:4px;border-bottom:none;min-height:160px}
  .menu-heading>span{color:rgba(255,255,255,.45)}
  .menu-heading strong{font-size:34px;color:#fff;margin-top:auto;padding-top:16px}
  .menu-pull-quote{font-size:20px;padding-top:14px;align-items:flex-start}
  .menu-primary{display:block;margin-top:8px;border-top:none;background:rgba(255,255,255,.62);border-radius:16px;overflow:hidden}
  .menu-primary a{min-height:90px;padding:14px 16px;grid-template-columns:30px 1fr;border-right:none}
  .menu-primary strong{font-size:28px}.menu-primary small{font-size:9px}
  .menu-primary a[aria-current="page"]{border-left:3px solid var(--ma,#75dfc4);padding-left:13px}
  .menu-primary a[aria-current="page"]::after{opacity:.18}
  .menu-primary a::before{height:0}
  .menu-secondary{display:grid;grid-template-columns:1fr 1fr;margin-top:8px;gap:0;background:rgba(255,255,255,.62);border-radius:16px;padding:20px 16px 16px;overflow:hidden}
  .menu-featured-col{grid-column:1/-1}
  .menu-featured-card{padding:14px}
  .menu-contact{margin-top:12px;min-height:auto}
  .hero { padding: 18vh 6vw 8vh; justify-content:flex-start; }
  .home-complete{display:block}.home-complete .section-intro{position:static}.home-complete .prose{grid-template-columns:1fr}
  .home-briefings-heading{display:block}.home-briefings-heading h2{margin:24px 0}.home-briefings-grid{grid-template-columns:1fr}.home-briefing,.home-briefing:first-child{min-height:390px}
  h1 { margin-top:9vh; font-size:clamp(64px,19vw,100px); }
  .hero-note { right:6vw; bottom:6vh; width:250px; }
  .scroll-cue { display:none; }
  .proof-strip { grid-template-columns:1fr 1fr; padding:35px 6vw; }
  .proof-statement { grid-column:1 / -1; padding:20px 0 0; }
  .section { padding:14vh 6vw; }
  .lens-grid { margin-left:0; }
  .case-grid { grid-template-columns:1fr; }
  .case-card { min-height:380px; }
  .method { display:block; }
  .method-heading { position:static; margin-bottom:70px; }
}

@media (max-width: 580px) {
  .hero { min-height:900px; }
  h1 { font-size:19vw; }
  .hero-copy { font-size:14px; }
  .hero-actions { align-items:flex-start; flex-direction:column; gap:10px; }
  .hero-note { left:6vw; right:auto; }
  .proof-strip { grid-template-columns:1fr; }
  .proof-statement { grid-column:auto; }
  .lens-grid { grid-template-columns:1fr; }
  .lens-card { min-height:220px; }
  .section-intro h2, .method-heading h2, .contact h2 { font-size:15vw; }
  .quote-section blockquote { font-size:12vw; }
  .contact { min-height:auto; padding:10vw 7vw; }
  .contact-content { grid-template-columns: 1fr; }
  .contact-content > .section-number { margin-bottom: 2vh; }
  .contact h2 { grid-column: 1; grid-row: auto; margin-bottom: 20px; }
  .contact p { grid-column: 1; grid-row: auto; padding-top: 0; }
  .contact .button { grid-column: 1; grid-row: auto; margin-top: 32px; font-size: clamp(22px, 5.5vw, 38px); white-space: nowrap; }
  .contact-details { position: static; margin-top: 28px; flex-direction: column; gap: 6px; }
  .contact-details { left:7vw; right:auto; flex-direction:column; gap:12px; }
  footer { gap:20px; flex-wrap:wrap; }
  .back-to-clarity{right:16px;bottom:16px}
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior:auto; }
  .reveal { opacity:1; transform:none; transition:none; }
  .ribbon-stage { position:absolute; }
  .back-to-clarity{transition:none}
}

/* Site-wide editorial choreography */
.motion-section{--scene-progress:0;isolation:isolate;position:relative;overflow:hidden}
.motion-scene-1:after,.motion-scene-3:after{content:"";position:absolute;z-index:-2;width:42vw;aspect-ratio:1;right:-16vw;top:15%;border-radius:50%;background:radial-gradient(circle,rgba(70,214,174,.13),rgba(172,93,222,.06) 48%,transparent 70%);transform:translate3d(0,calc((.5 - var(--scene-progress))*25vh),0) scale(calc(.8 + var(--scene-progress)*.35));pointer-events:none}
.motion-scene-2:before,.motion-scene-4:before{content:"";position:absolute;z-index:-2;left:-10vw;bottom:-20vw;width:48vw;aspect-ratio:1;border:1px solid rgba(36,173,203,.1);border-radius:50%;box-shadow:0 0 0 4vw rgba(81,215,170,.025),0 0 0 9vw rgba(164,68,225,.018);transform:rotate(calc(var(--scene-progress)*80deg));pointer-events:none}
.scene-divider{min-height:76px;padding:0 7vw;display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;border-block:1px solid var(--line);background:rgba(248,250,248,.7);backdrop-filter:blur(14px);position:relative;z-index:2}.scene-divider span,.scene-divider em{font-size:8px;font-style:normal;text-transform:uppercase;letter-spacing:.16em;color:#799197}.scene-divider i{height:1px;background:linear-gradient(90deg,#75dfc4 0%,#68afd5 22%,#877bd0 45%,#9bc9c2 68%,#53b5ae 85%,#75dfc4 100%);background-size:280% 100%;animation:iridescent 8s ease infinite;transform:scaleX(calc(.25 + var(--page-progress,0)*.75));transform-origin:left}
.motion-card{--card-rx:0deg;--card-ry:0deg;--card-light-x:50%;--card-light-y:50%;transform:perspective(1000px) rotateX(var(--card-rx)) rotateY(var(--card-ry));transform-style:preserve-3d;transition:transform .35s ease,background .3s ease,border-color .3s ease;will-change:transform}
.motion-card:after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at var(--card-light-x) var(--card-light-y),rgba(255,255,255,.5),transparent 46%);opacity:0;transition:opacity .3s;pointer-events:none}.motion-card:hover:after{opacity:.5}
.motion-scene-0 .motion-card:nth-child(odd){transform:perspective(1000px) translateY(calc((.5 - var(--scene-progress))*26px)) rotateX(var(--card-rx)) rotateY(var(--card-ry))}
.motion-scene-0 .motion-card:nth-child(even){transform:perspective(1000px) translateY(calc((var(--scene-progress) - .5)*26px)) rotateX(var(--card-rx)) rotateY(var(--card-ry))}
.motion-scene-3 .motion-card{transform:perspective(1000px) translateX(calc((.5 - var(--scene-progress))*35px)) rotateX(var(--card-rx)) rotateY(var(--card-ry))}
.quote-section.motion-section blockquote{transform:scale(calc(.86 + var(--scene-progress)*.2));opacity:calc(.25 + var(--scene-progress)*1.1)}

/* Site-wide composition: bold hierarchy, calm geometry, and gentle movement. */
.content-section{min-height:92vh;align-items:center;position:relative;overflow:hidden}.content-section:after{content:"";position:absolute;z-index:-1;width:32vw;height:32vw;right:-18vw;bottom:-18vw;border:1px solid rgba(83,171,165,.12);border-radius:50%;transform:rotate(calc(var(--scene-progress)*70deg))}.content-section:nth-of-type(4n) .content-heading{margin-left:7vw}.content-section:nth-of-type(4n) .content-copy{grid-template-columns:1fr}.content-section:nth-of-type(4n) .content-card{min-height:180px;border-radius:4px 55px 4px 4px}.content-section:nth-of-type(4n+1) .content-card:nth-child(even){border-radius:90px 8px 90px 8px}
.content-heading h2,.page-links h2{letter-spacing:-.07em}.content-heading:after{content:"";display:block;width:70px;height:1px;margin-top:35px;background:#8fb9b4;transform:scaleX(0);transform-origin:left;transition:transform .7s cubic-bezier(.2,.7,.2,1) .3s}.content-heading.visible:after{transform:scaleX(1)}
.content-card,.link-card,.case-card,.lens-card{transition:border-radius .55s ease,background .35s ease,transform .35s ease,box-shadow .35s ease}.content-card:hover,.link-card:hover{border-radius:50px 6px 50px 6px;background:rgba(255,255,255,.7);box-shadow:0 0 0 1.5px rgba(117,223,196,.35),0 12px 40px rgba(117,223,196,.1),0 4px 16px rgba(135,123,208,.08)}
.page-links{position:relative;overflow:hidden}.page-links:before{content:"";position:absolute;z-index:-1;width:52vw;height:24vw;right:-10vw;bottom:-14vw;border:1px solid rgba(105,146,202,.13);border-radius:50%;transform:rotate(calc(-12deg + var(--page-progress,0)*30deg))}.link-card:nth-child(2){margin-top:45px}.link-card:nth-child(3){margin-top:90px}
.contact{overflow:hidden}.contact-content{transform:translateY(calc((.5 - var(--scene-progress,0))*20px))}

@media(hover:hover) and (pointer:fine){
  .header-briefings:hover:after{transform:scaleX(1)}
  .menu-primary a:hover{transform:translateY(-3px)}
  .lens-card:hover,.home-briefing:hover{transform:translateY(-5px)}
}

a,button,label,[role="button"]{touch-action:manipulation}

@media(max-width:900px){
  html,body{touch-action:pan-y;overscroll-behavior-y:contain}
  body.menu-open{overflow:hidden;touch-action:none}
  .ribbon-stage{position:fixed;opacity:.72;mix-blend-mode:multiply;contain:layout paint}
  .site-header,.mobile-menu,.cookie-panel,.back-to-clarity:before,.scene-divider,
  .content-card,.story-card,.link-card,.home-complete .prose>*,.home-briefing,
  .briefing-tools,.briefing-item,.briefing-recommendation,.enquiry-form,.assessment-card,
  .assessment-facts{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .motion-section,.motion-card,.contact-content{transform:none!important;will-change:auto!important}
  .motion-section:before,.motion-section:after,.motion-card:after{display:none!important}
  .back-to-clarity{right:12px;bottom:12px}
  .briefing-marquee span,.subscribe-orbit i,.hero-motif,.motif-editorial{animation:none!important}
  .menu-pull-quote,.briefing-intro h2 em,h1 em,.button.primary,.header-cta,.proof-item strong,.scene-divider i,.menu-featured-card,.menu-contact,.home-briefing:first-child,.assessment-promo,.cookie-panel button:last-child,.menu-heading{animation:none!important;background-position:0% 50%!important}
  *{-webkit-backdrop-filter:none!important;backdrop-filter:none!important}
  .scene-divider{padding:0 6vw}.scene-divider em{max-width:55vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content-section{min-height:auto}.content-section:nth-of-type(4n) .content-heading{margin-left:0}.link-card:nth-child(n){margin-top:0}
}
.assessment-promo.motion-section .assessment-promo-orbit{transform:rotate(calc(var(--scene-progress)*110deg)) scale(calc(.82 + var(--scene-progress)*.3))}

@media(prefers-reduced-motion:reduce){
  .scene-divider i{transform:none}
  .motion-card,.motion-scene-0 .motion-card:nth-child(odd),.motion-scene-0 .motion-card:nth-child(even),.motion-scene-3 .motion-card{transform:none}
}

/* Ribbons are the sole decorative metaphor for smooth operational flow. */
.contact-orb,
.assessment-promo-orbit,
.case-card::before,
.mobile-menu::before,
.motion-scene-1::after,
.motion-scene-3::after,
.motion-scene-2::before,
.motion-scene-4::before,
.content-section::after,
.page-links::before {
  display:none !important;
}

/* Cropped ribbon fragments give information cards texture without a second motif. */
:is(.content-card,.story-card,.link-card,.case-card,.lens-card,.home-briefing,.briefing-item,.briefing-recommendation){
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
:is(.content-card,.story-card)>:not(.card-no):not(span){
  position:relative;
  z-index:1;
}
@media(hover:hover) and (pointer:fine){
  :is(.content-card,.story-card,.link-card,.case-card,.lens-card,.home-briefing,.briefing-item,.briefing-recommendation){
    transition:transform .35s ease, box-shadow .35s ease;
  }
  :is(.content-card,.story-card,.link-card,.case-card,.lens-card,.home-briefing,.briefing-item,.briefing-recommendation):hover{
    transform:translateY(-4px);
    box-shadow:0 12px 40px rgba(54,178,160,.1), 0 4px 16px rgba(108,66,237,.07);
  }
}

@media(max-width:900px){
  :is(.content-card,.story-card,.link-card,.case-card,.lens-card,.home-briefing,.briefing-item,.briefing-recommendation)::after{
    opacity:.2;
    transition:none;
  }
}

