/* ══════════════════════════════════════════════════════════════
   Vostego — Career surfaces, refined.
   Token-driven so every rule survives a theme swap. Nothing here
   hardcodes a hex that isn't a fallback. Default palette = editorial.
   ══════════════════════════════════════════════════════════════ */

:root {
  --paper-0:#fcfbf9; --paper-1:#f3f1ee; --paper-2:#e6e3dd;
  --ink-0:#232946; --ink-1:#2e3556; --ink-2:#5b6485; --ink-3:#8a92ad; --ink-4:#b8c1d4;
  --brand:#232946; --brand-soft:#e5e8f6; --brand-deep:#161a35;
  --sage:#b8c1ec; --sage-soft:#eef0fa;
  --clay:#d99aa3; --clay-soft:#f6e3e6; --clay-deep:#8a4d56;
  --on-accent:#232946; --on-ink:#fcfbf9;
  --panel-dark:#161a35; --panel-dark-2:#232946;
  --card:#ffffff;
  --line:rgba(35,41,70,0.10); --line-strong:rgba(35,41,70,0.16);
  --shadow-sm:0 1px 2px rgba(35,41,70,0.04);
  --shadow-md:0 6px 24px rgba(35,41,70,0.07);
  --shadow-lg:0 20px 45px rgba(35,41,70,0.09);
  --shadow-xl:0 32px 70px rgba(35,41,70,0.16);

  --font-display:'Fraunces','DM Serif Display',Georgia,serif;
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --font-serif:'Source Serif 4','Source Serif Pro',Georgia,serif;
  --font-mono:'JetBrains Mono','IBM Plex Mono',SF Mono,monospace;

  --r-xs:4px; --r-sm:6px; --r-md:10px; --r-lg:14px; --r-xl:20px; --r-2xl:28px; --radius-full:999px;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px;
  --space-6:24px; --space-7:32px; --space-8:40px; --space-10:56px; --space-12:72px; --space-16:104px;

  --text-xs:12px; --text-sm:14px; --text-base:16px; --text-lg:18px; --text-xl:21px;
  --text-2xl:clamp(22px,2.2vw,27px); --text-3xl:clamp(27px,3vw,34px); --text-4xl:clamp(33px,4vw,46px);
}

/* ── Warm (the original default; offered as a theme) ─────────── */
[data-theme="warm"]{
  --paper-0:#faf8f3; --paper-1:#f4f1ea; --paper-2:#ebe6dc;
  --ink-0:#15171c; --ink-1:#2a2d36; --ink-2:#5b6070; --ink-3:#8a8f9c; --ink-4:#bcbfc7;
  --brand:#5560d0; --brand-soft:#ebecf9; --brand-deep:#2f378a;
  --sage:#6da8a2; --sage-soft:#dfeae8;
  --clay:#c47b4a; --clay-soft:#f4e2d2; --clay-deep:#7a3f1e;
  --on-accent:#15171c; --on-ink:#ffffff;
  --panel-dark:#0f1115; --panel-dark-2:#15181f; --card:#ffffff;
  --line:rgba(20,22,28,0.08); --line-strong:rgba(20,22,28,0.14);
  --shadow-sm:0 1px 2px rgba(20,22,28,0.04);
  --shadow-md:0 6px 24px rgba(20,22,28,0.06);
  --shadow-lg:0 20px 45px rgba(20,22,28,0.08);
  --shadow-xl:0 32px 70px rgba(20,22,28,0.14);
}

