/* ============================================================
   MedPrüf — case experience · WO! Studio
   From Prüfung to Proof. Clinical calm: navy authority, pass-green,
   Inter clarity, a vital pulse from anxious → steady.
   ============================================================ */

:root{
  --navy:#0A2041;
  --navy-2:#0C284F;        /* a half-step up for cards */
  --navy-deep:#06101F;     /* deepest grounds */
  --green:#027C5F;
  --pass:#17B98A;          /* brighter signal/pass green */
  --paper:#F4F6F9;
  --slate:#8294B4;
  --slate-dim:#7C8DAD;     /* AA-safe on navy (~4.6:1) */
  --wrong:#E5544B;
  --line:rgba(244,246,249,.13);
  --line-2:rgba(244,246,249,.07);

  --f:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --f-mono:'IBM Plex Mono',ui-monospace,'SF Mono',SFMono-Regular,Menlo,monospace;   /* the documented / clinical / on-the-record voice */

  --mx:clamp(20px,6vw,120px);              /* page side margin */
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
body.mp{
  margin:0;background:#070f1c;color:var(--paper);
  font-family:var(--f);font-weight:400;line-height:1.5;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:clip;
}
body.mp.has-spark,body.mp.has-spark *{cursor:none}
@media (pointer:coarse){body.mp.has-spark,body.mp.has-spark *{cursor:auto}}
a{color:inherit;text-decoration:none}
em{font-style:italic}
::selection{background:var(--pass);color:var(--navy-deep)}
img,svg{display:block;max-width:100%}

/* ---------- atmosphere ---------- */
.mp-grain{position:fixed;inset:0;z-index:80;pointer-events:none;opacity:.05;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.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- desktop pulse cursor ---------- */
.mp-spark{position:fixed;left:0;top:0;z-index:120;width:34px;height:34px;margin:-17px 0 0 -17px;
  border:1px solid color-mix(in srgb,var(--pass) 70%,transparent);border-radius:50%;pointer-events:none;
  transition:width .25s var(--ease),height .25s var(--ease),margin .25s var(--ease),background .25s,border-color .25s;
  display:none;}
.mp-spark::after{content:"";position:absolute;left:50%;top:50%;width:4px;height:4px;margin:-2px 0 0 -2px;border-radius:50%;background:var(--pass)}
body.has-spark .mp-spark{display:block}
.mp-spark.is-hot{width:54px;height:54px;margin:-27px 0 0 -27px;background:color-mix(in srgb,var(--pass) 14%,transparent);border-color:var(--pass)}
.mp-spark.is-quiet{opacity:.32}                          /* duck out of the way over big type */

/* ---------- reading progress ---------- */
.mp-prog{position:fixed;left:0;top:0;width:100%;height:2px;z-index:110;background:var(--line-2)}
.mp-prog i{display:block;height:100%;width:100%;transform:scaleX(var(--prog,0));transform-origin:0 50%;
  background:linear-gradient(90deg,var(--green),var(--pass));box-shadow:0 0 12px color-mix(in srgb,var(--pass) 60%,transparent)}

/* ---------- nav ---------- */
.mp-nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:18px var(--mx);transition:transform .5s var(--ease),opacity .5s var(--ease);
  background:linear-gradient(180deg,color-mix(in srgb,var(--navy) 84%,transparent),transparent)}
.mp-nav.is-hidden{transform:translateY(-104%);opacity:0}
.mp-nav__brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em;font-size:16px;min-height:44px}
.mp-nav__mark{width:22px;height:22px;display:inline-block}
.mp-nav__mark svg{width:100%;height:100%}
.mp-nav__case{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);font-weight:500}
@media (max-width:740px){.mp-nav__case{display:none}}
.mp-nav__end{display:inline-flex;align-items:center;gap:10px}
.mp-nav__sound{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--line);border-radius:100px;color:var(--slate);background:none;cursor:pointer;transition:border-color .3s,color .3s,background .3s}
.mp-nav__sound svg{width:19px;height:14px}
.mp-nav__sound .b{fill:currentColor;transform-origin:center bottom;transform:scaleY(.55);transition:transform .3s}
.mp-nav__sound:hover{color:var(--paper)}
.mp-nav__sound.is-on{color:var(--pass);border-color:color-mix(in srgb,var(--pass) 40%,var(--line));background:color-mix(in srgb,var(--pass) 8%,transparent)}
.mp-nav__sound.is-on .b{animation:mp-eq 1s ease-in-out infinite}
.mp-nav__sound.is-on .b2{animation-delay:.16s}.mp-nav__sound.is-on .b3{animation-delay:.32s}.mp-nav__sound.is-on .b4{animation-delay:.08s}
@keyframes mp-eq{0%,100%{transform:scaleY(.38)}50%{transform:scaleY(1)}}
body.reduce .mp-nav__sound.is-on .b{animation:none;transform:scaleY(.8)}
.mp-nav__back{display:inline-flex;align-items:center;min-height:44px;font-size:12px;letter-spacing:.04em;color:var(--paper);border:1px solid var(--line);border-radius:100px;padding:8px 16px;
  transition:border-color .3s,background .3s,color .3s}
.mp-nav__back i{color:var(--pass)}
.mp-nav__back:hover{border-color:var(--pass);background:color-mix(in srgb,var(--pass) 10%,transparent)}

/* ---------- studio badge ---------- */
.mp-badge{position:fixed;left:var(--mx);bottom:22px;z-index:100;display:inline-flex;align-items:baseline;gap:7px;
  font-size:12px;letter-spacing:.04em;color:var(--slate);mix-blend-mode:difference;transition:color .3s}
.mp-badge__wo{font-weight:800;color:var(--paper)}.mp-badge__wo b{color:var(--pass)}
.mp-badge:hover{color:var(--paper)}
@media (max-width:740px){.mp-badge{display:none}}

/* ---------- shared labels / reveal ---------- */
.mp-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--pass);font-weight:600;margin:0 0 clamp(20px,3vw,38px)}
.mp-label--center{text-align:center}

section{position:relative;padding:clamp(80px,13vh,170px) var(--mx)}
.mp-hero,.mp-insight,.mp-mark,.mp-product,.mp-end{max-width:none}
.mp-wall__cols,.mp-move__grid,.mp-outcome__grid,.mp-system{max-width:var(--maxw);margin-inline:auto}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-split] .w{display:inline-block;overflow:hidden;vertical-align:top}
[data-split] .w>span{display:inline-block;transform:translateY(105%);transition:transform .8s var(--ease);transition-delay:calc(var(--wi,0)*.05s)}
[data-split].in .w>span{transform:none}
body.reduce [data-reveal],body.reduce [data-split] .w>span{opacity:1;transform:none;transition:none}

