/* ============================================================
   SALURA — "Editorial Clinic" design system
   Editorial Science (warm paper · variable serif · film grain)
   × Soft Clinical (floating bento · ultra-soft diffused depth)
   Awwwards-tier craft: double-bezel nesting, magnetic motion.
   ============================================================ */

:root{
  /* paper & ink */
  --paper:#f7f4ee;
  --paper-2:#fffdf8;
  --paper-3:#f1ede4;
  --card:#fffefb;
  --ink:#17140d;
  --ink-soft:#4d473b;
  --ink-faint:#8b8475;
  --rule:#e4ded1;
  --rule-2:#d8d1c0;
  /* signature: clay (warmth) · prussian (trust/data) · sage (calm) */
  --clay:#b14d35;
  --clay-deep:#8f3c28;
  --clay-soft:#f3e6df;
  --prussian:#1d4258;
  --prussian-soft:#e4ebef;
  --sage:#5f6e5c;
  --sage-soft:#e8ece4;
  --gold:#a8782e;
  /* soft diffused ambient shadows (Soft Clinical) */
  --sh-sm:0 1px 2px rgba(35,28,15,.04), 0 2px 6px rgba(35,28,15,.04);
  --sh:0 2px 4px rgba(35,28,15,.03), 0 12px 28px -10px rgba(35,28,15,.12);
  --sh-lg:0 4px 10px rgba(35,28,15,.04), 0 30px 60px -18px rgba(35,28,15,.18);
  --sh-xl:0 50px 100px -30px rgba(28,22,12,.26), 0 8px 24px -12px rgba(28,22,12,.12);
  /* inset highlight for double-bezel inner cores */
  --hi:inset 0 1px 0 rgba(255,255,255,.9);
  --font-display:"Fraunces","Newsreader",Georgia,serif;
  --font-ui:"Plus Jakarta Sans","Segoe UI",system-ui,sans-serif;
  --font-mono:"Spline Sans Mono",ui-monospace,Consolas,monospace;
  --ease:cubic-bezier(0.32,0.72,0,1);       /* lifts, shadows — long settle */
  --ease-out:cubic-bezier(0.16,1,0.3,1);    /* reveals — dramatic */
  --ease-fast:cubic-bezier(0.4,0,0.2,1);    /* hovers, color/bg < 300ms */
  /* on-brand focus ring (clay signature) */
  --focus-ring:0 0 0 3px var(--paper), 0 0 0 5px rgba(177,77,53,.55);
  /* radius scale + uniform double-bezel inset */
  --r-sm:12px; --r-md:16px; --r-lg:22px; --r-xl:28px; --r-2xl:34px; --r-inset:9px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-ui);
  font-size:16px;line-height:1.6;color:var(--ink-soft);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* smooth first paint — fades the whole composed page (chrome injected at
     DOMContentLoaded lands inside this window, so the nav never "pops") */
  animation:pageIn .55s var(--ease-out) both;
}
@keyframes pageIn{from{opacity:0}to{opacity:1}}
/* fixed film-grain — performance-safe (fixed, pointer-events:none) */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.4;
  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' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.09 0 0 0 0 0.08 0 0 0 0 0.05 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* warm ambient light blooms, very subtle, fixed */
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 520px at 88% -6%, rgba(177,77,53,.05), transparent 60%),
    radial-gradient(820px 560px at -4% 10%, rgba(29,66,88,.045), transparent 58%);
}
::selection{background:rgba(177,77,53,.16);color:var(--ink)}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:#cfc7b6;border-radius:9px;border:3px solid var(--paper)}
::-webkit-scrollbar-track{background:transparent}

a{color:inherit;text-decoration:none}
img,svg,canvas{display:block;max-width:100%}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);font-weight:480;letter-spacing:-.02em;line-height:1.04;
  font-optical-sizing:auto;font-variation-settings:"opsz" 96,"SOFT" 0,"WONK" 0}
/* vary weight + optical size with scale so headings aren't a monotone block */
h1.display{font-weight:500;font-variation-settings:"opsz" 144,"SOFT" 0,"WONK" 0}
.feat h3,.rb h4{font-weight:520;font-variation-settings:"opsz" 40,"SOFT" 0,"WONK" 0}
em{font-style:italic;font-variation-settings:"opsz" 120,"SOFT" 4,"WONK" 1}

