/* SkinSafe marcomms — site.css
   Decomposed from skinsafe-marcomms-v3-story-funnel.html (design authority).
   Self-hosted fonts; no runtime third-party requests. */

/* Archivo — 400 900 — latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400 900;
  font-stretch: 62% 125%;
  font-display: swap;
  src: url('../fonts/archivo-400-900-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Archivo — 400 900 — latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400 900;
  font-stretch: 62% 125%;
  font-display: swap;
  src: url('../fonts/archivo-400-900-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Archivo Black — 400 — latin-ext */
@font-face {
  font-family: 'Archivo Black';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/archivo-black-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Archivo Black — 400 — latin */
@font-face {
  font-family: 'Archivo Black';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/archivo-black-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* IBM Plex Mono — 400 — latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/ibm-plex-mono-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* IBM Plex Mono — 400 — latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/ibm-plex-mono-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* IBM Plex Mono — 500 — latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/ibm-plex-mono-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* IBM Plex Mono — 500 — latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/ibm-plex-mono-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Inter — 400 500 (variable) — latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('../fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Inter — 400 500 (variable) — latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('../fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root{
  --ink:#0A0A0A; --surface:rgba(20,20,18,.66); --bone:#EDE8DF; --steel:#8A8782; --seal:#D9A441;
  --hairline:rgba(237,232,223,0.14);
  --display:'Archivo Black','Archivo',sans-serif; --sans:'Inter',sans-serif; --mono:'IBM Plex Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--ink);color:var(--bone);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--seal);color:var(--ink)}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--seal);outline-offset:3px}
img,svg,canvas{display:block}

#gl{position:fixed;inset:0;width:100vw;height:100vh;z-index:0}
.scrim{position:fixed;inset:0;z-index:1;pointer-events:none;background:radial-gradient(120% 90% at 50% 10%,rgba(10,10,10,0) 0%,rgba(10,10,10,.55) 78%,rgba(10,10,10,.82) 100%)}
main,header,footer,.nav,.ticker,.rail{position:relative;z-index:2}

.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 32px}
.nav .brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:18px;letter-spacing:.06em}
.nav .dot{color:var(--seal)}
.nav .actions{display:flex;align-items:center;gap:18px}
.nav .login{font-size:14px;color:var(--steel)}
.nav .login:hover{color:var(--bone)}
.btn{display:inline-block;font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;padding:13px 26px;border:1px solid var(--bone);color:var(--bone);background:transparent;cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.btn:hover{background:var(--bone);color:var(--ink)}
.btn.gold{border-color:var(--seal);color:var(--seal)}
.btn.gold:hover{background:var(--seal);color:var(--ink)}
@media(max-width:760px){.nav{padding:14px 18px}}

.rail{position:fixed;left:26px;top:50%;transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;gap:18px}
.rail a{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--steel);transition:color .3s}
.rail a .pip{width:7px;height:7px;border-radius:50%;border:1px solid var(--steel);transition:all .3s}
.rail a.on{color:var(--bone)}
.rail a.on .pip{background:var(--seal);border-color:var(--seal);box-shadow:0 0 0 5px rgba(217,164,65,.15)}
.rail a .lbl{opacity:0;transform:translateX(-6px);transition:all .3s}
.rail a:hover .lbl,.rail a.on .lbl{opacity:1;transform:none}
@media(max-width:1100px){.rail{display:none}}

.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:140px 7vw 90px;position:relative}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--steel);text-transform:uppercase;margin-bottom:24px}
.hero h1{font-family:var(--display);font-size:clamp(48px,8.5vw,128px);line-height:.94;letter-spacing:-.01em;text-transform:uppercase}
.hero h1 .gold{color:var(--seal)}
.hero .sub{max-width:600px;margin-top:30px;color:var(--steel);font-size:19px}
.hero .sub strong{color:var(--bone);font-weight:500}
.hero .ctas{display:flex;gap:16px;margin-top:42px;flex-wrap:wrap}
.recline{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--seal);margin-top:60px}
.scrollcue{position:absolute;bottom:34px;left:7vw;font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--steel);display:flex;align-items:center;gap:12px}
.scrollcue .line{width:54px;height:1px;background:var(--steel);transform-origin:left;animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleX(.3);opacity:.4}50%{transform:scaleX(1);opacity:1}}