/* =========================================================
   00 · HERO — scroll-scrubbed Prüfung→Proof; the ü-dots lift into the eyes
   ========================================================= */
.mp-hero{position:relative;z-index:2;height:190vh;background:transparent}
.mp-hero__stage{position:sticky;top:0;height:100svh;display:flex;align-items:center;overflow:hidden;will-change:transform,opacity;transform-origin:50% 48%}
.mp-hero__atmos{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(56% 46% at 50% 45%,color-mix(in srgb,var(--green) 20%,transparent),transparent 70%);opacity:.7}

.mp-ecg{position:absolute;left:0;right:0;top:40%;width:100%;height:clamp(88px,14vh,160px);z-index:1;opacity:.5;pointer-events:none}
@media (max-width:740px){.mp-ecg{height:66px;opacity:.42}}
.mp-ecg__base{fill:none;stroke:var(--line);stroke-width:1}
.mp-ecg__line{fill:none;stroke:var(--pass);stroke-width:2.2;stroke-linejoin:round;stroke-linecap:round;
  filter:drop-shadow(0 0 6px color-mix(in srgb,var(--pass) 55%,transparent));
  stroke-dasharray:var(--len,2600);stroke-dashoffset:var(--len,2600)}
body.reduce .mp-ecg__line{stroke-dashoffset:0}

.mp-hero__inner{position:relative;z-index:3;width:100%;max-width:var(--maxw);margin-inline:auto;text-align:center;padding:0 var(--mx)}
.mp-hero__pre{font-size:clamp(11px,1.3vw,13px);letter-spacing:.18em;text-transform:uppercase;color:var(--slate);margin:0 0 clamp(22px,3vw,34px);font-weight:500}

.mp-hero__word{position:relative;display:inline-grid;margin:0 auto;font-weight:800;letter-spacing:-.04em;line-height:.9;
  font-size:clamp(4.2rem,16vw,14rem)}
.mp-hero__word>span{grid-area:1/1;will-change:opacity,transform,filter}
.mp-hero__from{color:var(--paper)}
.mp-hero__u{position:relative;display:inline-block}      /* the dotless u — the flydots are its diaeresis */
.mp-hero__to{color:var(--pass);opacity:0}
.mp-hero__dot{color:var(--pass)}
.mp-hero__from .mp-hero__dot{color:inherit}      /* the period after "Prüfung." stays white — only the two eye-dots are green */
.mp-hero__rm{display:none}                               /* reduced-motion fallback only */

/* the travelling diaeresis → eyes (positioned by JS, in stage space) */
.mp-flydots{position:absolute;inset:0;z-index:4;pointer-events:none}
.mp-flydots i{position:absolute;left:0;top:0;width:clamp(15px,1.7vw,26px);height:clamp(15px,1.7vw,26px);border-radius:50%;opacity:0;
  background:var(--pass);box-shadow:0 0 18px color-mix(in srgb,var(--pass) 70%,transparent);will-change:transform;backface-visibility:hidden}

.mp-hero__sub{max-width:46ch;margin:clamp(26px,4vw,42px) auto 0;font-size:clamp(15px,1.7vw,20px);color:color-mix(in srgb,var(--paper) 82%,transparent);line-height:1.55;opacity:0}
.mp-hero__meta{list-style:none;margin:clamp(26px,4vw,44px) auto 0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(18px,4vw,52px);max-width:760px;opacity:0}
.mp-hero__meta li{display:flex;flex-direction:column;gap:4px}
.mp-hero__meta b{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate-dim);font-weight:600}
.mp-hero__meta span{font-size:13px;color:var(--paper);font-weight:500}
.mp-hero__cue{margin:clamp(28px,4vw,46px) 0 0;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:color-mix(in srgb,var(--paper) 56%,transparent)}
.mp-hero__cue i{display:block;margin-top:8px;animation:mp-bob 2s ease-in-out infinite;color:var(--pass)}
@keyframes mp-bob{0%,100%{transform:translateY(0);opacity:.6}50%{transform:translateY(6px);opacity:1}}

/* reduced motion: drop the scrub, show the whole idea statically */
body.reduce .mp-hero{height:auto}
body.reduce .mp-hero__stage{position:static;height:auto;min-height:100svh;padding:16vh 0}
body.reduce .mp-hero__word,body.reduce .mp-flydots{display:none}
body.reduce .mp-hero__rm{display:block;font-weight:800;letter-spacing:-.03em;line-height:.95;font-size:clamp(3rem,11vw,8rem);color:var(--paper);margin:0 auto}
body.reduce .mp-hero__rm span{color:var(--pass)}
body.reduce .mp-hero__sub,body.reduce .mp-hero__meta{opacity:1}

/* =========================================================
   THE OPENING — a scroll-zoom portal: POV chorus → Prüfung → gate
   ========================================================= */
