/* ANKI — public surface stylesheet v1.0
   Tokens descend from anki_site_map_v1 + voice_mandala_engine_v2 (disk truth). */

:root{
  --ink:#0a0e18; --ink-2:#0d1220; --panel:#141d2c; --panel-2:#1a2334;
  --line:rgba(148,166,192,.14); --line-strong:rgba(148,166,192,.28);
  --ivory:#EDE4CE; --cream:#F4F0E6;
  --blue:#94a6c0; --blue-dim:#62748f; --blue-faint:#48566e;
  --arc:#4a9eff; --arc-bright:#9fd0ff; --arc-dim:#2f6fd0;
  --moss:#7fae8f; --danger:#c47a6e;
  --ink-rgb:10,14,24; --card-1:#10182a; --card-2:#0d1424;
  --max:1120px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{background:var(--ink)}
body{font-family:'Inter',-apple-system,sans-serif;font-size:16px;line-height:1.7;
  color:var(--blue);-webkit-font-smoothing:antialiased}
::selection{background:rgba(74,158,255,.28);color:var(--cream)}
img,svg,canvas{display:block;max-width:100%}
a{color:var(--ivory);text-decoration:none;transition:color .2s}
a:hover{color:var(--arc-bright)}
a:focus-visible,button:focus-visible{outline:2px solid var(--arc);outline-offset:3px;border-radius:2px}

/* ---------- type roles ---------- */
h1,h2,h3,.display{font-family:'Marcellus',serif;font-weight:400;color:var(--cream)}
.data,.chip,.eyebrow,nav .links a{font-family:'Space Grotesk',monospace}
.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--arc);display:block}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;
  background:linear-gradient(to bottom,rgba(var(--ink-rgb),.94),rgba(var(--ink-rgb),.72) 70%,transparent);
  backdrop-filter:blur(8px)}
nav .bar{max-width:var(--max);margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;gap:26px}
.mark{display:flex;align-items:center;gap:11px}
.mark svg{width:26px;height:26px}
.mark .name{font-family:'Marcellus',serif;font-size:17px;letter-spacing:.3em;color:var(--cream)}
/* nav wordmark lockup: ANKI + 'by Northline Office' sub-tag (muted, subordinate; both themes) */
.mark .lockup{display:flex;flex-direction:column;justify-content:center;line-height:1}
.mark .subtag{font-family:'Space Grotesk',monospace;font-size:9px;letter-spacing:.18em;color:var(--blue-dim);margin-top:3px;white-space:nowrap}
nav .links{margin-left:auto;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
nav .links a{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue)}
nav .links a:hover{color:var(--cream)}
nav .links a.here{color:var(--arc)}
nav .links a.cta{border:1px solid var(--arc);border-radius:3px;padding:8px 14px;color:var(--arc)}
nav .links a.cta:hover{color:var(--arc-bright);border-color:var(--arc-bright)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
#mandala{position:absolute;inset:0;width:100%;height:100%;opacity:.85}
.hero .veil{position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 46%,transparent 30%,rgba(var(--ink-rgb),.55) 72%,var(--ink) 100%)}
.hero .inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;
  padding:150px 28px 90px;width:100%;text-align:center}
.hero h1{font-size:clamp(34px,5.4vw,62px);line-height:1.14;letter-spacing:.015em;
  max-width:19ch;margin:22px auto 0;text-shadow:0 0 44px rgba(237,228,206,.16)}
.hero h1 em{font-style:normal;color:var(--arc-bright)}
.hero .sub{max-width:60ch;margin:26px auto 0;font-size:17.5px;color:var(--blue)}
.hero .sub b{color:var(--cream);font-weight:500}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:38px}
.btn{font-family:'Space Grotesk',monospace;font-size:12.5px;letter-spacing:.16em;
  text-transform:uppercase;border-radius:3px;padding:15px 26px;display:inline-block;
  transition:all .2s;border:1px solid transparent}