.wrap{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:0 32px}
@media(max-width:640px){.wrap{padding:0 20px}}

/* ===================== fluid island nav ===================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;justify-content:center;pointer-events:none}
.site-header .bar{
  pointer-events:auto;margin-top:18px;
  display:flex;align-items:center;gap:22px;
  padding:9px 9px 9px 20px;border-radius:999px;
  background:rgba(255,253,248,.72);backdrop-filter:blur(18px) saturate(1.4);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:var(--sh), var(--hi);
  transition:box-shadow .5s var(--ease), background .5s var(--ease);
}
.site-header.scrolled .bar{box-shadow:var(--sh-lg), var(--hi);background:rgba(255,253,248,.86)}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:540;font-size:18px;color:var(--ink);letter-spacing:-.02em}
.brand .mark{width:30px;height:30px;flex:none;display:grid;place-items:center}
.s-nav{display:flex;gap:2px}
.s-nav a{position:relative;padding:8px 14px;border-radius:999px;font-size:13.5px;font-weight:500;color:var(--ink-soft);transition:color .2s var(--ease-fast),background .2s var(--ease-fast)}
.s-nav a:hover{color:var(--ink);background:rgba(23,20,13,.04)}
.s-nav a.here{color:var(--ink);background:rgba(23,20,13,.05)}
.s-nav a.here::after{content:"";position:absolute;left:50%;bottom:3px;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--clay)}
.h-actions{display:flex;gap:8px;align-items:center}
.nav-toggle{display:none}
@media(max-width:860px){
  .s-nav,.h-actions .btn-ghost{display:none}
  .nav-toggle{display:grid;place-items:center;width:40px;height:40px;border-radius:999px;background:rgba(23,20,13,.04);cursor:pointer;pointer-events:auto;border:none}
  .nav-toggle span{display:block;width:17px;height:1.5px;background:var(--ink);transition:transform .4s var(--ease),opacity .3s var(--ease)}
  .nav-toggle span+span{margin-top:4px}
}

/* full-screen menu overlay */
.menu-veil{position:fixed;inset:0;z-index:55;background:rgba(247,244,238,.86);backdrop-filter:blur(24px);
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:0 32px}
.menu-veil.open{opacity:1;visibility:visible}
.menu-veil a{font-family:var(--font-display);font-size:clamp(34px,9vw,64px);color:var(--ink);padding:8px 0;
  transform:translateY(40px);opacity:0;transition:transform .7s var(--ease),opacity .7s var(--ease)}
.menu-veil.open a{transform:none;opacity:1}
.menu-veil.open a:nth-child(1){transition-delay:.08s}
.menu-veil.open a:nth-child(2){transition-delay:.14s}
.menu-veil.open a:nth-child(3){transition-delay:.20s}
.menu-veil.open a:nth-child(4){transition-delay:.26s}
.menu-veil.open a:nth-child(5){transition-delay:.32s}

/* ===================== buttons (magnetic, island, button-in-button) ===================== */
/* --mx/--my = cursor magnet (set by JS), --lift = hover rise. Composed in one
   transform so the magnet and the spring-lift coexist instead of overwriting. */