.mp-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* interactive Ü/dot field — fixed behind the cinematic opening; content scrolls over it */
/* one consistent gradient ground for the WHOLE page — no flat-solid sections */
/* premium, even deepening — a linear base (consistent on any aspect) + a soft top glow for the hero/seal moment */
.mp-ground{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(115% 70% at 50% -6%, rgba(30,72,134,.42), rgba(30,72,134,0) 60%),
    linear-gradient(180deg, #0b2245 0%, #091c39 36%, #07142a 64%, #050d1b 100%)}
.mp-field{position:fixed;inset:0;z-index:1;pointer-events:none;background:transparent}
/* certification seal — ABSENT until the gate; JS drives its entrance (big, central, full-res) → scales DOWN to the top-left dock → persists */
.mp-cert{position:fixed;top:56px;left:clamp(12px,2.5vw,30px);z-index:90;pointer-events:none;opacity:0;transform-origin:center;will-change:transform,opacity}
.mp-cert__seal{display:block;width:clamp(214px,23vw,294px);height:auto;filter:drop-shadow(0 24px 56px rgba(0,0,0,.6))}   /* layout = the dominant entrance size; JS scales down to dock (stays sharp) */
@media (max-width:740px){.mp-cert{top:54px;left:10px}.mp-cert__seal{width:min(258px,72vw)}}
/* short / landscape viewports: shrink the seal + tighten the copy push so they never crowd in limited height */
@media (max-height:520px){.mp-cert__seal{width:min(208px,33vh)}.mp-gate__copy{transform:translateY(clamp(14px,3vh,34px))}}
body.reduce .mp-cert{opacity:.92;transform:scale(.33);transform-origin:top left}

/* opening scenes — transparent (the field shows through), tall, sticky-staged, zoom-ready */
.mp-pov,.mp-gate{position:relative;z-index:2;background:transparent}
.mp-pov{height:300vh}
.mp-gate{height:140vh}
.mp-pov__stage,.mp-gate__stage{position:sticky;top:0;height:100svh;overflow:hidden;display:grid;place-items:center;text-align:center;will-change:transform,opacity;transform-origin:50% 48%}
.mp-pov__stage>*,.mp-gate__stage>*{grid-area:1/1}

.mp-pov__vig{width:100%;height:100%;pointer-events:none;background:radial-gradient(circle at 50% 46%,transparent 28%,rgba(2,7,15,.92) 94%);opacity:0}
.mp-pov__ecg{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);width:100%;height:min(40vh,340px);opacity:.85;pointer-events:none}
.mp-pov__ecgbase{fill:none;stroke:var(--line);stroke-width:1}
.mp-pov__ecgline{fill:none;stroke:#9fb0cc;stroke-width:2.4;stroke-linejoin:round;stroke-linecap:round;will-change:stroke-dashoffset}
.mp-pov__ecgline.is-steady{stroke:var(--pass);filter:drop-shadow(0 0 8px color-mix(in srgb,var(--pass) 65%,transparent))}
.mp-pov__ecgline.is-flat{stroke:color-mix(in srgb,var(--wrong) 80%,#fff)}

.mp-pov__cost{position:absolute;top:11%;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:clamp(8px,1.2vw,12px);opacity:0;pointer-events:none;text-align:center}
.mp-pov__costn{font-weight:800;font-size:clamp(2.6rem,8vw,5.4rem);letter-spacing:-.03em;color:#fff;font-variant-numeric:tabular-nums;line-height:.96}
.mp-pov__costn b{color:var(--wrong);font-weight:800;margin-right:.04em}
.mp-pov__costlab{font-family:var(--f-mono);font-size:clamp(11px,1.25vw,13px);letter-spacing:.04em;color:color-mix(in srgb,var(--paper) 64%,transparent)}
.mp-pov__costlab [data-pov-cost-x]{color:var(--wrong);font-weight:600;text-transform:uppercase;letter-spacing:.1em}

/* the chorus — each pain a different person (quote + origin) */
.mp-pov__seq{position:relative;width:100%;max-width:min(94vw,920px);margin-inline:auto}
.mp-pov__line{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:100%;margin:0;opacity:0}
.mp-pov__line blockquote{margin:0;font-weight:500;font-size:clamp(1.5rem,3.8vw,3.3rem);line-height:1.1;letter-spacing:-.02em;color:color-mix(in srgb,var(--paper) 92%,transparent);text-wrap:balance}
.mp-pov__line blockquote b{font-weight:700;color:#fff}
.mp-pov__line[data-cost] blockquote b{color:var(--wrong)}
.mp-pov__line figcaption{margin-top:clamp(16px,2.4vw,26px);font-family:var(--f-mono);font-size:clamp(10.5px,1.3vw,13px);letter-spacing:.16em;text-transform:uppercase;color:var(--pass)}

.mp-pov__promise{display:flex;flex-direction:column;align-items:center;gap:clamp(14px,2.4vw,22px);opacity:0;padding:0 var(--mx)}
.mp-pov__pre{margin:0;font-family:var(--f-mono);font-size:clamp(11px,1.4vw,13px);letter-spacing:.18em;text-transform:uppercase;color:var(--pass)}
.mp-pov__big{margin:0;font-weight:700;font-size:clamp(2rem,6vw,4.8rem);line-height:1.04;letter-spacing:-.03em;color:#fff;max-width:18ch}
.mp-pov__big em{font-style:normal;color:var(--pass)}

.mp-pov__cue,.mp-gate__cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);align-self:end;font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb,var(--paper) 56%,transparent);display:flex;flex-direction:column;align-items:center;gap:6px}
.mp-pov__cue i,.mp-gate__cue i{color:var(--pass);animation:mp-bob 2s ease-in-out infinite}

/* the gate — the seal stamps in WITH the sentence (its entrance is the fixed .mp-cert, JS-driven), copy sits below it */
.mp-gate__copy{position:relative;text-align:center;padding:0 var(--mx);transform:translateY(clamp(44px,7vh,92px))}
.mp-gate__pre{margin:0 0 clamp(16px,2.4vw,26px);font-family:var(--f-mono);font-size:clamp(13px,1.9vw,18px);letter-spacing:.12em;text-transform:uppercase;color:color-mix(in srgb,var(--paper) 62%,transparent);opacity:0}
.mp-gate__big{margin:0;font-weight:800;font-size:clamp(2.5rem,7.6vw,6rem);letter-spacing:-.03em;line-height:1;color:#fff;opacity:0;text-shadow:0 4px 40px rgba(5,12,22,.7)}
.mp-gate__big em{font-style:normal;color:var(--pass)}

/* content sits above the fixed field */
.mp-insight,.mp-name,.mp-move,.mp-steps,.mp-mark,.mp-system,.mp-product,.mp-outcome,.mp-end{position:relative;z-index:2;background:transparent!important}

/* reduced motion — static, no field/scrub motion */
body.reduce .mp-pov{height:auto}
body.reduce .mp-pov__stage{position:static;height:auto;min-height:100svh;padding:16vh 0}
body.reduce .mp-pov__seq,body.reduce .mp-pov__cost,body.reduce .mp-pov__ecg{display:none}
body.reduce .mp-pov__promise{opacity:1}
body.reduce .mp-gate__pre,body.reduce .mp-gate__big{opacity:1}
body.reduce .mp-cert{opacity:1;transform:none}

/* =========================================================
   01 · THE WALL
   ========================================================= */
.mp-wall{background:var(--navy)}
.mp-wall__stat{margin:0 0 clamp(44px,7vw,86px);font-weight:400;line-height:1.15;font-size:clamp(1.6rem,3.4vw,2.7rem);
  color:color-mix(in srgb,var(--paper) 92%,transparent);max-width:var(--maxw);margin-inline:auto;letter-spacing:-.01em}
.mp-wall__stat b{font-weight:500;color:var(--slate);display:inline}
.mp-wall__big{font-weight:800;font-size:clamp(3.4rem,12vw,9rem);letter-spacing:-.04em;line-height:.9;color:var(--paper);
  display:block;margin-top:.1em}
.mp-wall__big--acc{color:var(--pass)}
.mp-wall__cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px)}
.mp-wall__cols p{margin:0;font-size:clamp(15px,1.55vw,18px);color:color-mix(in srgb,var(--paper) 78%,transparent);line-height:1.62}
.mp-wall__cols b{color:var(--paper);font-weight:600}
.mp-wall__cols em{color:var(--pass);font-style:normal}
@media (max-width:740px){.mp-wall__cols{grid-template-columns:1fr;gap:24px}}

/* =========================================================
   02 · INSIGHT
   ========================================================= */
.mp-insight{background:var(--navy-deep);text-align:center;overflow:hidden}
.mp-insight__atmos{position:absolute;inset:0;pointer-events:none;background:radial-gradient(50% 60% at 50% 50%,color-mix(in srgb,var(--green) 14%,transparent),transparent 72%)}
.mp-insight .mp-label{margin-bottom:clamp(28px,5vw,52px)}
.mp-insight__quote{position:relative;margin:0 auto;max-width:17ch;font-family:var(--f);font-weight:600;
  font-size:clamp(2.3rem,7vw,6rem);line-height:1.02;letter-spacing:-.03em;color:var(--paper)}
.mp-insight__sub{position:relative;margin:clamp(34px,5vw,52px) auto 0;max-width:52ch;font-size:clamp(15px,1.7vw,19px);color:color-mix(in srgb,var(--paper) 76%,transparent);line-height:1.6}
.mp-insight__sub em{color:var(--pass);font-style:normal;font-weight:600}
/* web: spread it — quote anchored left, the reading pushed to the right, using the width */
@media (min-width:900px){
  .mp-insight{text-align:left;max-width:var(--maxw);margin-inline:auto;display:grid;grid-template-columns:1.5fr 1fr;column-gap:clamp(48px,7vw,120px);align-items:end}
  .mp-insight__atmos{left:-50%;width:200%}
  .mp-insight .mp-label{grid-column:1/-1;text-align:left}
  .mp-insight__quote{grid-column:1;margin:0;max-width:none;font-size:clamp(3rem,6.4vw,7rem)}
  .mp-insight__sub{grid-column:2;margin:0;max-width:42ch;padding-bottom:.6em}
}

/* =========================================================
   03 · THE NAME
   ========================================================= */
.mp-name{background:var(--navy);text-align:center}
.mp-name__build{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 18px;margin-bottom:clamp(28px,4vw,44px)}
.mp-name__chip{display:inline-flex;flex-direction:column;gap:5px;align-items:center;font-weight:700;font-size:clamp(1.1rem,2.4vw,1.7rem);letter-spacing:-.01em;
  border:1px solid var(--line);border-radius:14px;padding:14px 22px;background:color-mix(in srgb,var(--paper) 3%,transparent)}
.mp-name__chip i{font-style:normal;font-weight:500;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate)}
.mp-name__plus{color:var(--pass);font-weight:700;font-size:1.3rem}
.mp-name__line{font-weight:600;font-size:clamp(1.4rem,3.6vw,2.6rem);letter-spacing:-.02em;color:var(--paper);margin:0 auto clamp(48px,8vw,96px);max-width:20ch}
.mp-name__line em{color:var(--pass);font-style:italic}
@media (max-width:560px){.mp-name__build{flex-direction:column;gap:12px}.mp-name__plus{display:none}.mp-name__chip{width:100%;flex-direction:row;justify-content:space-between;gap:14px}.mp-name__chip i{text-align:right}}

.mp-uu{margin:0;display:flex;flex-direction:column;align-items:center;gap:clamp(20px,3vw,30px)}
.mp-uu__glyph{font-weight:800;font-size:clamp(4rem,16vw,12rem);letter-spacing:-.04em;line-height:.85;color:color-mix(in srgb,var(--paper) 30%,transparent)}
.mp-uu__u{position:relative;color:var(--paper)}
/* hide the real diaeresis, draw our own two dots so we can animate them lifting into the mark */
.mp-uu__u{ }
.mp-uu__d{position:absolute;top:-.02em;width:.155em;height:.155em;border-radius:50%;background:var(--pass);
  box-shadow:0 0 .18em color-mix(in srgb,var(--pass) 75%,transparent);opacity:0;transform:translateY(8px) scale(.6)}
.mp-uu__d--l{left:.13em}.mp-uu__d--r{left:.43em}
.mp-uu.in .mp-uu__d{opacity:1;transform:none;transition:opacity .7s var(--ease) .3s,transform .8s var(--ease) .3s}
.mp-uu.in .mp-uu__d--r{transition-delay:.45s}
.mp-uu figcaption{max-width:30ch;font-size:clamp(14px,1.6vw,17px);color:color-mix(in srgb,var(--paper) 74%,transparent);line-height:1.55}
.mp-uu figcaption b{color:var(--pass);font-weight:700}
/* web: an editorial spread — the wordplay reads down the left, the giant Prüf hinge owns the right */
@media (min-width:900px){
  .mp-name{text-align:left;max-width:var(--maxw);margin-inline:auto;display:grid;
    grid-template-columns:1.04fr .96fr;grid-template-areas:"label label" "build glyph" "line glyph";
    column-gap:clamp(48px,7vw,116px);row-gap:clamp(22px,3vw,40px);align-items:start}
  .mp-name .mp-label{grid-area:label;margin:0}
  .mp-name__build{grid-area:build;justify-content:flex-start;margin:0;align-self:end}
  .mp-name__line{grid-area:line;margin:0;text-align:left;max-width:22ch;align-self:start}
  .mp-uu{grid-area:glyph;align-items:flex-start;align-self:center;justify-self:start}
  .mp-uu figcaption{text-align:left;max-width:28ch}
}

/* =========================================================
   04 · THE MOVE
   ========================================================= */
.mp-move{background:var(--navy-deep)}
.mp-move__lead{font-weight:700;font-size:clamp(1.9rem,5vw,4rem);letter-spacing:-.03em;line-height:1.02;margin:0 0 clamp(44px,7vw,80px);max-width:var(--maxw);margin-inline:auto}
.mp-move__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,30px)}
.mp-move__grid--six{grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,40px) clamp(22px,3vw,48px)}
.mp-move__grid article{border-top:1px solid var(--line);padding-top:18px}
.mp-move__grid span{display:block;font-weight:700;font-size:clamp(1.1rem,1.6vw,1.35rem);color:var(--pass);margin-bottom:12px;letter-spacing:-.01em}
.mp-tool__code{display:inline-block;font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.08em;color:var(--pass);
  background:color-mix(in srgb,var(--pass) 11%,transparent);border:1px solid color-mix(in srgb,var(--pass) 28%,transparent);border-radius:6px;padding:3px 8px;margin-bottom:14px}
