/* ============================================================
   Living Library — NEUTRAL placeholder styling.
   Function over aesthetics. Bright / high-key only.
   design-claude owns the bespoke visual identity later — do not
   treat anything here as the brand. No dark/moody surfaces.
   ============================================================ */

@import url('/assets/tokens.css');

:root {
  /* RE-SKINNED into the locked "look of listening" identity (was a neutral
     placeholder). tokens.css now owns the palette — warm paper, ink, sage,
     hairline line, Fraunces/Inter. The two lines below map the library's older
     semantic names (--accent…) onto that palette so existing markup inherits it
     with no per-page edits. --focus comes from tokens.css. */
  --accent: var(--sage-deep);
  --accent-soft: var(--sage-wash);

  /* recipe groups — color-coded, all bright/high-key.
     sage (greens) · honey/clay (roots & citrus) · sky (gentle / re-entry) */
  --sage-bg:  #ecf5ec;  --sage-fg:  #2f6b46;  --sage-line:  #c4e2c8;
  --honey-bg: #fbf1da;  --honey-fg: #97651a;  --honey-line: #efd9a4;
  --sky-bg:   #e9f3fb;  --sky-fg:   #2a6395;  --sky-line:   #c2ddf0;

  /* evidence tiers — distinguishable by hue AND label (not color alone) */
  --strong-bg: #e3f1e4;  --strong-fg: #1f5d2c;  --strong-line: #b6dcb9;
  --moderate-bg: #fdf3da; --moderate-fg: #8a6400; --moderate-line: #ecd79a;
  --spec-bg: #f3edf8;    --spec-fg: #5e3c87;    --spec-line: #d9c8ec;
  --debunk-bg: #fbe6e3;  --debunk-fg: #9a3528;  --debunk-line: #f0c2ba;
  --nuance-bg: #eef0f2;  --nuance-fg: #45525e;  --nuance-line: #d3d9de;

  --maxw: 44rem;
  --radius: 10px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.62;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}

.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 1.5rem 1.25rem 4rem;
}

a { color: var(--accent); text-underline-offset: 2px; }
a:focus-visible, button:focus-visible, input:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}

h1 { font-size: 1.7rem; line-height: 1.25; margin: 0 0 .5rem; }
h2 { font-size: 1.25rem; margin: 2rem 0 .6rem; }
h3 { font-size: 1.05rem; margin: 1.4rem 0 .4rem; color: var(--ink); }

p { margin: .7rem 0; }

.muted { color: var(--ink-soft); }
.small { font-size: .9rem; }

/* ---- site header / footer ---- */
.site-head {
  border-bottom: 1px solid var(--line);
  background: var(--paper);
}
.site-head .wrap { padding-top: 1rem; padding-bottom: 1rem; }
.site-head .wrap { display:flex; align-items:baseline; gap:.5rem 1.1rem; flex-wrap:wrap; }
.site-head a.home { font-family: var(--serif); font-weight: 400; font-size: 1.18rem; text-decoration: none; color: var(--ink); }
.site-head a.home:hover { color: var(--sage-deep); }
.site-head .to-front { margin-left:auto; font-size:.82rem; font-weight:600; letter-spacing:.02em; text-decoration:none; color:var(--ink-soft); }
.site-head .to-front:hover { color: var(--sage-deep); }
.kicker {
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .72rem;
  color: var(--sage-deep);
  font-weight: 600;
}
.site-foot {
  border-top: 1px solid var(--line);
  margin-top: 3rem;
  color: var(--ink-soft);
  font-size: .85rem;
}
.site-foot .wrap { padding-top: 1.5rem; padding-bottom: 2.5rem; }

/* ---- cards / lists ---- */
.card {
  display: block;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1rem 1.1rem;
  margin: .85rem 0;
  text-decoration: none;
  color: inherit;
  background: var(--paper);
  transition: border-color .12s ease, transform .12s ease;
}
.card:hover { border-color: var(--accent); }
.card h3 { margin: 0 0 .25rem; }
.card .meta { color: var(--ink-soft); font-size: .9rem; }

.pill {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  padding: .12rem .5rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--paper-2);
  color: var(--ink-soft);
}

