/* ============================================================
   Sketchedule — landing page.  Dark premium skin (+ light), monday-style
   structure & energy.  Fully self-contained (no external assets), so it
   self-contained: no external CSS/JS dependencies.
   ============================================================ */
:root{
  --bg:#080a10; --bg2:#0c0f17; --card:#12161f; --cardHi:#171c28; --hair:#222a3a; --hairSoft:#1a202d;
  --txt:#eef1f7; --txtMid:#aeb6c8; --txtDim:#727b90; --surfaceHi:#1c2230;
  --accent:#6E7BFF; --accent2:#9d7bff; --accentLine:#3a4170;
  --ok:#16a34a; --warn:#e0991f; --bad:#e1455e;
  --b1:#3b82f6; --b2:#0891b2; --b3:#16a34a; --b4:#d97706; --b5:#7c3aed; --b6:#e11d48;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
  --maxw:1180px;
}
/* ---- LIGHT THEME (dark is the default above) ---- */
html[data-theme="light"]{
  --bg:#ffffff; --bg2:#f5f7fb; --card:#ffffff; --cardHi:#f2f5fa; --hair:#e3e7f0; --hairSoft:#edf0f6;
  --txt:#0e1320; --txtMid:#465065; --txtDim:#7b8499; --surfaceHi:#eef2f9; --accentLine:#c5cbf2;
}
html[data-theme="light"] .window,
html[data-theme="light"] .cap-vis,
html[data-theme="light"] .stat,
html[data-theme="light"] .use,
html[data-theme="light"] .tier{box-shadow:0 22px 50px -34px rgba(20,30,60,.28)}
html[data-theme="light"] .hero::after{opacity:.2}
html[data-theme="light"] .g-bar .fill{background:rgba(255,255,255,.45)}
html[data-theme="light"] .collab-vis,
html[data-theme="light"] .pvis{background:var(--bg2)}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--font);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
h1,h2,h3{letter-spacing:-.02em;line-height:1.1;margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.grad{background:linear-gradient(92deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font:inherit;font-weight:700;font-size:14.5px;padding:12px 20px;border-radius:12px;border:1px solid var(--hair);background:var(--surfaceHi);color:var(--txt);cursor:pointer;transition:.16s}
.btn:hover{transform:translateY(-1px);border-color:var(--accentLine)}
.btn.primary{background:linear-gradient(92deg,var(--accent),var(--accent2));border-color:transparent;color:#fff;box-shadow:0 14px 34px -14px var(--accent)}
.btn.lg{padding:15px 26px;font-size:16px}
.btn.ghost{background:transparent}

/* nav */
.nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(14px) saturate(140%);background:color-mix(in srgb,var(--bg) 78%,transparent);border-bottom:1px solid transparent;transition:.2s}
.nav.scrolled{border-bottom-color:var(--hair);background:color-mix(in srgb,var(--bg) 90%,transparent)}
.nav .row{display:flex;align-items:center;gap:22px;height:62px}
.brand{font-weight:800;display:flex;align-items:center;gap:9px;font-size:16px}
.brand .lo{color:var(--accent);font-size:15px}
.preview-pill{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--warn);border:1px solid color-mix(in srgb,var(--warn) 40%,transparent);border-radius:20px;padding:3px 9px}
.nav .links{display:flex;gap:20px;margin-left:8px}
.nav .links a{color:var(--txtMid);font-weight:600;font-size:14px}
.nav .links a:hover{color:var(--txt)}
.nav .sp{flex:1}
.theme-tog{width:36px;height:36px;border-radius:10px;border:1px solid var(--hair);background:var(--surfaceHi);color:var(--txt);cursor:pointer;font-size:15px;line-height:1;display:grid;place-items:center;transition:.15s}
.theme-tog:hover{border-color:var(--accentLine)}
@media(max-width:860px){.nav .links{display:none}}

/* reveal */
[data-rev]{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
[data-rev].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){[data-rev]{opacity:1;transform:none;transition:none}}

/* hero */
.hero{position:relative;padding:64px 0 36px;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-30% -10% auto -10%;height:80%;background:radial-gradient(58% 60% at 50% 0%,color-mix(in srgb,var(--accent) 24%,transparent),transparent 70%);pointer-events:none;z-index:0}
.hero::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.4;
  background-image:repeating-linear-gradient(90deg,color-mix(in srgb,var(--accent) 16%,transparent) 0 1px,transparent 1px 84px),repeating-linear-gradient(0deg,color-mix(in srgb,var(--accent2) 9%,transparent) 0 1px,transparent 1px 110px);
  -webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000 22%,transparent 78%);mask-image:radial-gradient(120% 80% at 50% 0%,#000 22%,transparent 78%)}
.hero>*{position:relative;z-index:1}
.hero h1{font-size:clamp(34px,5.6vw,60px);max-width:16ch;margin:14px auto 16px}
.hero .lede{color:var(--txtMid);max-width:60ch;margin:0 auto 22px;font-size:clamp(16px,2vw,19px)}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:8px}
.reassure{color:var(--txtDim);font-size:13px;margin:14px 0 0}