.mp-move__grid article h3{margin:0 0 8px;font-weight:600;font-size:clamp(1.02rem,1.5vw,1.22rem);letter-spacing:-.01em;color:var(--paper)}
.mp-move__grid p{margin:0;font-size:14px;line-height:1.58;color:color-mix(in srgb,var(--paper) 74%,transparent)}
.mp-move__grid em{color:var(--paper);font-style:normal;font-weight:600}
.mp-move__tag{text-align:center;margin:clamp(56px,9vw,110px) auto 0;max-width:22ch;font-weight:600;font-size:clamp(1.5rem,4vw,2.7rem);letter-spacing:-.02em;line-height:1.12;color:var(--paper)}
.mp-move__tag em{color:var(--pass);font-style:italic}
@media (max-width:880px){.mp-move__grid,.mp-move__grid--six{grid-template-columns:1fr 1fr;gap:26px}}
@media (max-width:520px){.mp-move__grid,.mp-move__grid--six{grid-template-columns:1fr}}

/* =========================================================
   05 · THE MARK
   ========================================================= */
.mp-mark{background:var(--navy);text-align:center}
.mp-mark .mp-label{text-align:center}
.mp-mark__stage{display:flex;justify-content:center;align-items:center;min-height:clamp(220px,40vh,420px);margin-bottom:clamp(34px,6vw,70px)}
/* the mark shown in its true positive form — on a clinic-paper chip (kills the navy-outline "magnet" read) */
.mp-mark__chip{display:flex;align-items:center;justify-content:center;width:clamp(200px,32vw,330px);aspect-ratio:1;
  background:var(--paper);border-radius:30px;box-shadow:0 36px 80px -34px rgba(0,0,0,.65),0 0 0 1px color-mix(in srgb,var(--navy) 18%,transparent)}
