/* ============================================================
   the h3rbalist — design system
   Concept: monastic herbal manuscript meets modern pharmacopoeia.
   Serif = the old source. Sans/mono = the modern evidence.
   Palette: cool parchment, oak-gall ink, spruce glass, madder, gold.
   ============================================================ */

:root{
  /* paper / surfaces */
  --paper:    #EEECE4;
  --paper-2:  #F6F5EF;
  --paper-3:  #FBFAF6;
  /* ink */
  --ink:      #20242C;
  --ink-soft: #4C515A;
  --ink-faint:#7A7E86;
  /* brand + accents */
  --brand:   #2A3F63;
  --brand-2: #3C557E;
  --madder:   #97392C;
  --madder-2: #B85842;
  --gold:     #A6854A;
  --gold-2:   #C2A569;
  /* lines */
  --line:   rgba(32,36,44,.15);
  --line-2: rgba(32,36,44,.30);
  --line-gold: rgba(166,133,74,.45);

  --maxw: 1180px;
  --readw: 720px;
  --r: 3px;

  --font-display:'Fraunces', Georgia, serif;
  --font-serif:'Spectral', Georgia, serif;
  --font-sans:'IBM Plex Sans', system-ui, sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, monospace;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-serif);
  font-size:18px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{ /* faint laid-paper texture, extremely subtle */
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.5;
  background-image:repeating-linear-gradient(90deg, rgba(33,38,31,.012) 0 1px, transparent 1px 3px);
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; position:relative; z-index:1; }
.read{ max-width:var(--readw); }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:400; line-height:1.1; letter-spacing:-.01em; margin:0; }
.eyebrow{
  font-family:var(--font-sans); font-size:12px; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:var(--gold);
}
.eyebrow.spruce{ color:var(--brand-2); }
.lead{ font-size:1.22rem; color:var(--ink-soft); line-height:1.62; }
.latin{ font-family:var(--font-mono); font-style:normal; font-size:.82em; color:var(--brand-2); letter-spacing:-.01em; }
.mono{ font-family:var(--font-mono); }
.sans{ font-family:var(--font-sans); }
em,i{ font-style:italic; }