.ticker{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);overflow:hidden;padding:16px 0;background:rgba(10,10,10,.6)}
.ticker .track{display:flex;gap:64px;white-space:nowrap;font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--steel);will-change:transform}
.ticker b{color:var(--seal);font-weight:500}

section.chapter{position:relative;padding:22vh 7vw;overflow:clip}
section.slim{padding:14vh 7vw}
.ghost{position:absolute;top:6vh;left:0;right:0;font-family:var(--display);font-size:clamp(90px,22vw,340px);line-height:1;text-transform:uppercase;color:transparent;-webkit-text-stroke:1px rgba(237,232,223,.10);white-space:nowrap;pointer-events:none;user-select:none}
.wrap{max-width:1100px;margin:0 auto;position:relative;z-index:1}
.chapter h2{font-family:var(--display);font-size:clamp(36px,5.6vw,80px);line-height:1;text-transform:uppercase;max-width:16ch}
.chapter .lede{max-width:540px;color:var(--steel);margin-top:24px;font-size:18px}
.chapter .lede strong{color:var(--bone);font-weight:500}
.w{display:inline-block;overflow:hidden;vertical-align:top}
.wi{display:inline-block;will-change:transform}

/* incidents */
.incidents{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;background:var(--hairline);margin-top:70px;border:1px solid var(--hairline)}
.incident{background:var(--surface);backdrop-filter:blur(6px);padding:34px 30px}
.incident .tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--seal);text-transform:uppercase}
.incident h3{font-weight:500;font-size:20px;margin-top:14px;line-height:1.4}
.incident p{color:var(--steel);font-size:15px;margin-top:12px}
.source{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--steel);margin-top:34px;text-transform:uppercase}

/* record — pinned scene */
.pinstage{display:grid;grid-template-columns:1fr 1.2fr;gap:7vw;align-items:start;margin-top:8vh}
.pinleft{position:relative}
.stagewrap{position:relative;padding-left:34px}
.vline{position:absolute;left:0;top:0;bottom:0;width:1px;background:var(--hairline)}
.vfill{position:absolute;left:0;top:0;width:1px;height:100%;background:var(--seal);transform:scaleY(0);transform-origin:top}
.stages{list-style:none}
.stage{padding:26px 0;border-bottom:1px solid var(--hairline);opacity:.22;transform:translateX(18px);transition:opacity .4s,transform .4s}
.stage.on{opacity:1;transform:none}
.stage:last-child{border-bottom:none}
.stage .code{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--steel)}
.stage.on .code{color:var(--seal)}
.stage h3{font-weight:500;font-size:21px;margin-top:6px}
.stage p{color:var(--steel);font-size:15px;margin-top:6px;max-width:52ch}
.stage.final.on h3{color:var(--seal)}
@media(max-width:900px){.pinstage{grid-template-columns:1fr}.progress{display:none}.stage{opacity:1;transform:none}}

/* law */
.regs{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:70px}
.reg{background:var(--surface);backdrop-filter:blur(6px);border:1px solid var(--hairline);padding:36px 30px}
.reg .ref{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--seal)}
.reg h3{font-weight:500;font-size:19px;margin-top:16px}
.reg p{color:var(--steel);font-size:15px;margin-top:10px}

/* supporting value */
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:56px}
.value{border-left:1px solid var(--hairline);padding:6px 0 6px 26px}
.value .tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--steel);text-transform:uppercase}
.value h3{font-weight:500;font-size:18px;margin-top:12px}
.value p{color:var(--steel);font-size:15px;margin-top:8px}
.discs{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1px;background:var(--hairline);border:1px solid var(--hairline);margin-top:56px}
.disc{background:var(--surface);backdrop-filter:blur(6px);padding:30px 26px}
.disc h3{font-family:var(--display);font-size:18px;letter-spacing:.03em;text-transform:uppercase}
.disc h3 .d{color:var(--seal)}
.disc p{color:var(--steel);font-size:14px;margin-top:10px;line-height:1.6}
.founder{position:relative;margin:-18px 0 10px;max-width:420px}
.founder img{width:100%;height:auto;display:block;border:0}
.founder figcaption{position:absolute;left:8px;bottom:30px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--steel);text-transform:uppercase;line-height:1.9}
.founder figcaption b{color:var(--seal);font-weight:500}