.mp-mark__logo{width:60%;display:block}
.mp-mark__logo svg{width:100%;height:auto;overflow:visible}
/* assemble: dots drop, shield layers build inward */
.mp-mark__logo .mp-eye{transform-box:fill-box;transform-origin:center;opacity:0;transform:translateY(-14px) scale(.5);transition:opacity .6s var(--ease),transform .7s var(--ease)}
.mp-mark__logo .mp-shield{opacity:0;transform-box:fill-box;transform-origin:center;transform:scale(.86);transition:opacity .7s var(--ease),transform .9s var(--ease)}
.mp-mark.in .mp-mark__logo .mp-eye{opacity:1;transform:none}
.mp-mark.in .mp-mark__logo .mp-eye:nth-of-type(2){transition-delay:.12s}
.mp-mark.in .mp-mark__logo .mp-shield{opacity:1;transform:none}
.mp-mark.in .mp-mark__logo .mp-shield:nth-of-type(1){transition-delay:.28s}
.mp-mark.in .mp-mark__logo .mp-shield:nth-of-type(2){transition-delay:.40s}
.mp-mark.in .mp-mark__logo .mp-shield:nth-of-type(3){transition-delay:.52s}
.mp-mark.in .mp-mark__logo .mp-shield:nth-of-type(4){transition-delay:.64s}
.mp-mark.in .mp-mark__logo .mp-cap{transition-delay:.72s}

.mp-mark__row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;max-width:var(--maxw);margin-inline:auto;text-align:left}
.mp-wordmark{width:100%;max-width:360px}
.mp-wordmark svg{width:100%;height:auto}
.mp-mark__note{margin:0;font-size:clamp(14px,1.55vw,17px);line-height:1.62;color:color-mix(in srgb,var(--paper) 76%,transparent)}
.mp-mark__note em{color:var(--pass);font-style:normal;font-weight:600}
@media (max-width:740px){.mp-mark__row{grid-template-columns:1fr;gap:26px;text-align:center}.mp-wordmark{margin-inline:auto}}

/* mark colours — nav + end live on navy (paper shield, green eyes); the §05 chip shows the TRUE positive form */
.mp-end__mark .st0,.mp-nav__mark .st0{fill:var(--pass)}
.mp-end__mark .st1,.mp-nav__mark .st1{fill:var(--paper)}
.mp-mark__logo .st1{fill:var(--navy)}
.mp-mark__logo .st0{fill:var(--green)}
.mp-wordmark .st0{fill:var(--pass)}
.mp-wordmark .st1{fill:var(--paper)}

/* =========================================================
   06 · SYSTEM
   ========================================================= */