/* ---- buttons ---- */
.btn {
  display: inline-block;
  font: inherit;
  font-weight: 600;
  padding: .8rem 1.4rem;
  border-radius: var(--radius);
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
}
.btn:hover { filter: brightness(1.05); }
.btn.secondary { background: var(--paper); color: var(--accent); }
.btn.ghost { background: transparent; border-color: var(--line); color: var(--ink); }
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn-row { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1rem; }

.notice {
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .9rem 1.1rem;
  font-size: .92rem;
}

/* ============================================================
   EVIDENCE TIER BADGES (Research Library)
   ============================================================ */
.tier {
  display: inline-block;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .12rem .45rem;
  border-radius: 5px;
  vertical-align: middle;
  white-space: nowrap;
  border: 1px solid transparent;
}
.tier-strong    { background: var(--strong-bg);   color: var(--strong-fg);   border-color: var(--strong-line); }
.tier-moderate  { background: var(--moderate-bg); color: var(--moderate-fg); border-color: var(--moderate-line); }
.tier-speculative { background: var(--spec-bg);   color: var(--spec-fg);     border-color: var(--spec-line); }
.tier-debunk    { background: var(--debunk-bg);   color: var(--debunk-fg);   border-color: var(--debunk-line); }
.tier-nuance    { background: var(--nuance-bg);   color: var(--nuance-fg);   border-color: var(--nuance-line); }

/* legend on research index + each article */
.tier-legend {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .9rem;
  align-items: center;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .8rem 1rem;
  margin: 1rem 0 1.5rem;
  font-size: .85rem;
}
.tier-legend .item { display: flex; gap: .35rem; align-items: center; }

/* research article body */
.article-body { }
.article-body ul { padding-left: 1.25rem; }
.article-body li { margin: .45rem 0; }
.article-body blockquote {
  margin: 1rem 0;
  padding: .6rem 1rem;
  border-left: 3px solid var(--line);
  color: var(--ink-soft);
  background: var(--paper-2);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.article-body code {
  background: var(--paper-2);
  padding: .05em .35em;
  border-radius: 4px;
  font-size: .85em;
}
.article-body a { word-break: break-word; }

/* ============================================================
   ASSESSMENT FLOW (The Four Questions)
   ============================================================ */
.assess { max-width: 38rem; }
.assess .screen { display: none; }
.assess .screen.active { display: block; animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.assess .q {
  font-size: 1.18rem;
  line-height: 1.4;
  margin: .25rem 0 1rem;
}
.assess .sub { color: var(--ink-soft); font-size: .95rem; margin-bottom: 1.25rem; }
.assess .nudge { color: var(--ink-soft); font-size: .9rem; font-style: italic; margin-top: .75rem; }

/* self-placement: radio chips — NOT a scale, no numbers */
.choices { display: flex; flex-direction: column; gap: .6rem; margin: 1rem 0; }
.choice {
  display: flex; align-items: center; gap: .7rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .85rem 1rem;
  cursor: pointer;
  background: var(--paper);
}
.choice:hover { border-color: var(--accent); }
.choice input { width: 1.1rem; height: 1.1rem; accent-color: var(--accent); flex: none; }
.choice.checked { border-color: var(--accent); background: var(--accent-soft); }
.choice span { font-size: 1.02rem; }

.assess textarea {
  width: 100%;
  min-height: 4.5rem;
  font: inherit;
  padding: .7rem .85rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  resize: vertical;
  background: var(--paper);
  color: var(--ink);
}
.assess label.field { display: block; font-style: italic; color: var(--ink-soft); margin: 1rem 0 .4rem; }

/* progress: position-in-flow ONLY — explicitly NOT a score.
   plain dots, no fill-as-grade, no percentage, no number. */
.dots { display: flex; gap: .4rem; margin: 0 0 1.25rem; }
.dots .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--line); }
.dots .dot.here { background: var(--accent); }

/* reflection screen (screen 6) — echoes their own answers, no totals */
.echo { list-style: none; padding: 0; margin: 1rem 0; }
.echo li {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .7rem .9rem;
  margin: .55rem 0;
  background: var(--paper-2);
}
.echo .label { font-weight: 600; }
.echo .mark { color: var(--accent); }
.echo .note { display: block; color: var(--ink-soft); font-style: italic; margin-top: .25rem; }