/* ---------- top nav ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-in{ display:flex; align-items:center; gap:28px; height:62px; }
.brand{ display:flex; align-items:center; gap:11px; text-decoration:none; margin-right:auto; }
.brand .mark{ width:26px; height:26px; color:var(--brand); flex:0 0 auto; }
.brand .word{ font-family:var(--font-display); font-size:1.16rem; letter-spacing:-.02em; }
.brand .word b{ font-weight:600; }
.brand .word .h3{ color:var(--madder); font-style:italic; }
.nav-links{ display:flex; gap:26px; align-items:center; font-family:var(--font-sans); font-size:.84rem; letter-spacing:.02em; }
.nav-links a{ text-decoration:none; color:var(--ink-soft); padding:4px 0; border-bottom:1.5px solid transparent; transition:color .15s,border-color .15s; }
.nav-links a:hover,.nav-links a[aria-current="page"]{ color:var(--ink); border-color:var(--gold); }
.nav-burger{ display:none; background:none; border:0; color:var(--ink); cursor:pointer; padding:6px; }
.nav-search{ display:inline-flex; align-items:center; color:var(--ink-soft); padding:4px; border-bottom:1.5px solid transparent; }
.nav-search:hover{ color:var(--ink); }
.lang-switch{ display:inline-flex; gap:2px; margin-left:6px; padding-left:14px; border-left:1px solid var(--line-2); }
.lang-btn{ background:none; border:0; cursor:pointer; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.04em; color:var(--ink-faint); padding:3px 5px; border-radius:4px; transition:color .15s,background .15s; }
.lang-btn:hover{ color:var(--ink); }
.lang-btn.on{ color:var(--paper); background:var(--brand); }
/* search */
.search-controls{ display:flex; flex-wrap:wrap; gap:12px; align-items:center; }
.search-controls #q{ flex:1 1 280px; min-width:200px; font-family:var(--font-sans); font-size:1rem; padding:13px 16px; border:1px solid var(--line-2); border-radius:10px; background:var(--paper-3); color:var(--ink); }
.search-controls #q:focus{ outline:none; border-color:var(--brand-2); }
.search-controls select{ font-family:var(--font-sans); font-size:.9rem; padding:12px 14px; border:1px solid var(--line-2); border-radius:10px; background:var(--paper-3); color:var(--ink); cursor:pointer; }
.search-controls .chk{ display:flex; align-items:center; gap:8px; font-family:var(--font-sans); font-size:.88rem; color:var(--ink-soft); cursor:pointer; }
.rescount{ margin-top:18px; font-family:var(--font-mono); font-size:.8rem; color:var(--ink-faint); }
/* safety groups */
.safe-group{ margin-bottom:44px; }
.safe-group h2{ font-size:1.45rem; margin:0 0 18px; padding-bottom:12px; border-bottom:1px solid var(--line); color:var(--madder); }
/* about prose */
#about-body h2{ font-size:1.5rem; margin:40px 0 14px; padding-top:28px; border-top:1px solid var(--line); }
#about-body h2:first-child{ border-top:0; padding-top:0; margin-top:0; }
#about-body p{ margin:0 0 1em; }
#about-body ul{ margin:0 0 1.2em; padding-left:1.1em; }
#about-body li{ margin:0 0 .5em; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-sans); font-size:.86rem; font-weight:500; letter-spacing:.02em;
  text-decoration:none; cursor:pointer; padding:11px 20px; border-radius:var(--r);
  border:1px solid var(--brand); color:var(--paper-3); background:var(--brand);
  transition:background .18s, transform .18s, color .18s;
}
.btn:hover{ background:var(--brand-2); transform:translateY(-1px); }
.btn.ghost{ background:transparent; color:var(--brand); }
.btn.ghost:hover{ background:rgba(42,63,99,.06); }
.btn .ar{ transition:transform .2s; }
.btn:hover .ar{ transform:translateX(3px); }

/* ---------- badges ---------- */
.badges{ display:flex; flex-wrap:wrap; gap:7px; }
.badge{
  font-family:var(--font-sans); font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  padding:4px 9px; border-radius:100px; border:1px solid var(--line-2); color:var(--ink-soft);
  display:inline-flex; align-items:center; gap:5px; white-space:nowrap;
}
.badge .dot{ width:6px; height:6px; border-radius:50%; background:currentColor; }
.badge.era{ border-color:var(--line-gold); color:var(--gold); }
.badge.ev-G{ color:var(--brand-2); border-color:rgba(42,63,99,.4); background:rgba(42,63,99,.06); }
.badge.ev-K{ color:#7a5a14; border-color:rgba(166,133,74,.5); background:rgba(166,133,74,.1); }
.badge.ev-T{ color:var(--ink-soft); }
.badge.warn{ color:var(--madder); border-color:rgba(151,57,44,.45); background:rgba(151,57,44,.07); }

/* ---------- hero ---------- */
.hero{ padding:72px 0 56px; border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.35fr .65fr; gap:48px; align-items:center; }
.hero h1{ font-size:clamp(2.6rem,5.5vw,4.5rem); margin:.3em 0 .35em; }
.hero h1 .ital{ font-style:italic; color:var(--brand); }
.manuscript-quote{
  font-family:var(--font-display); font-style:italic; font-size:clamp(1.3rem,2.4vw,1.9rem);
  line-height:1.32; color:var(--brand); border-left:2px solid var(--gold); padding-left:22px; margin:0 0 4px;
}
.quote-trans{ font-family:var(--font-serif); font-style:italic; color:var(--ink-soft); padding-left:24px; font-size:1.02rem; }
.quote-cite{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-faint); padding-left:24px; margin-top:8px; letter-spacing:-.01em; }
.hero-art{ color:var(--brand); opacity:.92; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }

/* ---------- section scaffold ---------- */
.section{ padding:74px 0; border-bottom:1px solid var(--line); }
.section.tight{ padding:52px 0; }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:38px; }
.sec-head h2{ font-size:clamp(1.8rem,3.4vw,2.6rem); }
.sec-head p{ margin:.5em 0 0; color:var(--ink-soft); max-width:48ch; }