.mp-system{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(34px,6vw,90px);align-items:start;background:var(--navy)}
.mp-swatches{display:grid;grid-template-columns:repeat(auto-fit,minmax(116px,1fr));gap:14px 12px}
.mp-swatch{min-width:0}
/* faint diagonal sheen so even navy-on-navy reads as a deliberate filled chip */
.mp-swatch b{display:block;height:84px;border-radius:12px;
  background:linear-gradient(155deg,color-mix(in srgb,var(--s) 92%,#fff),var(--s) 55%);
  border:1px solid color-mix(in srgb,var(--paper) 30%,transparent);box-shadow:inset 0 1px 0 rgba(255,255,255,.08);margin-bottom:12px}
.mp-swatch span{display:block;font-size:13px;font-weight:600;color:var(--paper)}
.mp-swatch i{font-style:normal;font-size:11px;letter-spacing:.08em;color:var(--slate);font-variant-numeric:tabular-nums}
.mp-swatch u{display:block;text-decoration:none;font-size:10.5px;line-height:1.35;color:color-mix(in srgb,var(--paper) 50%,transparent);margin-top:6px;max-width:16ch}
.mp-type__aa{font-weight:800;font-size:clamp(5rem,14vw,11rem);line-height:.8;letter-spacing:-.04em;color:var(--paper);margin-bottom:20px}
.mp-type__glyphs{font-weight:600;font-size:clamp(1.3rem,3vw,2rem);letter-spacing:-.01em;color:var(--pass);margin:0 0 10px}
.mp-type__line{margin:0;font-size:14.5px;line-height:1.55;color:color-mix(in srgb,var(--paper) 72%,transparent);max-width:34ch}
@media (max-width:820px){.mp-system{grid-template-columns:1fr;gap:46px}}

/* =========================================================
   THE IDENTITY, IN USE — the system off the page
   ========================================================= */
.mp-brand{text-align:center}
.mp-brand__lead{font-weight:600;font-size:clamp(1.4rem,3.4vw,2.4rem);letter-spacing:-.02em;line-height:1.12;color:var(--paper);margin:0 auto clamp(38px,6vw,68px);max-width:24ch}
.mp-brand__lead em{color:var(--pass);font-style:italic}
.mp-brand__grid{max-width:var(--maxw);margin-inline:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px);text-align:left}
.mp-brand__tile{margin:0;position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;background:var(--navy-2)}
.mp-brand__tile img{width:62%;height:auto;position:relative;z-index:1}
.mp-brand__tile figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:16px 18px;font-size:12.5px;line-height:1.42;color:color-mix(in srgb,var(--paper) 76%,transparent);background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--navy-deep) 92%,transparent) 62%)}
.mp-brand__tile figcaption b{display:block;color:var(--pass);font-weight:600;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:5px}
.mp-brand__tile--pattern{background:url('assets/brand/pattern-01.svg') center/cover, var(--navy)}
.mp-brand__tile--paper{background:var(--paper)}
.mp-brand__tile--paper img{width:80%}
.mp-brand__tile--paper figcaption{color:color-mix(in srgb,var(--navy) 82%,transparent);background:linear-gradient(180deg,transparent,color-mix(in srgb,#fff 82%,transparent) 60%)}
.mp-brand__tile--paper figcaption b{color:var(--green)}
.mp-brand__tile--seal{background:radial-gradient(70% 70% at 50% 38%,var(--navy-2),var(--navy-deep))}
.mp-brand__tile--seal img{width:50%}
@media (max-width:740px){.mp-brand__grid{grid-template-columns:1fr;gap:14px}.mp-brand__tile{aspect-ratio:16/9}}

/* =========================================================
   07 · THE PRODUCT
   ========================================================= */
.mp-product{background:linear-gradient(180deg,var(--navy),var(--navy-deep));text-align:center;overflow:hidden}
.mp-product__head{font-weight:700;font-size:clamp(1.9rem,5vw,3.6rem);letter-spacing:-.03em;margin:0 auto clamp(16px,2vw,24px);max-width:16ch}
.mp-phones__hint{margin:0 auto clamp(40px,6vw,72px);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate)}
.mp-phones__hint i{color:var(--pass);font-style:normal}
.mp-phones__hint span{color:var(--pass)}
/* real-screenshot phone screens — the actual app UI in a device frame */
.mp-screen--shot{padding:0;overflow:hidden}
.mp-screen--shot img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
.mp-phone--live .mp-screen{box-shadow:0 40px 80px -28px rgba(0,0,0,.72),0 0 0 1px color-mix(in srgb,var(--pass) 46%,transparent),inset 0 0 0 6px color-mix(in srgb,var(--pass) 7%,transparent)}
.mp-phone--live figcaption{color:var(--pass);display:inline-flex;align-items:center}
.mp-phone__dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--pass);margin-right:7px;box-shadow:0 0 8px var(--pass);animation:mp-livedot 1.5s ease-in-out infinite}
@keyframes mp-livedot{0%,100%{opacity:.35}50%{opacity:1}}
body.reduce .mp-phone__dot{animation:none}
.mp-phones{display:flex;justify-content:center;align-items:flex-end;gap:clamp(16px,2.2vw,32px);flex-wrap:wrap}
.mp-phone{margin:0;display:flex;flex-direction:column;align-items:center;gap:16px;width:min(244px,82vw)}
.mp-phone--lift{transform:translateY(-18px)}
.mp-phone figcaption{font-size:12px;letter-spacing:.04em;color:var(--slate)}
/* mobile: re-author as a full-bleed snap-carousel, not three shrunk phones in a column */
@media (max-width:880px){
  .mp-phones{flex-wrap:nowrap;justify-content:flex-start;align-items:stretch;overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;gap:16px;padding:4px 14vw 10px;margin-inline:calc(var(--mx)*-1);scrollbar-width:none}
  .mp-phones::-webkit-scrollbar{display:none}
  .mp-phone{flex:0 0 auto;width:72vw;max-width:300px;scroll-snap-align:center}
  .mp-phone--lift{transform:none}
}

.mp-screen{width:100%;aspect-ratio:9/19;border-radius:32px;background:var(--navy-deep);
  border:1px solid var(--line);padding:10px;box-shadow:0 40px 80px -30px rgba(0,0,0,.7),inset 0 0 0 6px color-mix(in srgb,var(--paper) 4%,transparent);
  position:relative;overflow:hidden;text-align:left}
.mp-screen__bar{display:flex;justify-content:space-between;align-items:center;padding:6px 14px 10px;font-size:11px;font-weight:600;color:var(--slate);font-variant-numeric:tabular-nums}
.mp-screen__sig{width:16px;height:9px;border-radius:2px;background:var(--slate);opacity:.6}
.mp-screen__bar--light{color:var(--navy-deep)}.mp-screen__bar--light .mp-screen__sig{background:var(--navy-deep)}

.mp-app{padding:6px 16px 16px;display:flex;flex-direction:column;height:calc(100% - 30px)}
.mp-app__crumb{margin:0 0 14px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--pass);font-weight:600}
.mp-app__case{margin:0 0 10px;font-weight:800;font-size:26px;letter-spacing:-.02em;color:var(--paper)}
.mp-app__q{margin:0 0 18px;font-size:13px;line-height:1.45;color:color-mix(in srgb,var(--paper) 84%,transparent)}
.mp-app__opts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.mp-app__opts li{font-size:13px;font-weight:500;padding:12px 14px;border-radius:11px;border:1px solid var(--line);
  background:color-mix(in srgb,var(--paper) 4%,transparent);color:var(--paper);position:relative;transition:.4s var(--ease);cursor:pointer}