/* ── Dark ────────────────────────────────────────────────────── */
[data-theme="dark"]{
  --paper-0:#0f1320; --paper-1:#1a1f33; --paper-2:#2a3050;
  --ink-0:#f3eee6; --ink-1:#d8d3c9; --ink-2:#9aa1b8; --ink-3:#6f7896; --ink-4:#4a5375;
  --brand:#b8c1ec; --brand-soft:#2a3050; --brand-deep:#e5e8f6;
  --clay:#e7b3bb; --clay-soft:#2e2128; --clay-deep:#f3d0d5;
  --sage:#b8c1ec; --sage-soft:#232946;
  --on-accent:#232946; --on-ink:#0f1320;
  --panel-dark:#060816; --panel-dark-2:#0f1320; --card:#1a1f33;
  --line:rgba(255,255,255,0.08); --line-strong:rgba(255,255,255,0.14);
  --shadow-sm:0 1px 2px rgba(0,0,0,0.4);
  --shadow-md:0 6px 24px rgba(0,0,0,0.35);
  --shadow-lg:0 20px 45px rgba(0,0,0,0.5);
  --shadow-xl:0 32px 70px rgba(0,0,0,0.6);
}

/* ── Forest ──────────────────────────────────────────────────── */
[data-theme="forest"]{
  --paper-0:#f5f3ea; --paper-1:#ece9dd; --paper-2:#dddccd;
  --ink-0:#18271f; --ink-1:#243a2e; --ink-2:#4f6358; --ink-3:#7e9085; --ink-4:#aebbb1;
  --brand:#2f6a4f; --brand-soft:#dde9e1; --brand-deep:#1c4632;
  --clay:#c47a45; --clay-soft:#f0ddcb; --clay-deep:#6f3c1d;
  --sage:#7fae8c; --sage-soft:#e0ebe2;
  --on-accent:#18271f; --on-ink:#f5f3ea;
  --panel-dark:#11241a; --panel-dark-2:#18271f; --card:#ffffff;
  --line:rgba(24,39,31,0.10); --line-strong:rgba(24,39,31,0.16);
  --shadow-sm:0 1px 2px rgba(24,39,31,0.04);
  --shadow-md:0 6px 24px rgba(24,39,31,0.07);
  --shadow-lg:0 20px 45px rgba(24,39,31,0.10);
  --shadow-xl:0 32px 70px rgba(24,39,31,0.16);
}

/* ── Slate ───────────────────────────────────────────────────── */
[data-theme="slate"]{
  --paper-0:#f4f5f7; --paper-1:#eaecf0; --paper-2:#dce0e6;
  --ink-0:#1a2030; --ink-1:#2a3142; --ink-2:#586072; --ink-3:#868d9e; --ink-4:#b6bcc8;
  --brand:#3a55c8; --brand-soft:#e4e8f8; --brand-deep:#243a8f;
  --clay:#3f8a80; --clay-soft:#dcebe8; --clay-deep:#265b53;
  --sage:#6da8a2; --sage-soft:#dfeae8;
  --on-accent:#ffffff; --on-ink:#f4f5f7;
  --panel-dark:#141a28; --panel-dark-2:#1a2030; --card:#ffffff;
  --line:rgba(26,32,48,0.09); --line-strong:rgba(26,32,48,0.15);
  --shadow-sm:0 1px 2px rgba(26,32,48,0.04);
  --shadow-md:0 6px 24px rgba(26,32,48,0.07);
  --shadow-lg:0 20px 45px rgba(26,32,48,0.10);
  --shadow-xl:0 32px 70px rgba(26,32,48,0.16);
}

/* ── Mocha ───────────────────────────────────────────────────── */
[data-theme="mocha"]{
  --paper-0:#f7f3ec; --paper-1:#efe9de; --paper-2:#e2d9c9;
  --ink-0:#241c14; --ink-1:#38291d; --ink-2:#6a5848; --ink-3:#9a8775; --ink-4:#c4b4a1;
  --brand:#8a5a36; --brand-soft:#ece0d2; --brand-deep:#5a3823;
  --clay:#c0902b; --clay-soft:#f1e4c2; --clay-deep:#7a5c12;
  --sage:#9a8f6a; --sage-soft:#ece6d4;
  --on-accent:#241c14; --on-ink:#f7f3ec;
  --panel-dark:#1a130c; --panel-dark-2:#241c14; --card:#ffffff;
  --line:rgba(36,28,20,0.10); --line-strong:rgba(36,28,20,0.16);
  --shadow-sm:0 1px 2px rgba(36,28,20,0.05);
  --shadow-md:0 6px 24px rgba(36,28,20,0.08);
  --shadow-lg:0 20px 45px rgba(36,28,20,0.11);
  --shadow-xl:0 32px 70px rgba(36,28,20,0.18);
}