.btn-g,.btn-spec{--mx:0px;--my:0px;--lift:0px}
.btn-g{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--ink);
  padding:11px 20px;border-radius:999px;cursor:pointer;
  background:var(--card);border:1px solid var(--rule-2);
  box-shadow:var(--sh-sm), var(--hi);
  transform:translate(var(--mx),calc(var(--my) + var(--lift)));
  transition:transform .18s var(--ease-fast),box-shadow .5s var(--ease),background .3s var(--ease);
}
.btn-g:hover{--lift:-2px;box-shadow:var(--sh), var(--hi)}
.btn-g:active{--lift:0px;transform:translate(var(--mx),var(--my)) scale(.985)}
.btn-spec{
  position:relative;display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--paper-2);
  padding:7px 8px 7px 22px;border-radius:999px;cursor:pointer;border:none;
  background:var(--ink);
  box-shadow:0 10px 30px -10px rgba(23,20,13,.5), inset 0 1px 0 rgba(255,255,255,.12);
  transform:translate(var(--mx),calc(var(--my) + var(--lift)));
  transition:transform .18s var(--ease-fast),box-shadow .5s var(--ease);
}
.btn-spec:hover{--lift:-2px;box-shadow:0 16px 40px -12px rgba(23,20,13,.6), inset 0 1px 0 rgba(255,255,255,.12)}
.btn-spec:active{--lift:0px;transform:translate(var(--mx),var(--my)) scale(.985)}
.btn-spec .cap{
  width:30px;height:30px;border-radius:999px;display:grid;place-items:center;flex:none;
  background:rgba(255,255,255,.14);font-size:14px;
  transition:transform .5s var(--ease),background .3s var(--ease);
}
.btn-spec:hover .cap{transform:translate(2px,-1px);background:var(--clay)}
.btn-clay{background:var(--clay);box-shadow:0 12px 30px -10px rgba(177,77,53,.55), inset 0 1px 0 rgba(255,255,255,.18)}
.btn-clay:hover{box-shadow:0 18px 44px -12px rgba(177,77,53,.65), inset 0 1px 0 rgba(255,255,255,.18)}
.btn-clay .cap{background:rgba(255,255,255,.2)}
.btn-clay:hover .cap{background:rgba(0,0,0,.18)}
.btn-ghost{background:transparent;border:none;box-shadow:none;color:var(--ink-soft)}
.btn-ghost:hover{background:rgba(23,20,13,.05);transform:none;box-shadow:none;color:var(--ink)}
.btn-lg{font-size:15px;padding:8px 8px 8px 26px}
.btn-lg .cap{width:36px;height:36px}
.btn-g.btn-lg{padding:14px 28px}

/* ===================== eyebrow tag ===================== */
.eyebrow{display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay-deep);
  padding:7px 15px;border-radius:999px;background:var(--clay-soft);border:1px solid rgba(177,77,53,.16)}
.eyebrow .tick,.live-ind{width:6px;height:6px;border-radius:50%;background:var(--clay);flex:none;
  animation:liveLight 1.8s cubic-bezier(.4,0,.6,1) infinite}
.eyebrow.cool .tick,.live-ind.cool{background:var(--prussian)}
@keyframes liveLight{
  0%,100%{box-shadow:0 0 0 0 rgba(177,77,53,.55), 0 0 6px 1px rgba(177,77,53,.5);opacity:1}
  50%{box-shadow:0 0 0 5px rgba(177,77,53,0), 0 0 3px 0 rgba(177,77,53,.2);opacity:.45}
}
.eyebrow.cool{color:var(--prussian);background:var(--prussian-soft);border-color:rgba(29,66,88,.14)}
.eyebrow.cool .tick{background:var(--prussian);box-shadow:0 0 0 3px rgba(29,66,88,.16)}

/* ===================== hero ===================== */
.hero{position:relative;padding:188px 0 70px;text-align:center}
h1.display{font-size:clamp(44px,7.6vw,92px);font-weight:460;letter-spacing:-.035em;margin:30px auto 0;max-width:15ch}
h1.display em{color:var(--clay)}
.lede{font-size:clamp(17px,2vw,20px);color:var(--ink-soft);max-width:600px;margin:26px auto 0;line-height:1.62}
.hero-cta{display:flex;gap:14px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.src-strip{margin-top:64px;display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.src-strip b{color:var(--ink-soft);font-weight:500}
.src-strip .dot{width:3px;height:3px;border-radius:50%;background:var(--rule-2);margin:0 14px}
@media(max-width:560px){.src-strip .dot{margin:0 8px}}

/* journal marquee — infinite scroll of watched journals */
.marquee{margin-top:56px;position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-eyebrow{text-align:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:18px}
.marquee-track{display:flex;width:max-content;animation:marquee 42s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:11px;padding:0 30px;white-space:nowrap;
  font-family:var(--font-display);font-size:21px;font-weight:480;color:var(--ink-soft);font-style:italic;letter-spacing:-.01em}
.marquee-item::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--rule-2)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center}}