.mp-app__opts li:hover{border-color:color-mix(in srgb,var(--pass) 55%,var(--line))}
.mp-app__opts.answered li{cursor:default}
.mp-app__opts.answered li:not(.is-revealed):not(.is-wrong){opacity:.5}
.mp-app__opts li.is-correct.is-revealed{border-color:var(--pass);background:color-mix(in srgb,var(--pass) 16%,transparent);color:#eafff7;font-weight:600}
.mp-app__opts li.is-correct.is-revealed::after{content:"✓";position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--pass);font-weight:800}
.mp-app__opts li.is-wrong{border-color:var(--wrong);background:color-mix(in srgb,var(--wrong) 15%,transparent);color:#ffe9e7;font-weight:600}
.mp-app__opts li.is-wrong::after{content:"✕";position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--wrong);font-weight:800}
.mp-app__hint{margin:14px 0 0;font-size:11px;text-align:center;color:var(--slate);letter-spacing:.04em;transition:opacity .3s}
/* the clinical explanation reveals once the question is answered */
.mp-app__tldr{margin-top:0;font-size:11px;line-height:1.5;color:color-mix(in srgb,var(--paper) 84%,transparent);
  background:color-mix(in srgb,var(--pass) 10%,transparent);border-left:2px solid var(--pass);border-radius:0 8px 8px 0;
  max-height:0;opacity:0;padding:0 11px;overflow:hidden;transition:max-height .55s var(--ease),opacity .4s var(--ease),padding .4s var(--ease),margin-top .4s var(--ease)}
.mp-app__tldr b{color:var(--pass);font-weight:700;letter-spacing:.05em;margin-right:5px}
.mp-app__tldr i{color:var(--slate);font-style:normal}
.mp-app__opts.answered ~ .mp-app__tldr{max-height:160px;opacity:1;padding:10px 11px;margin-top:11px}
.mp-app__opts.answered ~ .mp-app__hint{opacity:0}

/* dashboard */
.mp-app--dash{align-items:stretch}
.mp-ring{position:relative;width:128px;height:128px;margin:6px auto 18px}
.mp-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.mp-ring__bg{fill:none;stroke:var(--line);stroke-width:9}
.mp-ring__fg{fill:none;stroke:url(#mpgrad);stroke:var(--pass);stroke-width:9;stroke-linecap:round;
  stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset 1.4s var(--ease)}
.mp-phone.is-in .mp-ring__fg{stroke-dashoffset:72}
.mp-ring__num{position:absolute;inset:0;display:flex;align-items:baseline;justify-content:center;gap:2px;font-weight:800;color:var(--paper)}
.mp-ring__num b{font-size:34px;letter-spacing:-.03em;line-height:1}.mp-ring__num span{font-size:14px;color:var(--pass);font-weight:700}
.mp-bars{display:flex;flex-direction:column;gap:13px;margin-bottom:18px}
.mp-barrow{display:flex;flex-direction:column;gap:6px}
.mp-barrow span{font-size:11.5px;color:color-mix(in srgb,var(--paper) 80%,transparent);font-weight:500}
.mp-barrow i{height:6px;border-radius:4px;background:var(--line);position:relative;overflow:hidden}
.mp-barrow i::after{content:"";position:absolute;inset:0;width:var(--w);background:linear-gradient(90deg,var(--green),var(--pass));border-radius:4px;transform:scaleX(0);transform-origin:0 50%;transition:transform 1s var(--ease) .2s}
.mp-phone.is-in .mp-barrow i::after{transform:scaleX(1)}
.mp-app__streak{margin:auto 0 0;font-size:12px;color:var(--slate);text-align:center}
.mp-app__streak b{color:var(--pass);font-weight:700}

/* pass screen */
.mp-screen--pass{background:linear-gradient(180deg,var(--green),#015c46)}
.mp-app--pass{align-items:center;justify-content:center;text-align:center;gap:14px;color:#fff}
.mp-pass__tick{width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.mp-pass__tick svg{width:46px;height:46px}
.mp-pass__tick path{fill:none;stroke:#fff;stroke-width:7;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:80;stroke-dashoffset:80;transition:stroke-dashoffset .8s var(--ease) .3s}
.mp-phone.is-in .mp-pass__tick path{stroke-dashoffset:0}
.mp-phone.is-in .mp-pass__tick{animation:mp-pop .6s var(--ease) .2s both}
@keyframes mp-pop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.mp-pass__big{margin:0;font-weight:800;font-size:34px;letter-spacing:-.02em}
.mp-pass__sub{margin:0;font-size:13px;color:rgba(255,255,255,.86);max-width:22ch}
.mp-pass__chip{margin-top:10px;font-size:11px;font-weight:600;letter-spacing:.06em;padding:8px 16px;border-radius:100px;background:rgba(255,255,255,.16)}

/* =========================================================
   08 · OUTCOME
   ========================================================= */
.mp-outcome{background:var(--navy)}
.mp-outcome__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin-bottom:clamp(48px,8vw,90px)}
.mp-outcome__grid--four{grid-template-columns:repeat(4,1fr)}
.mp-stat{border-top:1px solid var(--line);padding-top:22px}
.mp-stat b{display:block;font-weight:800;font-size:clamp(1.9rem,3.4vw,2.7rem);letter-spacing:-.03em;color:var(--pass);margin-bottom:10px;line-height:1;font-variant-numeric:tabular-nums}
.mp-stat span{font-size:13.5px;line-height:1.5;color:color-mix(in srgb,var(--paper) 76%,transparent)}
.mp-outcome__line{max-width:var(--maxw);margin-inline:auto;font-weight:600;font-size:clamp(1.6rem,4.4vw,3.2rem);letter-spacing:-.025em;line-height:1.1;color:var(--paper)}
.mp-outcome__line em{color:var(--pass);font-style:italic;font-weight:700}
/* tabular figures everywhere numbers carry meaning — the clinical-data signature */
.mp-wall__big,.mp-ring__num,.mp-app__case,.mp-barrow,.mp-app__streak,.mp-swatch i{font-variant-numeric:tabular-nums}
@media (max-width:740px){.mp-outcome__grid{grid-template-columns:1fr;gap:0}.mp-outcome__grid--four{grid-template-columns:1fr 1fr;gap:0 22px}.mp-stat{padding:22px 0}.mp-outcome__grid:not(.mp-outcome__grid--four) .mp-stat+.mp-stat{border-top:1px solid var(--line-2)}}

/* =========================================================
   CLOSE
   ========================================================= */
.mp-end{min-height:92svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:var(--navy-deep);overflow:hidden}
.mp-end__atmos{position:absolute;inset:0;pointer-events:none;background:radial-gradient(50% 50% at 50% 60%,color-mix(in srgb,var(--green) 13%,transparent),transparent 72%)}
.mp-end__mark{width:clamp(70px,12vw,110px);margin-bottom:clamp(26px,4vw,40px);position:relative}
.mp-end__mark svg{width:100%;height:auto;overflow:visible}
.mp-end__pre{position:relative;margin:0 0 8px;font-size:clamp(14px,1.8vw,18px);color:var(--slate)}
.mp-end__big{position:relative;margin:0 0 clamp(40px,7vw,72px);font-family:var(--f);font-weight:800;font-size:clamp(2.6rem,9vw,7rem);letter-spacing:-.03em;line-height:.98;color:var(--paper)}
.mp-end__foot{position:relative;display:flex;flex-direction:column;gap:12px;max-width:54ch}
.mp-end__credit{margin:0;font-size:14px;color:color-mix(in srgb,var(--paper) 82%,transparent)}
.mp-end__credit a{color:var(--pass);border-bottom:1px solid color-mix(in srgb,var(--pass) 50%,transparent)}
.mp-end__note{margin:0;font-size:11.5px;line-height:1.5;color:var(--slate-dim)}
.mp-next{position:relative;margin-top:clamp(40px,6vw,64px);display:inline-flex;flex-direction:column;gap:3px;border:1px solid var(--line);border-radius:14px;padding:16px 28px;transition:border-color .3s,background .3s}
.mp-next:hover{border-color:var(--pass);background:color-mix(in srgb,var(--pass) 8%,transparent)}
.mp-next__label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate)}
.mp-next__name{font-weight:600;font-size:16px;color:var(--paper)}

/* =========================================================
   COMPONENTS — how-it-works · sources · specialties · live product
   ========================================================= */
.mp-steps{background:var(--navy);position:relative;overflow:hidden}
.mp-steps::before,.mp-outcome::before{content:"";position:absolute;inset:0;background:url('assets/brand/pattern-01.svg') center top/min(640px,88%) repeat;opacity:.035;mix-blend-mode:screen;pointer-events:none}
.mp-outcome{position:relative;overflow:hidden}
.mp-steps__head,.mp-steps__grid,.mp-outcome__grid,.mp-sources,.mp-specs,.mp-outcome__line{position:relative;z-index:1}
.mp-steps__head{max-width:var(--maxw);margin:0 auto clamp(38px,6vw,68px)}
.mp-steps__lead{font-weight:600;font-size:clamp(1.6rem,4vw,2.8rem);letter-spacing:-.03em;color:var(--paper);margin:0;max-width:18ch}
.mp-steps__lead em{color:var(--pass);font-style:normal}
.mp-steps__grid{max-width:var(--maxw);margin-inline:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px)}
.mp-step{position:relative;border-top:1px solid var(--line);padding-top:22px;transition:border-color .3s}
.mp-step:hover{border-color:color-mix(in srgb,var(--pass) 55%,var(--line))}
.mp-step__n{display:block;font-family:var(--f-mono);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:500;color:var(--pass);letter-spacing:-.02em;line-height:1;margin-bottom:18px;font-variant-numeric:tabular-nums}
.mp-step h3{margin:0 0 10px;font-weight:600;font-size:clamp(1.2rem,2vw,1.5rem);letter-spacing:-.01em;color:var(--paper)}
.mp-step p{margin:0 0 16px;font-size:14.5px;line-height:1.6;color:color-mix(in srgb,var(--paper) 74%,transparent)}
.mp-step__tag{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--slate);text-transform:uppercase}
@media (max-width:740px){.mp-steps__grid{grid-template-columns:1fr;gap:30px}}

.mp-sources{max-width:var(--maxw);margin:clamp(46px,8vw,88px) auto 0}
.mp-sources__lab{font-size:13px;color:var(--slate);margin:0 0 16px}
.mp-sources__lab span{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.12em;color:var(--pass);font-size:11px;margin-right:8px}
.mp-sources__bar{display:flex;gap:6px;align-items:stretch;min-height:92px}
.mp-sources__seg{flex:var(--w) 1 0;min-width:72px;display:flex;flex-direction:column;justify-content:flex-end;gap:4px;padding:14px 14px 14px;border-radius:10px;background:color-mix(in srgb,var(--paper) 4%,transparent);position:relative;overflow:hidden}
.mp-sources__seg i{position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,var(--green),var(--pass))}
.mp-sources__seg b{font-weight:800;font-size:clamp(1.1rem,2vw,1.7rem);color:var(--paper);font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}
.mp-sources__seg em{font-family:var(--f-mono);font-style:normal;font-size:10.5px;letter-spacing:.03em;color:var(--slate)}
.mp-sources__seg--sm em{font-size:9px}
@media (max-width:560px){.mp-sources__bar{flex-direction:column;min-height:0}.mp-sources__seg{flex:none;min-height:66px}}