.btn.gold{background:var(--arc);color:#141005;font-weight:500}
.btn.gold:hover{background:var(--arc-bright);color:#141005;transform:translateY(-1px)}
.btn.ghost{border-color:var(--line-strong);color:var(--cream)}
.btn.ghost:hover{border-color:var(--arc);color:var(--arc-bright)}
.hero .foot-note{margin-top:22px;font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--blue-faint)}

/* ---------- ledger strip ---------- */
.ledger{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink-2);overflow:hidden}
.ledger .lane{display:flex;gap:0;width:max-content;animation:lane 46s linear infinite}
@media (prefers-reduced-motion:reduce){.ledger .lane{animation:none;flex-wrap:wrap;width:auto}}
@keyframes lane{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rcpt{display:flex;align-items:center;gap:10px;padding:15px 30px;white-space:nowrap;
  border-right:1px solid var(--line)}
.rcpt .k{font-family:'Space Grotesk',monospace;font-size:10.5px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--arc)}
.rcpt .v{font-size:13px;color:var(--cream);font-family:'Space Grotesk',monospace}

/* ---------- sections ---------- */
section{padding:96px 28px}
.wrap{max-width:var(--max);margin:0 auto}
.sec-head{margin-bottom:52px;max-width:62ch}
.sec-head.centered{margin-left:auto;margin-right:auto;text-align:center}
h2{font-size:clamp(26px,3.4vw,40px);line-height:1.2;margin-top:14px}
.sec-head p{margin-top:16px;font-size:16.5px}
.vajra-rule{display:flex;align-items:center;gap:16px;max-width:var(--max);margin:0 auto;padding:0 28px}
.vajra-rule .l{height:1px;flex:1;background:linear-gradient(90deg,transparent,rgba(148,166,192,.45))}
.vajra-rule .r{height:1px;flex:1;background:linear-gradient(90deg,rgba(148,166,192,.45),transparent)}
/* BATCH_14: dark divider rules bolder (John ruling); light pinned to its current --line-strong treatment (unchanged) */
[data-theme="light"] .vajra-rule .l{background:linear-gradient(90deg,transparent,var(--line-strong))}
[data-theme="light"] .vajra-rule .r{background:linear-gradient(90deg,var(--line-strong),transparent)}
.vajra-rule svg{width:34px;height:34px;opacity:.9}
/* 14-ADD1: home divider without the mandala — continuous rule, vertical band preserved */
.vajra-rule.bare{gap:0;min-height:34px}

/* ---------- cards ---------- */
.grid{display:grid;gap:14px}
.grid.c3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid.c2{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}
.card{background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:12px;padding:28px;
  transition:border-color .2s,transform .2s}
.card:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.card h3{font-size:19px;letter-spacing:.03em;margin-bottom:10px}
.card p{font-size:14.5px;color:var(--blue)}
.card .glyph{font-size:26px;color:var(--arc);margin-bottom:16px;display:block;
  font-family:'Noto Sans Cuneiform',serif}
.pips{display:flex;align-items:center;gap:8px;margin-top:18px}
.pip{font-family:'Space Grotesk',monospace;font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;padding:3px 9px;border-radius:4px}
.pip.live{background:rgba(127,174,143,.14);color:var(--moss);border:1px solid rgba(127,174,143,.35)}
.pip.growing{background:rgba(74,158,255,.13);color:var(--arc);border:1px solid rgba(74,158,255,.35)}
.pip.chartered{background:rgba(148,166,192,.1);color:var(--blue);border:1px solid var(--line-strong)}