/* ---------- pillars (method) ---------- */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.pillar{ background:var(--paper-2); padding:30px 26px; }
.pillar .n{ font-family:var(--font-mono); font-size:.74rem; color:var(--gold); letter-spacing:.1em; }
.pillar h3{ font-size:1.32rem; margin:14px 0 8px; }
.pillar p{ margin:0; color:var(--ink-soft); font-size:.98rem; line-height:1.6; }
.pillar .ico{ color:var(--brand); margin-bottom:6px; }

/* ---------- category grid ---------- */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.cat-card{
  background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r);
  padding:26px 24px 22px; text-decoration:none; color:inherit; display:flex; flex-direction:column;
  min-height:200px; transition:border-color .2s, transform .2s, background .2s;
}
.cat-card:hover{ border-color:var(--line-gold); transform:translateY(-3px); background:var(--paper-3); }
.cat-card .art{ color:var(--brand); width:58px; height:auto; margin-bottom:12px; }
.cat-card .art svg{ display:block; width:100%; height:auto; }
.cat-card h3{ font-size:1.4rem; }
.cat-card .sv{ font-family:var(--font-sans); font-size:.78rem; color:var(--ink-faint); letter-spacing:.04em; text-transform:uppercase; margin-top:3px; }
.cat-card p{ font-size:.95rem; color:var(--ink-soft); margin:11px 0 0; line-height:1.55; }
.cat-card .count{ margin-top:auto; padding-top:16px; font-family:var(--font-mono); font-size:.76rem; color:var(--gold); display:flex; align-items:center; gap:7px; }

/* ---------- tentpole feature cards ---------- */
.feature-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.feature{
  position:relative; background:var(--brand); color:var(--paper-3); border-radius:var(--r);
  padding:34px 32px; text-decoration:none; overflow:hidden; min-height:230px; display:flex; flex-direction:column;
  transition:transform .2s;
}
.feature:hover{ transform:translateY(-3px); }
.feature.alt{ background:var(--paper-2); color:var(--ink); border:1px solid var(--line); }
.feature .fart{ position:absolute; right:-10px; bottom:-12px; opacity:.16; width:170px; color:currentColor; }
.feature.alt .fart{ opacity:.5; color:var(--gold); }
.feature .eyebrow{ color:var(--gold-2); }
.feature.alt .eyebrow{ color:var(--gold); }
.feature h3{ font-size:1.7rem; margin:12px 0 8px; max-width:18ch; }
.feature p{ position:relative; font-size:.96rem; line-height:1.55; opacity:.92; max-width:34ch; margin:0; }
.feature .go{ margin-top:auto; padding-top:18px; font-family:var(--font-sans); font-size:.82rem; display:flex; align-items:center; gap:8px; }