/* proof */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;margin-top:70px}
.quote{background:var(--surface);backdrop-filter:blur(6px);border:1px solid var(--hairline);padding:40px 34px;position:relative}
.quote .markq{font-family:var(--display);font-size:54px;line-height:1;color:var(--seal)}
.quote p{font-size:19px;line-height:1.6;margin-top:14px}
.quote .who{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--steel);margin-top:26px;text-transform:uppercase}

/* call */
.signup .panel{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:64px;align-items:start}
.form{background:var(--surface);backdrop-filter:blur(8px);border:1px solid var(--hairline);padding:40px}
.form label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);margin:22px 0 8px}
.form label:first-of-type{margin-top:0}
.form input,.form select{width:100%;background:rgba(10,10,10,.7);border:1px solid var(--hairline);color:var(--bone);padding:13px 14px;font-family:var(--sans);font-size:16px}
.form input:hover,.form select:hover{border-color:var(--steel)}
.form .btn{width:100%;margin-top:30px}
.form .fine{font-size:13px;color:var(--steel);margin-top:18px}
.fset{border:none;margin:22px 0 0;padding:0}
.fset legend{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);margin-bottom:10px;padding:0}
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.checks.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:480px){.checks,.checks.three{grid-template-columns:1fr}}
.form .check{margin:0;display:block}
.check{position:relative}
.check input{position:absolute;opacity:0;inset:0;cursor:pointer}
.check span{display:flex;align-items:center;gap:12px;width:100%;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--hairline);padding:12px 14px;color:var(--steel);cursor:pointer;transition:border-color .2s,color .2s;user-select:none}
.check .bx{flex:0 0 16px;width:16px;height:16px;border:1px solid var(--steel);display:inline-flex;align-items:center;justify-content:center;font-size:11px;line-height:1;color:transparent;transition:background .2s,border-color .2s,color .2s}
.check.radio .bx{border-radius:50%;font-size:8px}
.check span:hover{border-color:var(--steel);color:var(--bone)}
.check input:checked + span{border-color:var(--seal);color:var(--bone)}
.check input:checked + span .bx{background:var(--seal);border-color:var(--seal);color:var(--ink)}
.check input:focus-visible + span{outline:2px solid var(--seal);outline-offset:3px}
.form .fine a{text-decoration:underline;text-underline-offset:3px}
.confirm{font-family:var(--mono);font-size:14px;color:var(--seal);line-height:1.8}
.aside h3{font-weight:500;font-size:20px}
.aside p{color:var(--steel);font-size:16px;margin-top:14px;max-width:46ch}
.aside .loginrow{margin-top:36px;padding-top:28px;border-top:1px solid var(--hairline);font-size:15px;color:var(--steel)}
.aside .loginrow a{color:var(--seal);text-decoration:underline;text-underline-offset:3px}
@media(max-width:900px){.signup .panel{grid-template-columns:1fr}}

footer{border-top:1px solid var(--hairline);padding:64px 7vw 48px;background:rgba(10,10,10,.75)}
.foot{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:40px}
.brandline{display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:16px;letter-spacing:.06em}
.brandline .dot{color:var(--seal)}
.legal{display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--steel);text-align:right}
.legal a:hover{color:var(--bone)}
.colophon{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--steel);margin-top:22px}
@media(max-width:760px){.foot{grid-template-columns:1fr}.legal{text-align:left}}