/* chips */
.chips{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin:26px auto 6px;max-width:760px}
.chip{font:inherit;font-weight:700;font-size:13.5px;padding:9px 16px;border-radius:30px;border:1px solid var(--hair);background:var(--cardHi);color:var(--txtMid);cursor:pointer;transition:.15s}
.chip:hover{color:var(--txt);border-color:var(--accentLine)}
.chip.on{color:#fff;background:linear-gradient(92deg,var(--accent),var(--accent2));border-color:transparent}
.chip-hint{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--txtDim);margin:18px 0 0}

/* product window (animated gantt) */
.window{max-width:880px;margin:22px auto 0;background:var(--card);border:1px solid var(--hair);border-radius:16px;box-shadow:0 50px 120px -55px #000;overflow:hidden}
.win-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--hair)}
.win-bar i{width:11px;height:11px;border-radius:50%;background:var(--hair)}
.win-bar i:nth-child(1){background:#ef4444}.win-bar i:nth-child(2){background:#f59e0b}.win-bar i:nth-child(3){background:#22c55e}
.win-title{margin-left:9px;font-family:var(--mono);font-size:11.5px;color:var(--txtDim)}
.gantt{position:relative;padding:13px 18px 20px}
.g-axis{display:grid;grid-template-columns:repeat(6,1fr);font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;color:var(--txtDim);margin-bottom:9px}
.g-rows{position:relative;display:grid;gap:9px;background-image:repeating-linear-gradient(90deg,var(--hairSoft) 0 1px,transparent 1px calc(100%/6))}
.g-row{position:relative;display:flex;align-items:center;height:30px}
.g-name{width:32%;font-size:12px;color:var(--txtMid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:10px;opacity:0;transform:translateX(-6px)}
.g-track{position:relative;flex:1;height:100%}
.g-bar{position:absolute;top:50%;height:15px;transform:translateY(-50%) scaleX(0);transform-origin:left center;border-radius:6px;opacity:0;box-shadow:0 4px 12px -4px rgba(0,0,0,.5)}
.g-bar .fill{position:absolute;inset:0;border-radius:6px;background:rgba(255,255,255,.26);width:var(--pct,0%)}
.g-bar .sheen{position:absolute;inset:0;border-radius:6px;background:linear-gradient(180deg,rgba(255,255,255,.28),transparent 55%)}
.g-ms{position:absolute;top:50%;width:14px;height:14px;margin-left:-7px;transform:translateY(-50%) rotate(45deg) scale(0);border-radius:2px;opacity:0;box-shadow:0 3px 10px -3px rgba(0,0,0,.6)}
.g-pill{position:absolute;right:0;top:50%;transform:translateY(-50%) scale(0);font-family:var(--mono);font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:20px;opacity:0}
.g-pill.ok{background:color-mix(in srgb,var(--ok) 22%,transparent);color:#7ee2a8;border:1px solid color-mix(in srgb,var(--ok) 40%,transparent)}
.g-pill.warn{background:color-mix(in srgb,var(--warn) 22%,transparent);color:#f2cf86;border:1px solid color-mix(in srgb,var(--warn) 40%,transparent)}
.g-pill.bad{background:color-mix(in srgb,var(--bad) 22%,transparent);color:#f5a4b1;border:1px solid color-mix(in srgb,var(--bad) 45%,transparent)}
.g-today{position:absolute;top:30px;bottom:14px;width:2px;border-radius:2px;background:linear-gradient(180deg,transparent,var(--accent),transparent);box-shadow:0 0 12px var(--accent);opacity:0}
.g-today::before{content:"";position:absolute;top:-5px;left:50%;width:8px;height:8px;margin-left:-4px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}
/* play state */
.gantt.play .g-name{animation:nameIn .5s ease forwards;animation-delay:var(--d)}
.gantt.play .g-bar{animation:barIn 1.4s cubic-bezier(.22,1,.36,1) forwards;animation-delay:var(--d)}
.gantt.play .g-ms{animation:msIn 1.2s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(var(--d) + .35s)}
.gantt.play .g-pill{animation:pillIn .5s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(var(--d) + .7s)}
.gantt.play .g-today{animation:sweep 3.2s ease-in-out .4s forwards}
@keyframes nameIn{to{opacity:1;transform:none}}
@keyframes barIn{0%{opacity:0;transform:translateY(-50%) scaleX(0)}30%{opacity:1}100%{opacity:1;transform:translateY(-50%) scaleX(1)}}
@keyframes msIn{0%{opacity:0;transform:translateY(-50%) rotate(45deg) scale(0)}60%{opacity:1;transform:translateY(-50%) rotate(45deg) scale(1.25)}100%{opacity:1;transform:translateY(-50%) rotate(45deg) scale(1)}}
@keyframes pillIn{to{opacity:1;transform:translateY(-50%) scale(1)}}
@keyframes sweep{0%{left:6%;opacity:0}18%{opacity:.9}82%{opacity:.9}100%{left:90%;opacity:0}}

/* interop strip */
.strip{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:var(--bg2);padding:22px 0}
.strip .in{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center}
.strip .lbl{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--txtDim)}
.strip .logos{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.strip .lg{font-weight:700;font-size:13px;color:var(--txtMid);border:1px solid var(--hair);background:var(--card);border-radius:9px;padding:8px 13px}

/* section scaffolding */
.section{padding:78px 0}
.section.alt{background:var(--bg2);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.sec-head{text-align:center;max-width:760px;margin:0 auto 40px}
.sec-head h2{font-size:clamp(26px,3.4vw,40px);margin:12px 0 12px}
.sec-head p{color:var(--txtMid);font-size:17px;margin:0}

/* stat band */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--card);border:1px solid var(--hair);border-radius:14px;padding:24px;text-align:center}
.stat b{display:block;font-size:38px;letter-spacing:-.02em;background:linear-gradient(92deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{color:var(--txtDim);font-size:13.5px}

/* personas */
.persona-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.ptab{font:inherit;font-weight:700;font-size:14px;padding:10px 18px;border-radius:11px;border:1px solid var(--hair);background:var(--card);color:var(--txtMid);cursor:pointer;transition:.15s}
.ptab.on{color:#fff;border-color:transparent;background:linear-gradient(92deg,var(--accent),var(--accent2))}
.persona{display:none;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.persona.on{display:grid}
@media(max-width:820px){.persona.on{grid-template-columns:1fr}}
.persona h3{font-size:24px;margin-bottom:10px}
.persona p{color:var(--txtMid);font-size:15.5px}
.persona .quote{margin-top:14px;color:var(--txtDim);font-size:13.5px;font-style:italic;border-left:2px solid var(--accentLine);padding-left:12px}
.pvis{background:var(--card);border:1px solid var(--hair);border-radius:16px;padding:20px;min-height:230px;position:relative;overflow:hidden}

/* capability zigzag */
.cap{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center;padding:30px 0}
.cap:nth-child(even) .cap-txt{order:2}
@media(max-width:840px){.cap{grid-template-columns:1fr;gap:24px}.cap:nth-child(even) .cap-txt{order:0}}
.cap-k{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:700}
.cap-txt h3{font-size:25px;margin:10px 0 10px}
.cap-txt p{color:var(--txtMid);font-size:15.5px;margin:0 0 12px}
.cap-txt code{font-family:var(--mono);font-size:.9em;background:var(--surfaceHi);padding:1px 6px;border-radius:6px}
.ticks{list-style:none;padding:0;margin:0;display:grid;gap:7px}
.ticks li{color:var(--txtMid);font-size:14px;padding-left:24px;position:relative}
.ticks li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:800}
.cap-vis{background:var(--card);border:1px solid var(--hair);border-radius:16px;padding:18px;min-height:210px;position:relative;overflow:hidden;box-shadow:0 30px 70px -50px #000}

/* mini visual: RAG table */
.mini-tbl{width:100%;border-collapse:collapse;font-size:12px}
.mini-tbl th{text-align:left;color:var(--txtDim);font-weight:600;font-family:var(--mono);font-size:10px;letter-spacing:.05em;padding:0 8px 8px;border-bottom:1px solid var(--hair)}
.mini-tbl td{padding:9px 8px;border-bottom:1px solid var(--hairSoft);color:var(--txtMid)}
.dot{display:inline-block;width:12px;height:12px;border-radius:50%}
.dot.r{background:var(--bad)}.dot.a{background:var(--warn)}.dot.g{background:var(--ok)}
.rag-cycle{animation:rag 4.5s steps(1) infinite}
@keyframes rag{0%{background:var(--bad)}33%{background:var(--warn)}66%{background:var(--ok)}100%{background:var(--bad)}}
.pie{--p:62;width:22px;height:22px;border-radius:50%;background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--surfaceHi) 0)}
.pie::after{content:"";display:block;width:14px;height:14px;margin:4px;border-radius:50%;background:var(--card)}

/* mini visual: conditional symbol */
.cond{display:flex;align-items:center;justify-content:center;gap:28px;height:170px}
.cond .sym{width:34px;height:34px;transform:rotate(45deg);border-radius:5px;background:var(--ok);transition:.5s;animation:cond 5s ease-in-out infinite}
@keyframes cond{0%,40%{background:var(--ok);transform:rotate(45deg) scale(1)}50%,90%{background:var(--bad);transform:rotate(45deg) scale(1.18)}100%{background:var(--ok);transform:rotate(45deg) scale(1)}}
.cond .arrow{color:var(--txtDim);font-size:24px}
.cond .tag{font-family:var(--mono);font-size:12px;color:var(--txtMid)}
.cond .tag b{color:var(--bad)}

/* mini visual: EVM s-curve */
.evm svg{width:100%;height:175px;display:block}
.evm .draw{stroke-dasharray:600;stroke-dashoffset:600;animation:draw 3s ease forwards}
.cap-vis.in .evm .draw{animation-play-state:running}
@keyframes draw{to{stroke-dashoffset:0}}

/* mini visual: import flow */
.flow{display:flex;flex-direction:column;gap:10px;justify-content:center;height:175px}
.flow .file{display:flex;align-items:center;gap:10px;background:var(--surfaceHi);border:1px solid var(--hair);border-radius:9px;padding:9px 12px;font-size:13px;color:var(--txtMid);transform:translateX(-30px);opacity:0;animation:slideIn .6s ease forwards}
.cap-vis.in .flow .file{animation-play-state:running}
.flow .file .ext{font-family:var(--mono);font-size:10px;font-weight:700;color:#fff;background:var(--accent);border-radius:5px;padding:2px 6px}
.flow .file.chg{border-color:color-mix(in srgb,var(--warn) 50%,transparent);box-shadow:inset 3px 0 0 var(--warn)}
@keyframes slideIn{to{opacity:1;transform:none}}

/* use-case tiles */
.uses{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.uses{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.uses{grid-template-columns:1fr}}
.use{background:var(--card);border:1px solid var(--hair);border-radius:14px;padding:22px;transition:.18s;cursor:default}
.use:hover{transform:translateY(-4px);border-color:var(--accentLine)}
.use .ic{font-size:22px}
.use h3{font-size:17px;margin:10px 0 6px}
.use p{color:var(--txtMid);font-size:13.5px;margin:0}

/* collab */
.collab-vis{position:relative;background:var(--card);border:1px solid var(--hair);border-radius:16px;height:230px;overflow:hidden}
.cursor{position:absolute;font-size:11px;font-weight:700;padding:3px 8px;border-radius:8px 8px 8px 0;color:#fff;white-space:nowrap}
.cursor.a{background:var(--b1);animation:c1 7s ease-in-out infinite}
.cursor.b{background:var(--b6);animation:c2 7s ease-in-out infinite}
@keyframes c1{0%{left:14%;top:24%}50%{left:60%;top:55%}100%{left:14%;top:24%}}
@keyframes c2{0%{left:62%;top:68%}50%{left:24%;top:32%}100%{left:62%;top:68%}}

/* comparison table — homepage teaser + full compare page */
.cmp-wrap{overflow-x:auto;border:1px solid var(--hair);border-radius:14px;background:var(--card);max-width:920px;margin:0 auto;-webkit-overflow-scrolling:touch}
.cmp{width:100%;border-collapse:collapse;font-size:14px;min-width:640px}
.cmp th,.cmp td{padding:13px 14px;border-bottom:1px solid var(--hairSoft);text-align:center}
.cmp tbody tr:last-child th,.cmp tbody tr:last-child td{border-bottom:0}
.cmp thead th{position:sticky;top:0;background:var(--surfaceHi);color:var(--txtMid);font-weight:700;white-space:nowrap}
.cmp thead th.cmp-feat,.cmp thead th:first-child{text-align:left;color:var(--txtDim)}
.cmp thead th.cmp-us,.cmp .us,.cmp .cmp-us{color:var(--accent)}
.cmp tbody th{text-align:left;color:var(--txt);font-weight:600}
.cmp td.cmp-us,.cmp td.us{background:color-mix(in srgb,var(--accent) 8%,transparent)}
.cmp tbody tr:hover th,.cmp tbody tr:hover td{background:color-mix(in srgb,var(--accent) 5%,transparent)}
.yes{color:var(--ok);font-weight:800}.no{color:var(--txtDim)}.part{color:var(--warn)}
.cmp-legend{color:var(--txtMid);font-size:13px;text-align:center;max-width:790px;margin:18px auto 0;line-height:1.6}
.cmp-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:920px;margin:0 auto}
@media(max-width:780px){.cmp-cards{grid-template-columns:1fr}}
.cmp-card{background:var(--card);border:1px solid var(--hair);border-radius:14px;padding:24px}
.cmp-card .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.cmp-card h3{font-size:19px;margin:8px 0 10px}
.cmp-card p{color:var(--txtMid);font-size:14.5px;margin:0 0 10px}
.cmp-card .win{color:var(--txt)}
.cmp-card .win::before{content:"✓ ";color:var(--ok);font-weight:800}

/* old-class aliases so legacy inner-page buttons (.lg-btn) match v2 */
.lg-btn{display:inline-flex;align-items:center;gap:8px;font:inherit;font-weight:700;font-size:14px;text-decoration:none;padding:11px 18px;border-radius:11px;border:1px solid var(--hair);background:var(--surfaceHi);color:var(--txt);cursor:pointer;transition:.14s}
.lg-btn:hover{transform:translateY(-1px);border-color:var(--accentLine)}
.lg-btn.primary{background:linear-gradient(92deg,var(--accent),var(--accent2));border-color:transparent;color:#fff;box-shadow:0 14px 34px -14px var(--accent)}
.lg-btn.lg{padding:14px 24px;font-size:15.5px}

/* pricing teaser */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:840px;margin:0 auto}
@media(max-width:760px){.tiers{grid-template-columns:1fr}}
.tier{background:var(--card);border:1px solid var(--hair);border-radius:16px;padding:24px}
.tier.hot{border-color:var(--accentLine);box-shadow:0 0 0 1px var(--accentLine),0 30px 70px -50px var(--accent)}
.tier h3{font-size:17px}
.tier .price{font-size:34px;font-weight:800;margin:6px 0}
.tier .price small{font-size:14px;color:var(--txtDim);font-weight:600}
.tier ul{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:8px}
.tier li{color:var(--txtMid);font-size:13.5px;padding-left:22px;position:relative}
.tier li::before{content:"✓";position:absolute;left:0;color:var(--ok)}

/* final CTA */
.final{position:relative;text-align:center;padding:84px 0;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 50% 0%,color-mix(in srgb,var(--accent) 26%,transparent),transparent 70%);z-index:0}
.final>*{position:relative;z-index:1}
.final h2{font-size:clamp(28px,4vw,44px);max-width:18ch;margin:0 auto 16px}

/* footer */
footer{border-top:1px solid var(--hair);background:var(--bg2);padding:40px 0;color:var(--txtDim);font-size:13px}
footer .row{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
footer a{color:var(--txtMid)}

.note{background:color-mix(in srgb,var(--warn) 10%,transparent);border:1px solid color-mix(in srgb,var(--warn) 35%,transparent);color:var(--txtMid);font-size:13px;border-radius:10px;padding:10px 14px;text-align:center;margin:0 auto;max-width:var(--maxw)}

/* ============================================================
   Shared additions for inner pages: page header, nav auth/account,
   legal prose, examples gallery.  (Used with sknav2.js across the site.)
   ============================================================ */
.phead{position:relative;text-align:center;padding:56px 0 16px;overflow:hidden}
.phead::before{content:"";position:absolute;inset:-30% -10% auto -10%;height:70%;background:radial-gradient(55% 60% at 50% 0%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 70%);pointer-events:none;z-index:0}
.phead>*{position:relative;z-index:1}
.phead h1{font-size:clamp(30px,4.4vw,46px);max-width:20ch;margin:12px auto 12px}
.phead .lede{color:var(--txtMid);max-width:64ch;margin:0 auto;font-size:17px}

/* nav auth area + account menu */
.nav .auth{display:flex;align-items:center;gap:10px;position:relative}
.nav .auth .muted{color:var(--txtDim);font-size:13px}
.acct-btn{display:flex;align-items:center;gap:8px;background:var(--surfaceHi);border:1px solid var(--hair);color:var(--txt);border-radius:11px;padding:7px 11px;font:inherit;font-weight:600;font-size:13.5px;cursor:pointer}
.acct-btn:hover{border-color:var(--accentLine)}
.acct-av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:800;color:#fff;background:linear-gradient(92deg,var(--accent),var(--accent2))}
.acct-tier{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}
.acct-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:210px;background:var(--card);border:1px solid var(--hair);border-radius:12px;box-shadow:0 24px 60px -30px #000;padding:6px;display:grid;gap:2px;z-index:120}
.acct-menu[hidden]{display:none}
.acct-menu .head{font-size:12px;color:var(--txtDim);padding:8px 10px;overflow:hidden;text-overflow:ellipsis}
.acct-menu a,.acct-menu button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--txt);font:inherit;font-size:13.5px;padding:9px 10px;border-radius:8px;cursor:pointer}
.acct-menu a:hover,.acct-menu button:hover{background:var(--surfaceHi)}
.acct-menu hr{border:none;border-top:1px solid var(--hair);margin:4px 0}
@media(max-width:560px){.nav .auth .sk-ghost{display:none}}

/* legal / prose pages */
.legal{max-width:760px;margin:0 auto;padding:30px 22px 72px}
.legal h1{font-size:clamp(28px,4vw,38px);letter-spacing:-.02em;margin:8px 0 6px}
.legal .updated{font-family:var(--mono);font-size:12.5px;color:var(--txtDim);margin:0 0 24px}
.legal h2{font-size:19px;margin:30px 0 10px}
.legal p,.legal li{color:var(--txtMid);font-size:15px;line-height:1.7}
.legal p{margin:0 0 12px}.legal ul{margin:0 0 12px;padding-left:20px}.legal li{margin-bottom:9px}
.legal strong{color:var(--txt);font-weight:600}
.legal a{color:var(--accent)}.legal a:hover{text-decoration:underline}
.legal .lic{background:var(--bg2);border:1px solid var(--hair);border-radius:10px;padding:14px 16px;margin:14px 0;font-family:var(--mono);font-size:12.5px;line-height:1.6;color:var(--txtMid);white-space:pre-wrap}
.legal .comp{font-family:var(--mono);font-size:.92em;color:var(--txt)}

/* examples gallery */
.ex-tools{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:0 auto 26px;max-width:640px}
.ex-search{flex:1;min-width:200px;background:var(--cardHi);border:1px solid var(--hair);color:var(--txt);border-radius:10px;padding:11px 14px;font:inherit;font-size:14px;outline:none}
.ex-search:focus{border-color:var(--accentLine)}
.ex-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.ex-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ex-grid{grid-template-columns:1fr}}
.ex-card{background:var(--card);border:1px solid var(--hair);border-radius:14px;overflow:hidden;transition:.18s;text-decoration:none;color:inherit;display:block}
.ex-card:hover{transform:translateY(-4px);border-color:var(--accentLine)}
.ex-prev{background:var(--bg2);border-bottom:1px solid var(--hair)}
.ex-prev svg{width:100%;height:132px;display:block}
.ex-meta{padding:14px 16px}
.ex-meta .dom{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.ex-meta h3{font-size:15.5px;margin:6px 0 5px}
.ex-meta p{color:var(--txtMid);font-size:13px;margin:0}
.ex-pager{display:flex;gap:6px;justify-content:center;align-items:center;margin:30px 0 0;flex-wrap:wrap}
.ex-pager button{background:var(--card);border:1px solid var(--hair);color:var(--txtMid);border-radius:9px;padding:8px 13px;font:inherit;font-size:13.5px;cursor:pointer}
.ex-pager button:hover{border-color:var(--accentLine);color:var(--txt)}
.ex-pager button.on{background:linear-gradient(92deg,var(--accent),var(--accent2));border-color:transparent;color:#fff}
.ex-pager button[disabled]{opacity:.4;cursor:default}
.ex-count{text-align:center;color:var(--txtDim);font-size:13px;margin:14px 0 0}

/* token aliases used by the examples gallery's own inline styles */
:root{ --surface:var(--cardHi); --bgSub:var(--bg2); }

/* ============================================================
   Pricing page (rendered by pricing.js into .sk-* classes)
   ============================================================ */
.sk-wrap{max-width:980px;margin:0 auto;padding:54px 22px 28px;text-align:center}
.sk-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}
.sk-h1{font-size:clamp(28px,4vw,44px);letter-spacing:-.02em;margin:12px auto 14px;max-width:20ch}
.sk-sub{color:var(--txtMid);max-width:64ch;margin:0 auto;font-size:16.5px;line-height:1.6}
.sk-notice{background:color-mix(in srgb,var(--warn) 10%,transparent);border:1px solid color-mix(in srgb,var(--warn) 35%,transparent);color:var(--txtMid);font-size:13.5px;border-radius:10px;padding:12px 16px;margin:22px auto 0;max-width:660px}
.sk-notice code{font-family:var(--mono);font-size:.92em}
.sk-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:920px;margin:34px auto 0;text-align:left}
@media(max-width:820px){.sk-tiers{grid-template-columns:1fr;max-width:440px}}
.sk-tier-card{background:var(--card);border:1px solid var(--hair);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:6px}
.sk-tier-card.pop{border-color:var(--accentLine);box-shadow:0 0 0 1px var(--accentLine),0 30px 70px -50px var(--accent)}
.sk-tier-name{font-size:18px;font-weight:800}
.sk-badge{align-self:flex-start;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent);border-radius:20px;padding:3px 9px}
.sk-price{font-size:34px;font-weight:800;letter-spacing:-.02em;margin:4px 0 0}
.sk-cadence{color:var(--txtDim);font-size:13.5px}
.sk-feats{list-style:none;padding:0;margin:12px 0 16px;display:grid;gap:8px}
.sk-feats li{color:var(--txtMid);font-size:13.5px;padding-left:22px;position:relative;line-height:1.5}
.sk-feats li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:800}
.sk-cta{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;font:inherit;font-weight:700;font-size:14.5px;text-decoration:none;padding:12px 18px;border-radius:11px;border:1px solid var(--hair);background:var(--surfaceHi);color:var(--txt);cursor:pointer;transition:.14s}
.sk-cta:hover{border-color:var(--accentLine)}
.sk-cta.fill{background:linear-gradient(92deg,var(--accent),var(--accent2));border-color:transparent;color:#fff;box-shadow:0 14px 34px -14px var(--accent)}
.sk-foot{text-align:center;color:var(--txtDim);font-size:13px;padding:8px 22px 40px}
.sk-foot a{color:var(--txtMid)}

/* ============================================================
   Auth pages (login.html / account.html) — .sk-* form classes
   ============================================================ */
.sk-card{background:var(--card);border:1px solid var(--hair);border-radius:16px;padding:24px;max-width:430px;margin:24px auto 0;text-align:left}
.sk-tabs{display:flex;gap:6px;background:var(--bg2);border:1px solid var(--hair);border-radius:11px;padding:4px;margin-bottom:16px}
.sk-tabs button{flex:1;background:none;border:none;color:var(--txtMid);font:inherit;font-weight:700;font-size:14px;padding:8px;border-radius:8px;cursor:pointer}
.sk-tabs button.on{background:var(--surfaceHi);color:var(--txt)}
.sk-field{display:grid;gap:6px;margin-bottom:12px}
.sk-field label{font-size:13px;color:var(--txtMid);font-weight:600}
.sk-field input{background:var(--cardHi);border:1px solid var(--hair);border-radius:9px;color:var(--txt);padding:11px 13px;font:inherit;font-size:14px;outline:none}
.sk-field input:focus{border-color:var(--accentLine)}
.sk-submit{width:100%;background:linear-gradient(92deg,var(--accent),var(--accent2));border:none;color:#fff;border-radius:10px;padding:12px;font:inherit;font-weight:700;font-size:15px;cursor:pointer;box-shadow:0 14px 34px -16px var(--accent)}
.sk-submit:hover{filter:brightness(1.06)}
.sk-or{text-align:center;color:var(--txtDim);font-size:12px;margin:14px 0}
.sk-oauth{width:100%;background:var(--surfaceHi);border:1px solid var(--hair);color:var(--txt);border-radius:10px;padding:11px;font:inherit;font-weight:600;font-size:14px;cursor:pointer}
.sk-oauth:hover{border-color:var(--accentLine)}
.sk-msg{margin-top:12px;font-size:13px;border-radius:9px;padding:10px 12px;color:var(--txtMid)}
.sk-msg.err{background:color-mix(in srgb,var(--bad) 14%,transparent);color:#f5a4b1;border:1px solid color-mix(in srgb,var(--bad) 35%,transparent)}
.sk-msg.ok{background:color-mix(in srgb,var(--ok) 14%,transparent);color:#7ee2a8;border:1px solid color-mix(in srgb,var(--ok) 35%,transparent)}