/* hero showpiece: floating double-bezel app, parallax tilt */
.showpiece{margin:70px auto 0;max-width:1000px;perspective:1600px}
.bezel{
  position:relative;border-radius:30px;padding:10px;
  background:linear-gradient(180deg,var(--paper-3),#e9e3d6);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:var(--sh-xl), var(--hi);
  transform-style:preserve-3d;transition:transform .6s var(--ease-out);will-change:transform;
}
.bezel-core{
  position:relative;border-radius:21px;overflow:hidden;background:var(--card);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 1px 3px rgba(35,28,15,.05);
}
.float-badge{
  position:absolute;z-index:3;border-radius:18px;padding:8px;
  background:linear-gradient(180deg,var(--paper-3),#ece6d9);border:1px solid rgba(255,255,255,.6);
  box-shadow:var(--sh-lg), var(--hi);animation:bob 7s var(--ease) infinite alternate;
}
.float-badge .fb-core{background:var(--card);border-radius:11px;padding:13px 16px;box-shadow:var(--hi)}
.float-badge .fb-n{font-family:var(--font-display);font-size:24px;color:var(--ink);line-height:1}
.float-badge .fb-l{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-top:5px}
.fb-1{top:-26px;left:-30px;animation-delay:-1s}
.fb-2{bottom:34px;right:-34px;animation-delay:-4s}
@keyframes bob{from{transform:translateY(0) rotate(-1deg)}to{transform:translateY(-16px) rotate(1.5deg)}}
@media(max-width:760px){.float-badge{display:none}}

/* app mock interior */
.mock{display:grid;grid-template-columns:148px 1fr;min-height:340px;text-align:left}
.mock .m-rail{background:var(--paper-3);border-right:1px solid var(--rule);padding:16px 12px;display:flex;flex-direction:column;gap:7px}
.mock .m-logo{font-family:var(--font-display);font-size:15px;color:var(--ink);margin-bottom:10px;padding-left:4px}
.mock .m-item{display:flex;align-items:center;gap:8px;height:30px;border-radius:8px;padding:0 10px;font-size:11px;color:var(--ink-faint)}
.mock .m-item.on{background:var(--card);color:var(--ink);box-shadow:var(--sh-sm);font-weight:600}
.mock .m-item .d{width:13px;height:13px;border-radius:4px;background:var(--rule-2)}
.mock .m-item.on .d{background:var(--clay)}
.mock .m-body{padding:18px}
.mock .m-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.mock .m-kpi{background:var(--paper-2);border:1px solid var(--rule);border-radius:12px;padding:12px}
.mock .m-kpi b{display:block;font-family:var(--font-display);font-size:21px;color:var(--ink);font-weight:480}
.mock .m-kpi s{display:block;text-decoration:none;font-family:var(--font-mono);font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px}
.mock .m-gauge{height:7px;border-radius:999px;background:linear-gradient(90deg,#5f8d6b,#caa64e 55%,#c06a4a 80%,#b14d35);margin:4px 0 16px;position:relative}
.mock .m-gauge::after{content:"";position:absolute;left:62%;top:50%;width:14px;height:14px;border-radius:50%;background:var(--card);border:2.5px solid var(--ink);transform:translate(-50%,-50%);box-shadow:0 2px 6px rgba(23,20,13,.25);
  /* signature moment: the verdict needle settles into place on load */
  animation:gaugeSettle 1.2s var(--ease-out) .55s both}
@keyframes gaugeSettle{0%{left:8%}70%{left:66%}100%{left:62%}}
@media(prefers-reduced-motion:reduce){.mock .m-gauge::after{animation:none;left:62%}}
.mock .m-card{background:var(--paper-2);border:1px solid var(--rule);border-radius:11px;padding:11px 13px;margin-bottom:9px}
.mock .m-tag{display:inline-block;font-family:var(--font-mono);font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);border:1px solid var(--sage-soft);background:var(--sage-soft);border-radius:5px;padding:2px 7px;margin-bottom:8px}
.mock .m-row{height:7px;border-radius:4px;background:var(--rule);margin-bottom:6px}
.mock .m-row.s{width:54%;background:var(--paper-3);margin-bottom:0}

/* ===================== sections ===================== */
section.s{position:relative;z-index:2;padding:120px 0}
@media(max-width:760px){section.s{padding:80px 0}}
.s-head{max-width:680px;margin:0 0 60px}
.s-head.center{margin-left:auto;margin-right:auto;text-align:center}
.s-head .k{display:inline-block;font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay-deep);margin-bottom:18px}
.s-head h2{font-size:clamp(32px,4.6vw,54px);font-weight:460;letter-spacing:-.03em}
.s-head h2 em{color:var(--clay)}
.s-head p{color:var(--ink-soft);margin-top:18px;font-size:17px;max-width:560px}
.s-head.center p{margin-left:auto;margin-right:auto}

/* ===================== bento grid (asymmetric) ===================== */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.feat{
  position:relative;border-radius:26px;padding:6px;
  background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.3));
  border:1px solid var(--rule);box-shadow:var(--sh);
  transition:transform .6s var(--ease),box-shadow .6s var(--ease);
}
.feat:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.feat-core{position:relative;height:100%;background:var(--card);border-radius:20px;padding:28px;box-shadow:var(--hi);overflow:hidden}
.feat .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:20px;
  background:var(--paper-3);border:1px solid var(--rule);box-shadow:var(--hi);color:var(--clay-deep)}