.hero-art{position:absolute;right:2vw;top:5vh;width:min(42vw,640px);opacity:.85;pointer-events:none;z-index:0}
.bp{position:absolute;pointer-events:none;z-index:0;opacity:.72;height:auto}
#clients .bp{right:-4vw;top:-2vh;width:min(50vw,740px)}
.valrow{display:flex;gap:48px;align-items:center;flex-wrap:wrap;margin-top:7vh}
.valrow .lede{margin-top:0;flex:1 1 320px}
.vimg{flex:0 1 400px;width:min(100%,440px);display:block;opacity:.92}
.inset{width:100%;max-width:520px;display:block;margin-top:34px;opacity:.92}
.lawband{margin-top:56px}
.lawband img{width:100%;height:clamp(220px,36vh,380px);object-fit:cover;object-position:center 40%;display:block;opacity:.9}
@media(max-width:980px){.hero-art{width:52vw;opacity:.7;top:2vh}#clients .bp{width:62vw;opacity:.55}}
@media(max-width:640px){.hero-art,#clients .bp{display:none}}
.fade{opacity:0;transform:translateY(40px)}
@media(prefers-reduced-motion:reduce){.fade{opacity:1;transform:none}.scrollcue .line{animation:none}}

/* replaces the prototype's sole inline style attribute (CSP: no inline styles) */
.lede-gap{margin-top:56px}

/* ---------------------------------------------------------------
   Document pages (legal, subprocessors, thanks, 404).
   Same nav + footer as index; no shader, no GSAP — plain ink/bone,
   prose-first. Composed from the prototype's existing tokens.
   --------------------------------------------------------------- */
.docpage{background:var(--ink)}
.docpage .nav{background:linear-gradient(180deg,rgba(10,10,10,.92) 55%,rgba(10,10,10,0));padding-bottom:28px}
.doc{max-width:760px;margin:0 auto;padding:160px 7vw 110px;position:relative;z-index:2}
.doc .eyebrow{margin-bottom:18px}
.doc h1{font-family:var(--display);font-size:clamp(34px,5.4vw,58px);line-height:1.02;text-transform:uppercase;letter-spacing:-.01em}
.doc .docmeta{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--steel);text-transform:uppercase;margin-top:18px}
.doc h2{font-family:var(--display);font-size:clamp(20px,2.6vw,26px);line-height:1.15;text-transform:uppercase;margin:58px 0 0}
.doc h3{font-weight:500;font-size:19px;margin:36px 0 0;color:var(--bone)}
.doc p{margin-top:18px;color:var(--bone);opacity:.92}
.doc p.lead{font-size:19px}
.doc strong{font-weight:500;color:var(--bone)}
.doc a{color:var(--seal);text-decoration:underline;text-underline-offset:3px}
.doc a:hover{color:var(--bone)}
.doc ul,.doc ol{margin:18px 0 0 22px;color:var(--bone)}
.doc li{margin-top:10px;opacity:.92}
.doc li::marker{color:var(--steel)}
.doc hr{border:none;border-top:1px solid var(--hairline);margin:54px 0 0}
.doc table{width:100%;border-collapse:collapse;margin-top:24px;border:1px solid var(--hairline)}
.doc th{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);text-align:left;padding:12px 14px;border-bottom:1px solid var(--hairline);background:var(--surface)}
.doc td{font-size:15px;padding:12px 14px;border-bottom:1px solid var(--hairline);vertical-align:top}
.doc tr:last-child td{border-bottom:none}
.doc td+td,.doc th+th{border-left:1px solid var(--hairline)}
@media(max-width:640px){.doc table{display:block;overflow-x:auto}}

/* status pages: 404 + thanks */
.status{min-height:100vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;max-width:760px;margin:0 auto;padding:140px 7vw 110px;position:relative;z-index:2}
.status svg{margin-bottom:34px}
.status .confirm{margin-top:8px}
.status h1{font-family:var(--display);font-size:clamp(34px,5.4vw,58px);line-height:1.02;text-transform:uppercase}
.status p{margin-top:18px;color:var(--steel);max-width:46ch}
.status .back{display:inline-block;margin-top:38px}

/* log-in affordances hidden until the app URL exists; remove this rule
   in the commit that wires the real URL at first studio onboarding */
.requires-app{display:none}