/* ---------- two-up split (kodex + data teasers) ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }

/* onboarding — "Ny här?" */
.onboard{ background:var(--paper-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.onb-head{ max-width:64ch; margin-bottom:30px; }
.onb-head h2{ font-size:clamp(1.7rem,3.2vw,2.4rem); margin:.25em 0 .3em; }
.onb-head p{ color:var(--ink-soft); font-size:1.02rem; line-height:1.6; }
.onb-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.onb-card{ display:flex; flex-direction:column; background:var(--paper-3); border:1px solid var(--line); border-radius:var(--r); padding:22px 20px; text-decoration:none; color:inherit; transition:border-color .2s, transform .2s; }
.onb-card:hover{ border-color:var(--line-gold); transform:translateY(-3px); }
.onb-n{ font-family:var(--font-mono); font-size:.78rem; color:var(--gold); letter-spacing:.05em; }
.onb-card h3{ font-size:1.16rem; margin:10px 0 0; line-height:1.2; }
.onb-l{ font-family:var(--font-sans); font-size:.84rem; font-weight:600; color:var(--brand-2); margin:7px 0 0; }
.onb-d{ font-size:.85rem; color:var(--ink-soft); line-height:1.5; margin:9px 0 0; }
.onb-b{ margin-top:auto; padding-top:16px; display:inline-flex; align-items:center; gap:7px; font-family:var(--font-sans); font-size:.82rem; font-weight:600; color:var(--brand); }
.onb-b svg{ transition:transform .15s; }
.onb-card:hover .onb-b svg{ transform:translateX(3px); }
@media (max-width:1100px){ .onb-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .onb-grid{ grid-template-columns:1fr; } }

/* egna recept — coming soon */
.coming{ text-align:center; max-width:60ch; margin:0 auto; padding:36px 0; }
.coming .art{ width:92px; margin:0 auto 22px; color:var(--brand); }
.coming .art svg{ width:100%; height:auto; }
.coming .soon-tag{ display:inline-block; font-family:var(--font-sans); font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); border:1px solid var(--line-gold); border-radius:100px; padding:5px 14px; margin-bottom:18px; }
.coming h1{ font-size:clamp(2.3rem,5vw,3.4rem); margin:0 0 .3em; }
.coming p{ font-size:1.08rem; color:var(--ink-soft); line-height:1.65; margin:0 auto 28px; }
.coming .cta-row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.panel{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); padding:36px 34px; position:relative; overflow:hidden; }
.panel.dark{ background:var(--brand); color:var(--paper-3); border-color:var(--brand); }
.panel h3{ font-size:1.7rem; margin:12px 0 10px; }
.panel p{ color:var(--ink-soft); margin:0 0 20px; }
.panel.dark p{ color:rgba(251,250,245,.85); }
.panel .part{ position:absolute; right:-20px; top:-10px; width:150px; opacity:.12; color:currentColor; }

/* ---------- recipe cards (category + listings) ---------- */
.recipe-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.rcard{
  display:grid; grid-template-columns:64px 1fr; gap:18px; align-items:start;
  background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r);
  padding:22px 24px; text-decoration:none; color:inherit; transition:border-color .2s, transform .2s, background .2s;
}
.rcard:hover{ border-color:var(--line-gold); transform:translateY(-2px); background:var(--paper-3); }
.rcard .art{ color:var(--brand); width:64px; height:64px; }
.rcard .art svg{ display:block; width:100%; height:100%; }
.rcard .num{ font-family:var(--font-mono); font-size:.72rem; color:var(--gold); }
.rcard h3{ font-size:1.28rem; margin:4px 0 2px; line-height:1.12; }
.rcard .meta{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-faint); margin:2px 0 9px; }
.rcard p{ font-size:.92rem; color:var(--ink-soft); margin:0 0 12px; line-height:1.5; }

/* ============================================================
   RECIPE DETAIL
   ============================================================ */
.rec-hero{ padding:54px 0 40px; border-bottom:1px solid var(--line); }
.crumb{ font-family:var(--font-sans); font-size:.8rem; color:var(--ink-faint); margin-bottom:22px; display:flex; gap:8px; align-items:center; }
.crumb a{ color:var(--ink-soft); text-decoration:none; }
.crumb a:hover{ color:var(--ink); }
.rec-hero h1{ font-size:clamp(2.1rem,4.4vw,3.4rem); margin:.18em 0 .12em; max-width:20ch; }
.rec-hero .sub{ font-family:var(--font-mono); color:var(--brand-2); font-size:1rem; margin-bottom:18px; }
.rec-hero .en{ font-style:italic; color:var(--ink-faint); }
.rec-hero-grid{ display:grid; grid-template-columns:1fr 150px; gap:30px; align-items:center; }
.rec-hero-grid .art{ color:var(--brand); }

.rec-body{ display:grid; grid-template-columns:1fr 340px; gap:48px; align-items:start; padding:52px 0 24px; }
.rec-main h2{ font-size:1.5rem; margin:0 0 14px; }
.rec-main h2 + .sect-rule{ display:none; }
.block{ margin-bottom:40px; }
.block > .eyebrow{ display:block; margin-bottom:14px; }
.prose p{ margin:0 0 1em; }
.prose p:last-child{ margin-bottom:0; }