/* ---------- offer ---------- */
.offer{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.offer-box{background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid rgba(74,158,255,.4);border-radius:16px;padding:46px;
  display:grid;grid-template-columns:1.2fr .8fr;gap:44px;align-items:center;
  box-shadow:0 0 80px rgba(74,158,255,.05)}
@media (max-width:820px){.offer-box{grid-template-columns:1fr;padding:32px}}
.price{font-family:'Marcellus',serif;font-size:56px;color:var(--cream);line-height:1}
.price small{font-size:15px;color:var(--blue-dim);font-family:'Inter',sans-serif;
  display:block;margin-top:8px;letter-spacing:.02em}
.offer ul{list-style:none;margin-top:22px}
.offer li{padding:9px 0 9px 30px;position:relative;font-size:15px;color:var(--blue);
  border-bottom:1px solid var(--line)}
.offer li:last-child{border-bottom:none}
.offer li::before{content:"";position:absolute;left:2px;top:1.05em;width:9px;height:2px;border-radius:2px;background:var(--arc)}
.offer li b{color:var(--cream);font-weight:500}

/* ---------- doctrine ---------- */
.doct{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:0;
  border:1px solid var(--line);border-radius:14px;overflow:hidden}
.doct .law{padding:34px 30px;border-right:1px solid var(--line);background:var(--ink-2)}
.doct .law:last-child{border-right:none}
@media (max-width:960px){.doct .law{border-right:none;border-bottom:1px solid var(--line)}
  .doct .law:last-child{border-bottom:none}}
.law .n{font-family:'Space Grotesk',monospace;font-size:10.5px;letter-spacing:.26em;
  color:var(--arc);text-transform:uppercase}
.law h3{margin-top:12px;font-size:18px}
.law p{margin-top:10px;font-size:14px}

/* ---------- substack ---------- */
.stack-embed{border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:var(--panel);max-width:560px;margin:0 auto}
.stack-embed iframe{width:100%;height:150px;border:0;display:block}

/* ---------- timeline (build log) ---------- */
.tl{border-left:1px solid var(--line-strong);margin-left:8px;padding-left:34px;
  display:flex;flex-direction:column;gap:34px;position:relative}
.tl .entry{position:relative}
.tl .entry::before{content:"";position:absolute;left:-39px;top:7px;width:9px;height:9px;
  border-radius:50%;background:var(--ink);border:2px solid var(--arc)}
.tl .date{font-family:'Space Grotesk',monospace;font-size:11px;letter-spacing:.2em;
  color:var(--arc);text-transform:uppercase}
.tl h3{font-size:18px;margin-top:6px}
.tl p{font-size:14.5px;margin-top:6px;max-width:64ch}

/* ---------- about ---------- */
.bio{display:grid;grid-template-columns:300px 1fr;gap:54px;align-items:start}
@media (max-width:860px){.bio{grid-template-columns:1fr}}
.bio-mark{display:flex;align-items:center;justify-content:center}
.bio-mark svg{width:44%;height:44%}
.prose p{margin-bottom:20px;font-size:16.5px;max-width:66ch}
.prose p b{color:var(--cream);font-weight:500}
.prose .pull{font-family:'Marcellus',serif;font-size:24px;color:var(--cream);
  line-height:1.4;border-left:2px solid var(--arc);padding-left:24px;margin:34px 0}

/* ---------- contact ---------- */
.routes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:56px 28px 44px;background:var(--ink-2)}
footer .wrap{display:flex;flex-wrap:wrap;gap:30px;align-items:center}
footer .who{font-size:13px;color:var(--blue-dim)}
footer .who b{color:var(--blue);font-weight:500}
footer .fl{margin-left:auto;display:flex;gap:22px;flex-wrap:wrap}
footer .fl a{font-family:'Space Grotesk',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue)}
.honest{font-size:11.5px;color:var(--blue-faint);letter-spacing:.04em;width:100%;
  border-top:1px solid var(--line);padding-top:20px;margin-top:8px}

/* ---------- page tops (inner pages) ---------- */
.page-top{padding:170px 28px 30px}
.page-top h1{font-size:clamp(30px,4.2vw,50px);max-width:20ch;margin-top:18px}
.page-top .lead{margin-top:20px;font-size:17px;max-width:60ch;color:var(--blue)}


/* ---------- rotator mark (lifted from the app; motion + reduced-motion live in the SVG) ---------- */
.mark .mark-rot{width:26px;height:26px}
.vajra-rule .vajra-rot{width:34px;height:34px;opacity:.9}
.bio-mark .bio-rot{width:220px;height:220px;max-width:60vw}

/* ---------- icon badges (cuneiform card-glyphs retired) ---------- */
.icn-badge{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(74,158,255,.08);border:1px solid rgba(74,158,255,.3);box-shadow:inset 0 0 16px rgba(74,158,255,.10);margin-bottom:16px}
.icn-badge svg{width:24px;height:24px;color:var(--arc);fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 5px rgba(74,158,255,.45))}