/* ── Type systems ────────────────────────────────────────────── */
[data-type="grotesk"]{ --font-display:'Space Grotesk','Inter',sans-serif; --font-serif:'Source Serif 4',Georgia,serif; --font-mono:'Space Mono','JetBrains Mono',monospace; }
[data-type="literary"]{ --font-display:'Newsreader','Fraunces',Georgia,serif; --font-serif:'Newsreader',Georgia,serif; }

/* ══════════════════════════════════════════════════════════════
   Base
   ══════════════════════════════════════════════════════════════ */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--paper-0); color:var(--ink-1);
  font-family:var(--font-sans); font-size:var(--text-base); line-height:1.55;
  -webkit-font-smoothing:antialiased; font-feature-settings:'ss01' 1,'cv11' 1;
}
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ink-0); letter-spacing:-0.02em; margin:0; font-weight:500; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:var(--clay-soft); color:var(--clay-deep); }

.display{ font-family:var(--font-display); letter-spacing:-0.02em; }
.serif{ font-family:var(--font-serif); }
.mono{ font-family:var(--font-mono); }
.tnum{ font-variant-numeric:tabular-nums; }

/* Mono eyebrow — the editorial label voice */
.eyebrow{
  font-family:var(--font-mono); font-size:11px; font-weight:600;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-3);
}
.eyebrow--clay{ color:var(--clay-deep); }

/* ══════════════════════════════════════════════════════════════
   Buttons
   ══════════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-sans); font-size:var(--text-sm); font-weight:600;
  line-height:1; letter-spacing:0.005em; cursor:pointer; white-space:nowrap;
  padding:11px 18px; border-radius:var(--radius-full); border:1px solid transparent;
  transition:transform .16s cubic-bezier(.4,0,.2,1), background .2s, border-color .2s, color .2s, box-shadow .2s;
}
.btn:active{ transform:translateY(1px) scale(.99); }
.btn svg{ width:15px; height:15px; }
.btn--primary{ background:var(--ink-0); color:var(--on-ink); }
.btn--primary:hover{ box-shadow:var(--shadow-md); transform:translateY(-1px); }
.btn--accent{ background:var(--clay); color:var(--on-accent); }
.btn--accent:hover{ box-shadow:0 8px 22px -8px var(--clay); transform:translateY(-1px); }
.btn--outline{ background:transparent; color:var(--ink-1); border-color:var(--line-strong); }
.btn--outline:hover{ border-color:var(--ink-2); color:var(--ink-0); background:var(--paper-1); }
.btn--ghost{ background:transparent; color:var(--ink-2); padding:9px 12px; }
.btn--ghost:hover{ background:var(--paper-1); color:var(--ink-0); }
.btn--sm{ padding:8px 14px; font-size:13px; }
.btn--lg{ padding:14px 24px; font-size:var(--text-base); }
.btn--block{ width:100%; }

/* Tags & pills */
.tag{
  display:inline-flex; align-items:center; gap:6px; padding:4px 10px;
  border-radius:var(--radius-full); font-family:var(--font-mono); font-size:11px;
  font-weight:600; letter-spacing:0.04em; background:var(--paper-1);
  border:1px solid var(--line); color:var(--ink-2);
}
.tag .dot{ width:6px; height:6px; border-radius:999px; background:var(--clay); }
.tag--clay{ background:var(--clay-soft); color:var(--clay-deep); border-color:transparent; }
.tag--brand{ background:var(--brand-soft); color:var(--brand-deep); border-color:transparent; }

/* ══════════════════════════════════════════════════════════════
   App shell — left rail in its real product context
   ══════════════════════════════════════════════════════════════ */