/* original-source manuscript block */
.source-block{
  background:var(--paper-3); border:1px solid var(--line-gold); border-radius:var(--r);
  padding:26px 28px; position:relative;
}
.source-block .orig{
  font-family:var(--font-display); font-style:italic; font-size:1.2rem; line-height:1.5; color:var(--brand);
}
.source-block .orig::first-letter{ font-size:2.1em; line-height:.8; float:left; padding:6px 10px 0 0; color:var(--madder); font-style:normal; }
.source-block .trans{ font-style:italic; color:var(--ink-soft); margin-top:14px; }
.source-block .cite{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-faint); margin-top:16px; padding-top:14px; border-top:1px solid var(--line); letter-spacing:-.01em; }

/* the recipe sheet (ingredients + method) */
.sheet{ background:var(--paper-2); border:1px solid var(--line-2); border-radius:var(--r); overflow:hidden; }
.sheet-head{ padding:18px 26px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; gap:14px; }
.sheet-head .t{ font-family:var(--font-sans); font-size:.78rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--brand-2); }
.sheet-head .y{ font-family:var(--font-mono); font-size:.78rem; color:var(--ink-faint); }
.sheet-cols{ display:grid; grid-template-columns:1fr 1.2fr; }
.sheet-ing{ padding:22px 26px; border-right:1px solid var(--line); }
.sheet-met{ padding:22px 26px; }
.sheet h4{ font-family:var(--font-sans); font-size:.72rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 14px; }
ul.ing{ list-style:none; margin:0; padding:0; }
ul.ing li{ display:flex; gap:12px; padding:7px 0; border-bottom:1px dashed var(--line); font-size:.98rem; align-items:baseline; }
ul.ing li:last-child{ border-bottom:0; }
ul.ing li .amt{ font-family:var(--font-mono); font-size:.82rem; color:var(--brand-2); flex:0 0 auto; min-width:62px; }
ol.met{ margin:0; padding-left:1.2em; }
ol.met li{ padding:5px 0 5px 4px; font-size:.97rem; line-height:1.5; }
ol.met li::marker{ font-family:var(--font-mono); font-size:.82rem; color:var(--gold); }
.usefor{ font-family:var(--font-sans); font-size:.95rem; color:var(--ink-soft); }
.usefor b{ color:var(--ink); font-weight:600; }