.feat .ic svg{display:block}
.feat h3{font-size:21px;font-weight:480;margin-bottom:9px;letter-spacing:-.02em}
.feat p{font-size:14.5px;color:var(--ink-soft);line-height:1.6}
.feat .lab{position:absolute;top:26px;right:28px;font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay)}
.feat.wide{grid-column:span 4}.feat.mid{grid-column:span 3}.feat.third{grid-column:span 2}
.feat.tall .feat-core{display:flex;flex-direction:column;justify-content:space-between}
@media(max-width:900px){.bento{grid-template-columns:1fr}.feat.wide,.feat.mid,.feat.third{grid-column:span 1}}

/* big feature splash inside a wide bento */
.feat .splash{margin-top:22px;border-radius:14px;border:1px solid var(--rule);overflow:hidden;background:var(--paper-2)}
.splash-bar{display:flex;align-items:flex-end;gap:8px;height:96px;padding:14px;background:var(--paper-2)}
.splash-bar i{flex:1;border-radius:6px 6px 3px 3px;background:linear-gradient(180deg,var(--prussian),#2b5a76);opacity:.85;
  transform:scaleY(.05);transform-origin:bottom;transition:transform .9s var(--ease)}
.splash-bar i:nth-child(odd){background:linear-gradient(180deg,var(--clay),var(--clay-deep))}
.reveal.in .splash-bar i{transform:scaleY(1)}
.reveal.in .splash-bar i:nth-child(1){transition-delay:.05s}
.reveal.in .splash-bar i:nth-child(2){transition-delay:.11s}
.reveal.in .splash-bar i:nth-child(3){transition-delay:.17s}
.reveal.in .splash-bar i:nth-child(4){transition-delay:.23s}
.reveal.in .splash-bar i:nth-child(5){transition-delay:.29s}
.reveal.in .splash-bar i:nth-child(6){transition-delay:.35s}
.reveal.in .splash-bar i:nth-child(7){transition-delay:.41s}
.reveal.in .splash-bar i:nth-child(8){transition-delay:.47s}

/* ===================== pipeline ribbon ===================== */
.ribbon{display:flex;align-items:flex-start;gap:0;flex-wrap:wrap;counter-reset:step}
.rb{flex:1;min-width:150px;padding:26px 22px;border-left:1px solid var(--rule);position:relative}
.rb:first-child{border-left:none}
.rb .num{font-family:var(--font-mono);font-size:11px;color:var(--clay);letter-spacing:.1em}
.rb h4{font-family:var(--font-display);font-size:21px;font-weight:480;margin:14px 0 8px;letter-spacing:-.02em}
.rb p{font-size:13.5px;color:var(--ink-soft);line-height:1.55}
@media(max-width:760px){.rb{flex:1 1 100%;border-left:none;border-top:1px solid var(--rule);padding:20px 0}.rb:first-child{border-top:none}}

/* ===================== quote / editorial band ===================== */
.editorial{text-align:center;max-width:880px;margin:0 auto}
.editorial blockquote{font-family:var(--font-display);font-size:clamp(26px,3.8vw,44px);font-weight:420;line-height:1.18;letter-spacing:-.02em;color:var(--ink)}
.editorial blockquote em{color:var(--clay)}
.editorial .by{margin-top:26px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}

/* ===================== pricing ===================== */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
@media(max-width:900px){.tiers{grid-template-columns:1fr}}
.tier{position:relative;border-radius:26px;padding:6px;background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.3));border:1px solid var(--rule);box-shadow:var(--sh)}
.tier.hot{border-color:rgba(177,77,53,.4);box-shadow:var(--sh-lg)}
.tier-core{background:var(--card);border-radius:20px;padding:30px;box-shadow:var(--hi);height:100%;display:flex;flex-direction:column}
.tier .t-name{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay-deep)}
.tier .t-price{font-family:var(--font-display);font-size:46px;font-weight:460;letter-spacing:-.03em;margin:16px 0 2px;color:var(--ink)}
.tier .t-price small{font-family:var(--font-ui);font-size:15px;font-weight:400;color:var(--ink-faint)}
.tier .t-sub{color:var(--ink-soft);font-size:14px;margin-bottom:24px}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px;flex:1}
.tier li{font-size:14px;color:var(--ink);padding-left:26px;position:relative;line-height:1.45}
.tier li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:50%;background:var(--clay-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14'%3E%3Cpath d='M3.5 7.2l2.2 2.2 4.8-5' stroke='%23b14d35' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.tier li.dim{color:var(--ink-faint)}
.tier li.dim::before{background:var(--paper-3);background-image:none}
.hot-badge{position:absolute;top:-12px;left:30px;font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  background:var(--clay);color:#fff;font-weight:600;border-radius:999px;padding:5px 14px;box-shadow:var(--sh-sm)}

/* ===================== sub-page hero + prose ===================== */
.page-hero{padding:170px 0 30px;max-width:760px}
.page-hero.center{margin:0 auto;text-align:center}
.page-hero h1{font-size:clamp(38px,5.4vw,68px);font-weight:460;letter-spacing:-.03em}
.page-hero h1 em{color:var(--clay)}
.page-hero p{color:var(--ink-soft);font-size:18px;margin-top:18px;max-width:560px}
.page-hero.center p{margin-left:auto;margin-right:auto}
.prose{max-width:720px;color:var(--ink-soft);font-size:16px;line-height:1.75}
.prose h2{font-size:26px;font-weight:480;color:var(--ink);margin:44px 0 14px;letter-spacing:-.02em}
.prose h3{font-size:18px;font-weight:600;font-family:var(--font-ui);color:var(--ink);margin:28px 0 8px}
.prose p{margin-bottom:14px}
.prose ul{margin:0 0 16px 4px;list-style:none}
.prose li{position:relative;padding-left:22px;margin-bottom:9px}
.prose li::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--clay)}
.prose strong{color:var(--ink);font-weight:600}
.prose .upd{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;color:var(--ink-faint);text-transform:uppercase}
.prose a{color:var(--prussian);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--rule-2)}