.app{ display:grid; grid-template-columns:264px 1fr; min-height:100vh; }
.rail{
  position:sticky; top:0; align-self:start; height:100vh;
  display:flex; flex-direction:column; gap:2px;
  padding:24px 16px; border-right:1px solid var(--line); background:var(--paper-0);
  overflow-y:auto;
}
.rail-brand{ font-family:var(--font-display); font-size:21px; font-weight:600; color:var(--ink-0); letter-spacing:0.01em; padding:4px 10px 18px; }
.rail-brand .dot{ color:var(--clay); }
.rail-label{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-3); padding:14px 10px 6px; }
.rail-item{
  display:flex; align-items:center; gap:11px; padding:8px 11px; border-radius:9px;
  font-size:13.5px; font-weight:500; color:var(--ink-2); cursor:pointer;
  transition:background .18s, color .18s;
}
.rail-item:hover{ background:var(--paper-1); color:var(--ink-0); }
.rail-item.on{ background:var(--brand-soft); color:var(--brand-deep); font-weight:600; }
.rail-item .ic{ width:15px; height:15px; flex:none; opacity:.85; }
.rail-spacer{ flex:1; min-height:18px; }
.rail-goal{
  margin:8px 4px 0; padding:13px 14px; border:1px solid var(--line); border-radius:12px;
  background:var(--paper-1);
}
.rail-goal .gl{ font-family:var(--font-mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.rail-goal .gt{ font-family:var(--font-display); font-size:14px; color:var(--ink-0); margin-top:5px; line-height:1.25; }
.rail-goal .gm{ font-family:var(--font-serif); font-style:italic; font-size:12px; color:var(--ink-2); margin-top:4px; }
.rail-usage{ margin:10px 4px 0; padding:13px 14px; border:1px solid var(--line); border-radius:12px; background:var(--paper-1); }
.rail-usage .uh{ display:flex; justify-content:space-between; align-items:baseline; }
.rail-usage .ul{ font-family:var(--font-mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.rail-usage .uc{ font-family:var(--font-mono); font-size:11px; color:var(--clay-deep); font-variant-numeric:tabular-nums; }
.rail-meter{ height:5px; border-radius:99px; background:var(--paper-2); margin-top:8px; overflow:hidden; }
.rail-meter > i{ display:block; height:100%; background:var(--clay); border-radius:99px; }

.canvas{ min-width:0; display:flex; flex-direction:column; }

/* simple top product bar */
.topbar{
  position:sticky; top:0; z-index:20; display:flex; align-items:center; gap:16px;
  padding:14px 32px; border-bottom:1px solid var(--line);
  background:color-mix(in srgb, var(--paper-0) 86%, transparent); backdrop-filter:blur(12px) saturate(160%);
}
.topbar .crumb{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.topbar .crumb b{ color:var(--ink-1); font-weight:600; }
.topbar-spacer{ flex:1; }
.searchpill{
  display:flex; align-items:center; gap:8px; padding:8px 14px; border-radius:99px;
  border:1px solid var(--line); background:var(--paper-1); color:var(--ink-3); font-size:13px; cursor:pointer;
}
.avatar{ width:32px; height:32px; border-radius:99px; background:var(--brand-soft); color:var(--brand-deep);
  display:grid; place-items:center; font-family:var(--font-display); font-weight:600; font-size:13px; }

@media (max-width:980px){
  .app{ grid-template-columns:1fr; }
  .rail{ display:none; }
}

/* ══════════════════════════════════════════════════════════════
   Review chrome — floating control bar (NOT part of product)
   ══════════════════════════════════════════════════════════════ */
.review-bar{
  position:fixed; left:50%; bottom:20px; transform:translateX(-50%); z-index:9000;
  display:flex; align-items:center; gap:10px; padding:7px 8px 7px 16px;
  background:rgba(18,19,26,0.92); backdrop-filter:blur(14px) saturate(180%);
  border-radius:999px; color:#fff; font-family:var(--font-sans);
  box-shadow:0 16px 40px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.07) inset;
  max-width:calc(100vw - 32px);
}
.review-bar .rb-brand{ font-family:var(--font-display); font-size:13px; font-weight:600; letter-spacing:.02em; white-space:nowrap; }
.review-bar .rb-brand .dot{ color:#d99aa3; }
.review-bar .rb-sep{ width:1px; height:18px; background:rgba(255,255,255,0.16); flex:none; }
.review-seg{ display:flex; padding:2px; background:rgba(255,255,255,0.08); border-radius:999px; }
.review-seg a, .review-seg button{
  border:0; background:transparent; color:rgba(255,255,255,0.66);
  font:600 11.5px/1 var(--font-sans); letter-spacing:.01em; padding:7px 13px; border-radius:999px; cursor:pointer; transition:all .18s;
}
.review-seg a.on, .review-seg button.on{ background:#fff; color:#15171c; }
.review-seg a:hover:not(.on), .review-seg button:hover:not(.on){ color:#fff; }
.rb-select{
  appearance:none; border:0; cursor:pointer; color:#fff;
  background:rgba(255,255,255,0.08); border-radius:999px;
  font:600 11.5px/1 var(--font-sans); letter-spacing:.01em; padding:8px 30px 8px 13px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 11px center;
}
.rb-select option{ color:#15171c; }
.rb-toggle{ display:flex; align-items:center; gap:7px; cursor:pointer; padding-right:6px; }
.rb-toggle .lbl{ font:600 11.5px/1 var(--font-sans); color:rgba(255,255,255,0.78); white-space:nowrap; }
.rb-switch{ width:34px; height:19px; border-radius:99px; background:rgba(255,255,255,0.18); position:relative; transition:background .2s; flex:none; }
.rb-switch::after{ content:""; position:absolute; top:2px; left:2px; width:15px; height:15px; border-radius:99px; background:#fff; transition:transform .2s; }
.rb-toggle.on .rb-switch{ background:#d99aa3; }
.rb-toggle.on .rb-switch::after{ transform:translateX(15px); }
@media (max-width:720px){
  .review-bar{ flex-wrap:wrap; justify-content:center; bottom:12px; }
}

/* ══════════════════════════════════════════════════════════════
   Annotation pins — rationale overlay
   ══════════════════════════════════════════════════════════════ */
body:not(.notes-on) .anno{ display:none; }
.anno{ position:absolute; z-index:60; }
.anno-dot{
  width:24px; height:24px; border-radius:99px; background:var(--clay); color:var(--on-accent);
  display:grid; place-items:center; font:700 12px/1 var(--font-mono);
  box-shadow:0 4px 14px -2px var(--clay), 0 0 0 4px color-mix(in srgb, var(--clay) 26%, transparent);
  cursor:pointer; transition:transform .16s;
}
.anno:hover .anno-dot{ transform:scale(1.12); }
.anno-card{
  position:absolute; top:30px; left:0; width:268px; padding:13px 15px;
  background:var(--ink-0); color:var(--on-ink); border-radius:12px;
  box-shadow:var(--shadow-xl); opacity:0; pointer-events:none; transform:translateY(-4px);
  transition:opacity .18s, transform .18s; z-index:61;
}
.anno:hover .anno-card{ opacity:1; pointer-events:auto; transform:translateY(0); }
.anno-card.flip-right{ left:auto; right:0; }
.anno-card .at{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb,var(--clay) 75%, white); margin-bottom:5px; }
.anno-card .ah{ font-family:var(--font-display); font-size:14px; font-weight:600; margin-bottom:5px; line-height:1.25; }
.anno-card .ab{ font-size:12.5px; line-height:1.5; color:color-mix(in srgb, var(--on-ink) 78%, transparent); }

/* Notes legend banner */
.notes-legend{
  display:none; position:fixed; top:16px; left:50%; transform:translateX(-50%); z-index:8000;
  align-items:center; gap:10px; padding:8px 16px; border-radius:99px;
  background:var(--clay-soft); color:var(--clay-deep); border:1px solid color-mix(in srgb,var(--clay) 30%, transparent);
  font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; box-shadow:var(--shadow-md);
}
body.notes-on .notes-legend{ display:flex; }