/* ---------- premium finish ---------- */
.card{border:none;position:relative;background:linear-gradient(180deg,var(--card-1),var(--card-2))}
.card::before{content:"";position:absolute;inset:0;border-radius:12px;padding:1px;background:linear-gradient(155deg,rgba(74,158,255,.55),rgba(74,158,255,.07) 42%,rgba(74,158,255,.28));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;transition:opacity .25s;opacity:.75}
.card:hover::before{opacity:1}
.btn.gold{background:linear-gradient(180deg,var(--arc-bright),var(--arc));color:#06101f;box-shadow:0 0 26px rgba(74,158,255,.35);border:none}
.btn.gold:hover{box-shadow:0 0 36px rgba(74,158,255,.55);transform:translateY(-1px)}
.hero h1{text-shadow:0 0 46px rgba(74,158,255,.22)}
.pip.growing{background:rgba(74,158,255,.10);color:var(--arc);border:1px solid rgba(74,158,255,.38)}
nav .links a.cta{border-color:var(--arc);color:var(--arc)}
nav .links a.cta:hover{color:var(--arc-bright);border-color:var(--arc-bright)}

/* ---------- divider mandala — slow rotation (BATCH_5) ---------- */
@keyframes anki-slow-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.vajra-rot{animation:anki-slow-spin 90s linear infinite;transform-origin:center}
.mark-rot{animation:anki-slow-spin 90s linear infinite;transform-origin:center}
.bio-rot{animation:anki-slow-spin 90s linear infinite;transform-origin:center}
@media (prefers-reduced-motion:reduce){.vajra-rot,.mark-rot,.bio-rot{animation:none}}

/* ---------- BATCH_7: light theme (dark stays default) ---------- */
[data-theme="light"]{
  --ink:#f4f6fb; --ink-2:#eaeef6; --panel:#ffffff; --panel-2:#f3f6fc;
  --ink-rgb:244,246,251; --card-1:#ffffff; --card-2:#f3f6fc;
  --line:rgba(28,48,80,.20); --line-strong:rgba(28,48,80,.34);
  --ivory:#1b3153; --cream:#132038;
  --blue:#41506a; --blue-dim:#4f5f79; --blue-faint:#5b6a82;
  --arc:#2f6fd0; --arc-bright:#4a9eff; --arc-dim:#1f4f9e;
  --moss:#3f7d56; --danger:#b25a4c;
}
/* nav theme-toggle button (matches nav link styling) */
nav .links .tgl{font-family:'Space Grotesk',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);background:transparent;border:1px solid var(--line-strong);border-radius:3px;padding:7px 12px;cursor:pointer;transition:color .2s,border-color .2s}
nav .links .tgl:hover{color:var(--cream);border-color:var(--arc)}
/* E5: <img> mandala ornaments carry baked ivory/blue strokes — darken on light for legibility (bounded, reversible) */
[data-theme="light"] .mark-rot,[data-theme="light"] .vajra-rot,[data-theme="light"] .bio-rot{filter:brightness(.34) saturate(1.3) contrast(1.06)}

/* ---------- BATCH_11-R: light definition pass (LIGHT THEME ONLY; dark untouched) ---------- */
/* E2 — premium buttons on light */
[data-theme="light"] .btn.gold{background:linear-gradient(180deg,var(--arc-dim),#153a73);color:#f5f9ff;box-shadow:0 2px 12px rgba(28,48,80,.18),inset 0 0 0 1px rgba(255,255,255,.14);text-shadow:0 1px 1px rgba(8,18,38,.28)}
[data-theme="light"] .btn.gold:hover{box-shadow:0 5px 18px rgba(28,48,80,.26),inset 0 0 0 1px rgba(255,255,255,.20)}
[data-theme="light"] .btn.ghost{box-shadow:0 1px 5px rgba(28,48,80,.07)}
[data-theme="light"] .btn.ghost:hover{border-color:var(--arc);color:var(--arc-dim)}
[data-theme="light"] nav .links a.cta{box-shadow:0 1px 4px rgba(28,48,80,.06)}
[data-theme="light"] nav .links .tgl{box-shadow:0 1px 4px rgba(28,48,80,.05)}
/* E3 — chyron/ticker (ledger receipts strip) hairline definition; motion untouched */
[data-theme="light"] .ledger{border-top-color:var(--line-strong);border-bottom-color:var(--line-strong)}
/* E4 — card definition on white: restrained butter-gold hairline + soft shadow (no gold in dark) */
[data-theme="light"] .card{box-shadow:0 2px 16px rgba(28,48,80,.07)}
[data-theme="light"] .card::before{background:linear-gradient(155deg,rgba(199,171,115,.90),rgba(199,171,115,.18) 45%,rgba(199,171,115,.60));opacity:.9}
[data-theme="light"] .card:hover::before{opacity:1}