.mp-specs{max-width:var(--maxw);margin:clamp(32px,5vw,54px) auto clamp(46px,8vw,88px)}
.mp-specs__lab{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--pass);margin:0 0 16px}
.mp-specs__grid{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.mp-specs__grid li{font-size:13px;color:color-mix(in srgb,var(--paper) 82%,transparent);border:1px solid var(--line);border-radius:100px;padding:8px 15px;transition:.25s var(--ease);cursor:default}
.mp-specs__grid li:hover{border-color:var(--pass);color:#fff;background:color-mix(in srgb,var(--pass) 12%,transparent)}

.mp-live{max-width:1100px;margin:clamp(46px,7vw,80px) auto 0;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:0 50px 100px -42px rgba(0,0,0,.7);background:var(--navy-deep)}
.mp-live__bar{display:flex;align-items:center;gap:7px;padding:11px 16px;background:color-mix(in srgb,var(--paper) 5%,var(--navy-deep));border-bottom:1px solid var(--line)}
.mp-live__bar i{width:10px;height:10px;border-radius:50%;background:color-mix(in srgb,var(--paper) 22%,transparent)}
.mp-live__bar span{margin-left:12px;font-family:var(--f-mono);font-size:11px;color:var(--slate);letter-spacing:.04em}
.mp-live__shot{width:100%;display:block}
.mp-live figcaption{padding:16px;text-align:center;font-size:14px;color:var(--slate)}
.mp-live figcaption b{color:var(--pass)}

/* gentle zoom-in reveal on whole sections — "zoom in and reveal the sections" */
[data-scene].mp-zoom{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-scene].mp-zoom.in{opacity:1;transform:none}

/* =========================================================
   reduced motion
   ========================================================= */
body.reduce [data-scene].mp-zoom{transform:none;opacity:1;transition:none}
body.reduce *{animation:none!important}
body.reduce .mp-ring__fg,body.reduce .mp-barrow i::after,body.reduce .mp-pass__tick path{transition:none}
body.reduce .mp-ring__fg{stroke-dashoffset:72}
body.reduce .mp-barrow i::after{transform:scaleX(1)}
body.reduce .mp-pass__tick path{stroke-dashoffset:0}
body.reduce .mp-uu__d{opacity:1;transform:none}