/* sidebar */
.rec-side{ position:sticky; top:84px; display:flex; flex-direction:column; gap:16px; }
.side-card{ border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; background:var(--paper-2); }
.side-card .eyebrow{ display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.side-card.research{ background:var(--paper-3); }
.side-card.research .eyebrow{ color:var(--brand-2); }
.side-card.research p{ font-family:var(--font-sans); font-size:.9rem; line-height:1.55; color:var(--ink-soft); margin:0; }
.side-card.safety{ border-color:rgba(151,57,44,.4); background:rgba(151,57,44,.05); }
.side-card.safety .eyebrow{ color:var(--madder); }
.side-card.safety p{ font-family:var(--font-sans); font-size:.9rem; line-height:1.55; color:#6e2c22; margin:0; }
.side-card.safety.override{ border-width:1.5px; box-shadow:0 0 0 3px rgba(151,57,44,.07); }
.side-card.source p{ font-family:var(--font-mono); font-size:.8rem; line-height:1.6; color:var(--ink-soft); margin:0; }
.kv{ display:flex; flex-direction:column; gap:9px; }
.kv .row{ display:flex; justify-content:space-between; gap:14px; font-family:var(--font-mono); font-size:.78rem; }
.kv .row .k{ color:var(--ink-faint); } .kv .row .v{ color:var(--ink); text-align:right; }

/* prev / next */
.pager{ display:flex; justify-content:space-between; gap:14px; padding:30px 0 70px; border-top:1px solid var(--line); }
.pager a{ text-decoration:none; color:inherit; font-family:var(--font-sans); font-size:.9rem; display:flex; flex-direction:column; gap:3px; max-width:46%; }
.pager a .l{ font-size:.74rem; color:var(--ink-faint); letter-spacing:.08em; text-transform:uppercase; }
.pager a .t{ font-family:var(--font-display); font-size:1.1rem; }
.pager a.next{ text-align:right; margin-left:auto; }
.pager a:hover .t{ color:var(--brand); }

/* ---- expanded reading: plate, deep-dive, further reading ---- */
.plate{ margin:0 0 32px; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--paper-3); }
.plate .frame{ aspect-ratio:3/2; background:var(--paper-2); display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--line); }
.plate .frame img{ width:100%; height:100%; object-fit:cover; }
.plate .frame .ph{ color:var(--brand); width:120px; opacity:.5; }
.plate figcaption{ padding:12px 18px; font-family:var(--font-sans); font-size:.78rem; color:var(--ink-faint); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.plate figcaption .cap{ color:var(--ink-soft); }
.plate figcaption .credit{ font-family:var(--font-mono); }
.deepdive{ border:1px solid var(--line-gold); border-radius:var(--r); background:var(--paper-3); margin:0 0 40px; overflow:hidden; }
.deepdive > summary{ cursor:pointer; list-style:none; padding:18px 24px; display:flex; align-items:center; gap:12px; font-family:var(--font-sans); font-weight:600; font-size:.92rem; color:var(--brand); }
.deepdive > summary::-webkit-details-marker{ display:none; }
.deepdive > summary .chev{ transition:transform .2s; margin-left:auto; }
.deepdive[open] > summary .chev{ transform:rotate(90deg); }
.deepdive > summary .lbl{ letter-spacing:.04em; }
.deepdive .dd-body{ padding:4px 26px 26px; border-top:1px solid var(--line); }
.deepdive .dd-body h4{ font-family:var(--font-display); font-weight:500; font-size:1.15rem; color:var(--ink); margin:24px 0 8px; }
.deepdive .dd-body p{ margin:0 0 1em; }
.deepdive .dd-body em{ font-style:italic; }
.further{ margin:0 0 36px; }
.further ul{ list-style:none; margin:0; padding:0; }
.further li{ border-bottom:1px solid var(--line); }
.further li:last-child{ border-bottom:0; }
.further a{ display:flex; align-items:baseline; gap:12px; padding:12px 2px; text-decoration:none; color:var(--ink); font-family:var(--font-sans); font-size:.95rem; transition:color .15s; }
.further a:hover{ color:var(--brand); }
.further a .src{ font-family:var(--font-mono); font-size:.72rem; color:var(--gold); flex:0 0 auto; min-width:64px; }
.further a .ext{ margin-left:auto; color:var(--ink-faint); flex:0 0 auto; }

/* ============================================================
   KODEX (rosenrot) + DATA pages share generic helpers
   ============================================================ */
.kx-hero{ padding:60px 0 40px; border-bottom:1px solid var(--line); }
.kx-hero h1{ font-size:clamp(2.4rem,5vw,4rem); }
.kx-grid{ display:grid; grid-template-columns:300px 1fr; gap:48px; align-items:start; padding:50px 0; }
.kx-main h2{ font-size:1.7rem; margin:46px 0 16px; padding-top:30px; border-top:1px solid var(--line); }
.kx-main h2:first-child{ border-top:0; padding-top:0; margin-top:0; }
.kx-main h3{ font-size:1.2rem; margin:26px 0 10px; color:var(--brand); }
.kx-main p{ margin:0 0 1em; }
.kx-side{ position:sticky; top:84px; display:flex; flex-direction:column; gap:16px; }
.factsheet{ border:1px solid var(--line-gold); border-radius:var(--r); background:var(--paper-3); padding:22px 24px; }
.factsheet .ttl{ font-family:var(--font-sans); font-size:.72rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.factsheet .kv .row{ padding:6px 0; border-bottom:1px dashed var(--line); }
.factsheet .kv .row:last-child{ border-bottom:0; }
.toc{ border:1px solid var(--line); border-radius:var(--r); padding:18px 22px; background:var(--paper-2); }
.toc a{ display:block; font-family:var(--font-sans); font-size:.86rem; color:var(--ink-soft); text-decoration:none; padding:5px 0; border-bottom:1px solid var(--line); }
.toc a:last-child{ border-bottom:0; } .toc a:hover{ color:var(--brand); }

table.data{ width:100%; border-collapse:collapse; font-family:var(--font-sans); font-size:.9rem; margin:8px 0 6px; }
table.data th{ text-align:left; font-weight:600; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); padding:10px 12px; border-bottom:1.5px solid var(--line-2); }
table.data td{ padding:10px 12px; border-bottom:1px solid var(--line); vertical-align:top; }
table.data td.n{ font-family:var(--font-mono); font-size:.85rem; text-align:right; white-space:nowrap; }
table.data tr.best td{ background:rgba(42,63,99,.05); }
table.data .tag{ font-family:var(--font-mono); font-size:.72rem; padding:1px 6px; border-radius:3px; }
.metric-row{ display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin:22px 0; }
.metric{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); padding:16px 14px; }
.metric .l{ font-family:var(--font-sans); font-size:.7rem; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-faint); }
.metric .v{ font-family:var(--font-display); font-size:1.7rem; color:var(--brand); margin-top:4px; }
.metric .v small{ font-size:.9rem; color:var(--ink-faint); }