.big-line {
  font-size: 1.15rem;
  line-height: 1.45;
  margin: 1.5rem 0;
  padding-left: 1rem;
  border-left: 3px solid var(--accent);
}
.end-question {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 1.5rem 0;
}

@media (min-width: 40rem) {
  body { font-size: 18px; }
  h1 { font-size: 2rem; }
}

/* ============================================================
   RECIPE LIBRARY (/recipes) — 3 color-coded tabs, mobile-first
   sage (greens) · honey/clay (roots & citrus) · sky (gentle)
   THE ONE LAW: nothing here scores or ranks.
   ============================================================ */

.r-honest { margin: 1.1rem 0 1.4rem; }

/* longer-fast toggle */
.r-toggle {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .8rem 1rem;
  margin: 0 0 1.4rem;
  cursor: pointer;
  background: var(--paper-2);
  font-size: .95rem;
}
.r-toggle input { width: 1.15rem; height: 1.15rem; margin-top: .15rem; accent-color: var(--sky-fg); flex: none; }

/* tab bar — horizontally scrollable on tiny screens, no wrap-jank */
.r-tabs {
  display: flex;
  gap: .5rem;
  margin: 0 0 1.25rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: .25rem;
}
.r-tab {
  font: inherit;
  font-weight: 700;
  font-size: .92rem;
  white-space: nowrap;
  padding: .6rem 1rem;
  border-radius: 999px;
  border: 1.5px solid var(--line);
  background: var(--paper);
  color: var(--ink-soft);
  cursor: pointer;
  flex: none;
}
.r-tab:hover { filter: brightness(.99); }
/* per-group active colors */
.r-tab-greens.active { background: var(--sage-bg);  color: var(--sage-fg);  border-color: var(--sage-line); }
.r-tab-roots.active  { background: var(--honey-bg); color: var(--honey-fg); border-color: var(--honey-line); }
.r-tab-gentle.active { background: var(--sky-bg);   color: var(--sky-fg);   border-color: var(--sky-line); }

.r-group-blurb {
  font-size: .98rem;
  margin: 0 0 1rem;
  padding-left: .75rem;
  border-left: 3px solid var(--line);
  color: var(--ink-soft);
}
.r-blurb-greens { border-left-color: var(--sage-line); }
.r-blurb-roots  { border-left-color: var(--honey-line); }
.r-blurb-gentle { border-left-color: var(--sky-line); }

.r-dilute { margin: 0 0 1.25rem; }

/* card grid — single column on mobile, two-up on wider screens */
.r-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }

.r-card {
  border: 1px solid var(--line);
  border-left-width: 5px;
  border-radius: var(--radius);
  padding: 1.1rem 1.15rem 1.2rem;
  background: var(--paper);
}
/* color-coded left rail + tinted name per group */
.r-card.r-greens { border-left-color: var(--sage-fg); }
.r-card.r-roots  { border-left-color: var(--honey-fg); }
.r-card.r-gentle { border-left-color: var(--sky-fg); }

.r-card-head { display: flex; align-items: baseline; justify-content: space-between; gap: .6rem; flex-wrap: wrap; }
.r-card h3 { margin: 0; font-size: 1.12rem; }
.r-card.r-greens h3 { color: var(--sage-fg); }
.r-card.r-roots  h3 { color: var(--honey-fg); }
.r-card.r-gentle h3 { color: var(--sky-fg); }

.r-tag {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .15rem .5rem;
  border-radius: 999px;
  background: var(--sky-bg);
  color: var(--sky-fg);
  border: 1px solid var(--sky-line);
  white-space: nowrap;
}

.r-when { font-style: italic; color: var(--ink-soft); margin: .35rem 0 .8rem; }

.r-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: .6rem 0 .3rem;
}

.r-ing { list-style: none; padding: 0; margin: 0 0 .9rem; display: flex; flex-wrap: wrap; gap: .4rem; }
.r-ing li {
  font-size: .9rem;
  padding: .25rem .6rem;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: 999px;
}