/* ===================== auth (login) ===================== */
.auth-shell{max-width:440px;margin:0 auto}
.auth-card{border-radius:28px;padding:7px;background:linear-gradient(180deg,rgba(255,255,255,.8),rgba(255,255,255,.4));border:1px solid var(--rule);box-shadow:var(--sh-xl)}
.auth-core{background:var(--card);border-radius:22px;padding:38px 34px;box-shadow:var(--hi)}
.auth-core h1{font-family:var(--font-display);font-size:30px;font-weight:460;letter-spacing:-.02em;margin-bottom:8px}
.auth-core .sub{color:var(--ink-soft);font-size:14.5px;margin-bottom:26px}
.f-label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 8px 2px}
.inp{width:100%;font-family:var(--font-ui);font-size:15px;color:var(--ink);background:var(--paper-2);border:1px solid var(--rule-2);border-radius:13px;padding:13px 15px;outline:none;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease)}
.inp::placeholder{color:var(--ink-faint)}
.inp:focus{border-color:var(--clay);background:var(--card);box-shadow:0 0 0 4px rgba(177,77,53,.1)}
.oauth-row{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.btn-oauth{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--ink);
  padding:11px 18px;border-radius:12px;cursor:pointer;
  background:var(--card);border:1px solid var(--rule-2);box-shadow:var(--sh-sm);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.btn-oauth:hover{transform:translateY(-1px);border-color:var(--ink-faint);box-shadow:var(--sh)}
.btn-oauth:active{transform:translateY(0) scale(.99)}
.btn-oauth svg{flex:none}
.divider{display:flex;align-items:center;gap:14px;margin:24px 0;color:var(--ink-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--rule)}
.note{font-size:12.5px;color:var(--ink-faint);line-height:1.6}
.msg-ok{color:var(--sage);font-size:13.5px;margin-top:12px}
.msg-err{color:var(--clay-deep);font-size:13.5px;margin-top:12px}
details.cfg{margin-top:20px;border-top:1px solid var(--rule);padding-top:16px}
details.cfg summary{cursor:pointer;font-size:13px;color:var(--ink-soft);font-weight:500}
details.cfg[open] summary{margin-bottom:14px}

/* ===================== CTA band ===================== */
.cta{position:relative;border-radius:34px;padding:8px;background:linear-gradient(180deg,var(--paper-3),#e9e3d6);border:1px solid rgba(255,255,255,.6);box-shadow:var(--sh-xl)}
.cta-core{position:relative;background:var(--ink);border-radius:26px;padding:74px 36px;text-align:center;overflow:hidden}
.cta-core::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(600px 300px at 70% 0%,rgba(177,77,53,.28),transparent 60%),radial-gradient(500px 320px at 10% 120%,rgba(29,66,88,.34),transparent 55%)}
.cta-core h2{position:relative;font-size:clamp(30px,4.4vw,52px);font-weight:460;color:var(--paper-2);letter-spacing:-.03em}
.cta-core h2 em{color:#e8a48c}
.cta-core p{position:relative;color:rgba(247,244,238,.7);margin:16px auto 30px;max-width:480px;font-size:16px}
.cta-core .btn-spec{background:var(--paper-2);color:var(--ink)}
.cta-core .btn-spec .cap{background:rgba(23,20,13,.1)}
.cta-core .btn-spec:hover .cap{background:var(--clay);color:#fff}

/* ===================== footer ===================== */
.site-footer{position:relative;z-index:2;border-top:1px solid var(--rule);margin-top:40px;padding:64px 0 44px}
.f-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:34px;max-width:1180px;margin:0 auto;padding:0 32px}
@media(max-width:760px){.f-grid{grid-template-columns:1fr 1fr;padding:0 20px}}
.f-col h4{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px;font-weight:500}
.f-col a{display:block;color:var(--ink-soft);font-size:14px;padding:5px 0;transition:color .3s var(--ease)}
.f-col a:hover{color:var(--clay)}
.f-brand .brand{margin-bottom:14px}
.f-brand p{color:var(--ink-faint);font-size:13px;line-height:1.6;max-width:280px}
.f-bottom{max-width:1180px;margin:42px auto 0;padding:22px 32px 0;border-top:1px solid var(--rule);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:var(--ink-faint)}
.f-bottom .mono{font-family:var(--font-mono);letter-spacing:.04em}

/* ===================== scroll reveal ===================== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.09s}.reveal.d2{transition-delay:.18s}.reveal.d3{transition-delay:.27s}.reveal.d4{transition-delay:.36s}
/* above-the-fold hero resolves on load, not on scroll-intersection (kills the
   blank/blur "pop" on first paint); blur kept here only, where it earns its cost */
.showpiece.reveal{animation:heroIn .9s var(--ease-out) .12s both}
.showpiece.reveal.in{opacity:1;transform:none}
@keyframes heroIn{from{opacity:0;transform:translateY(28px);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}
.feat{will-change:auto}.feat:hover{will-change:transform}

.center{text-align:center}.mono{font-family:var(--font-mono)}

/* ===================== crafted focus-visible (on-brand, every control) ===================== */
a:focus-visible,button:focus-visible,.btn-g:focus-visible,.btn-spec:focus-visible,
.btn-oauth:focus-visible,.nav-toggle:focus-visible,.s-nav a:focus-visible,
.theme-btn-site:focus-visible,details.cfg summary:focus-visible{
  outline:none;box-shadow:var(--focus-ring);border-radius:999px;
}
.inp:focus-visible{border-color:var(--clay);box-shadow:0 0 0 4px rgba(177,77,53,.1)}
.f-col a:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:6px}
.f-col a{transition:color .2s var(--ease-fast)}
.btn-ghost{transition:background .2s var(--ease-fast),color .2s var(--ease-fast),box-shadow .2s var(--ease-fast)}

/* ===================== button states: disabled / loading ===================== */
.btn-g[disabled],.btn-spec[disabled],.btn-oauth[disabled],
.btn-g[aria-disabled="true"],.btn-spec[aria-disabled="true"]{
  opacity:.5;cursor:not-allowed;--lift:0px;--mx:0px;--my:0px;box-shadow:var(--sh-sm),var(--hi)!important;
}
.btn-spec.is-loading,.btn-g.is-loading,.btn-oauth.is-loading{pointer-events:none;color:transparent!important;position:relative}
.btn-spec.is-loading::after,.btn-g.is-loading::after,.btn-oauth.is-loading::after{
  content:"";position:absolute;inset:0;margin:auto;width:16px;height:16px;border-radius:50%;
  border:2px solid currentColor;border-top-color:transparent;color:var(--paper-2);animation:spin .7s linear infinite;
}
.btn-g.is-loading::after,.btn-oauth.is-loading::after{color:var(--ink)}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-block{width:100%;justify-content:center}

/* ===================== marketing theme toggle (in shared header) ===================== */
.theme-btn-site{display:grid;place-items:center;width:38px;height:38px;border-radius:999px;border:none;cursor:pointer;
  background:rgba(23,20,13,.05);color:var(--ink-soft);font-size:15px;line-height:1;pointer-events:auto;
  transition:background .2s var(--ease-fast),color .2s var(--ease-fast),transform .18s var(--ease-fast)}
.theme-btn-site:hover{background:rgba(23,20,13,.09);color:var(--ink);transform:translateY(-1px)}

/* ===================== cross-document View Transitions (smooth page-to-page) ===================== */
@view-transition{navigation:auto}
::view-transition-old(root),::view-transition-new(root){animation-duration:.28s;animation-timing-function:cubic-bezier(.4,0,.2,1)}
.site-header{view-transition-name:site-header}
.site-footer{view-transition-name:site-footer}

/* suppress transitions on the very first paint so the pre-set theme doesn't sweep */
html.theme-boot *{transition:none!important}

/* ===================== Dark mode (marketing) — warm-charcoal Editorial inversion ===================== */
html[data-theme="dark"]{
  --paper:#171411; --paper-2:#1f1b15; --paper-3:#262019; --card:#211d17;
  --ink:#f5f1e8; --ink-soft:#c3bca9; --ink-faint:#8f8775;
  --rule:#332d24; --rule-2:#433c30;
  --clay-deep:#e0937a; --clay-soft:#3a2820;
  --prussian:#86b0cc; --prussian-soft:#22303a;
  --sage:#8fb08a; --sage-soft:#22312a;
  --hi:inset 0 1px 0 rgba(255,255,255,.05);
  --sh-sm:0 1px 2px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.3);
  --sh:0 2px 4px rgba(0,0,0,.3),0 12px 28px -10px rgba(0,0,0,.5);
  --sh-lg:0 4px 10px rgba(0,0,0,.4),0 30px 60px -18px rgba(0,0,0,.6);
  --sh-xl:0 50px 100px -30px rgba(0,0,0,.7),0 8px 24px -12px rgba(0,0,0,.5);
}
html[data-theme="dark"] body{background:var(--paper)}
html[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#3a342a;border-color:var(--paper)}
html[data-theme="dark"] .site-header .bar{background:rgba(33,29,23,.72);border-color:rgba(255,255,255,.08)}
html[data-theme="dark"] .site-header.scrolled .bar{background:rgba(33,29,23,.88)}
html[data-theme="dark"] .menu-veil{background:rgba(18,15,11,.9)}
html[data-theme="dark"] .nav-toggle{background:rgba(255,255,255,.06)}
html[data-theme="dark"] .theme-btn-site{background:rgba(255,255,255,.06)}
html[data-theme="dark"] .theme-btn-site:hover{background:rgba(255,255,255,.12)}
/* glass cards bake white gradients — repaint on warm charcoal */
html[data-theme="dark"] .feat,
html[data-theme="dark"] .tier{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02))}
html[data-theme="dark"] .bezel,
html[data-theme="dark"] .float-badge{background:linear-gradient(180deg,#26211a,#1c1812);border-color:rgba(255,255,255,.06)}
html[data-theme="dark"] .cta{background:linear-gradient(180deg,#211d16,#15110d);border-color:rgba(255,255,255,.06)}
html[data-theme="dark"] .mock .m-rail{background:#1b1711}
/* .cta-core uses var(--ink) as a deliberately-dark surface → pin dark + light text */
html[data-theme="dark"] .cta-core{background:#100d0a}
html[data-theme="dark"] .cta-core h2{color:#f7f3ea}
html[data-theme="dark"] .cta-core p{color:rgba(245,241,232,.72)}
html[data-theme="dark"] .cta-core .btn-spec{background:#f5f1e8;color:#171411}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none;filter:none}
  .showpiece.reveal{opacity:1;transform:none}
  ::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}
}