.callout{ border-left:2px solid var(--gold); background:var(--paper-3); padding:16px 20px; margin:22px 0; font-size:.98rem; color:var(--ink-soft); border-radius:0 var(--r) var(--r) 0; }
.callout.warn{ border-color:var(--madder); background:rgba(151,57,44,.05); color:#6e2c22; }

/* ---------- footer ---------- */
.foot{ background:var(--brand); color:rgba(251,250,245,.82); padding:56px 0 30px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.foot h4{ font-family:var(--font-sans); font-size:.74rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-2); margin:0 0 14px; }
.foot a{ color:rgba(251,250,245,.82); text-decoration:none; font-family:var(--font-sans); font-size:.9rem; display:block; padding:4px 0; }
.foot a:hover{ color:#fff; }
.foot .brand .word{ color:var(--paper-3); }
.foot .brand .word .h3{ color:var(--madder-2); }
.foot p{ font-size:.92rem; color:rgba(251,250,245,.7); max-width:36ch; }
.foot .disc{ font-family:var(--font-sans); font-size:.78rem; line-height:1.55; color:rgba(251,250,245,.6); border-top:1px solid rgba(251,250,245,.16); margin-top:36px; padding-top:22px; }

/* ---------- misc ---------- */
.center{ text-align:center; }
.mt-l{ margin-top:40px; }
:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:2px; }
.reveal{ opacity:0; transform:translateY(14px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-grid,.rec-body,.kx-grid,.rec-hero-grid{ grid-template-columns:1fr; }
  .hero-art,.rec-hero-grid .art{ display:none; }
  .pillars,.cat-grid{ grid-template-columns:1fr; }
  .feature-grid,.split,.recipe-grid{ grid-template-columns:1fr; }
  .sheet-cols{ grid-template-columns:1fr; }
  .sheet-ing{ border-right:0; border-bottom:1px solid var(--line); }
  .rec-side,.kx-side{ position:static; }
  .metric-row{ grid-template-columns:1fr 1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{ display:none; position:absolute; top:62px; left:0; right:0; flex-direction:column; gap:0;
    background:var(--paper-2); border-bottom:1px solid var(--line); padding:8px 28px 16px; }
  .nav-links.open{ display:flex; }
  .nav-links a{ padding:11px 0; border-bottom:1px solid var(--line); }
  .nav-burger{ display:block; }
  .nav-search{ align-self:flex-start; padding:11px 0; }
  .lang-switch{ margin:10px 0 0; padding:10px 0 0; border-left:0; border-top:1px solid var(--line); width:100%; }
  .kx-grid{ gap:24px; }
  .search-controls #q,.search-controls select{ flex:1 1 100%; }
}
@media (max-width:560px){
  body{ font-size:17px; }
  .wrap{ padding:0 18px; }
  .metric-row{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; scroll-behavior:auto!important; }
  .reveal{ opacity:1; transform:none; }
}