/* tap-to-reveal method */
.r-reveal {
  font: inherit;
  font-weight: 600;
  font-size: .9rem;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem .9rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--ink);
  cursor: pointer;
}
.r-reveal::before { content: "▸"; font-size: .8em; transition: transform .12s ease; }
.r-reveal.open::before { transform: rotate(90deg); }
.r-reveal:hover { border-color: var(--ink-soft); }

.r-method { margin-top: .7rem; animation: fade .2s ease; }
.r-method p { margin: 0; }

.r-note {
  margin: 1rem 0 0;
  padding-top: .85rem;
  border-top: 1px dashed var(--line);
  font-size: .95rem;
  color: var(--ink);
}
.r-note-by {
  display: inline-block;
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-right: .35rem;
}

@media (min-width: 40rem) {
  .r-grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   BUY-MODE (the book is live — $19 e-book).
   Every Library page carries a quiet buy bar; the doorway pages
   carry a buy block at the end. Mirrors the front-door launchbar
   but self-contained in base.css tokens (these pages don't load
   site.css). Never the retired launch-list.
   ============================================================ */
.buy-block {
  border: 1px solid var(--line);
  border-left: 4px solid var(--clay);
  border-radius: var(--radius);
  background: var(--paper-2);
  padding: 1.2rem 1.25rem 1.3rem;
  margin: 2.6rem 0 1rem;
}
.buy-block h3 { margin: 0 0 .3rem; }
.buy-block p { margin: .3rem 0 .9rem; color: var(--ink-soft); font-size: .95rem; }

.libbar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  transform: translateY(115%); transition: transform .3s ease;
  background: var(--paper); border-top: 1px solid var(--line);
  box-shadow: 0 -6px 20px rgba(0,0,0,.06);
}
.libbar.up { transform: translateY(0); }
.libbar-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 10px clamp(16px,4vw,32px);
  display: flex; align-items: center; gap: .7rem 1rem; flex-wrap: wrap;
}
.libbar-msg { font-size: .95rem; margin: 0; flex: 1 1 220px; line-height: 1.4; color: var(--ink); }
.libbar-msg b { color: var(--sage-deep); }
.libbar .btn { padding: .55rem 1.05rem; font-size: .9rem; white-space: nowrap; }
.libbar-x { background: none; border: none; font-size: 21px; line-height: 1; color: var(--ink-soft); cursor: pointer; padding: 2px 6px; border-radius: 8px; }
.libbar-x:hover { color: var(--ink); }

/* ---- video embeds on Library pages ---- */
.lib-video {
  width: 100%; border-radius: var(--radius); border: 1px solid var(--line);
  background: #000; display: block; margin: 1.3rem 0; aspect-ratio: 16 / 9;
}
.video-soon {
  border: 1px dashed var(--line); border-radius: var(--radius);
  background: var(--paper-2); padding: 1.4rem 1.25rem; margin: 1.3rem 0;
  color: var(--ink-soft); font-size: .95rem;
}
.video-soon strong { color: var(--ink); }

/* ---- printable worksheet (the "download", generated in-page) ---- */
.worksheet {
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--paper); padding: 1.4rem 1.4rem 1.6rem; margin: 1.3rem 0;
}
.worksheet > h3:first-child { margin-top: 0; }
.ws-prompt { font-weight: 600; margin: 1.1rem 0 .2rem; }
.ws-sub { color: var(--ink-soft); font-size: .92rem; font-style: italic; margin: .1rem 0 .5rem; }
.ws-line { border-bottom: 1px solid var(--line); height: 1.95rem; }
.ws-box { border: 1px solid var(--line); border-radius: var(--radius); min-height: 4.6rem; padding: .6rem .8rem; margin: .4rem 0 1rem; }
.ws-list { margin: .3rem 0 1rem; padding-left: 1.2rem; }
.ws-list li { margin: .5rem 0; }

@media print {
  .site-head, .site-foot, .libbar, .buy-block, .no-print, .dots { display: none !important; }
  body { font-size: 11.5pt; background: #fff; color: #000; }
  .wrap { max-width: 100%; padding: 0 .2in; }
  .worksheet { border: none; padding: 0; margin: 0; }
  .lib-video, .video-soon { display: none !important; }
  a { color: #000; text-decoration: none; }
  .assess .screen { display: block !important; } /* print all reflection prompts */
}
