/* ============================================================
   NARRATIVE TRACKER — editorial / newsroom system
   ============================================================ */
:root{
  --paper:#f3ede2;        /* page background  */
  --card:#faf6ee;         /* card surface     */
  --card-edge:#e4dccc;
  --ink:#1d1a15;          /* near-black warm  */
  --ink-soft:#4a443a;
  --muted:#867c6c;
  --faint:#a89e8d;
  --hair:#e0d8c8;
  --hair-strong:#d2c8b5;
  --blue:#2f5d80;         /* structural accent (origin / UI) */
  --shadow:0 1px 0 rgba(40,32,18,.04), 0 22px 44px -28px rgba(40,32,18,.30);
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}

*{box-sizing:border-box;}
html,body{margin:0;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
.wrap{max-width:1560px; margin:0 auto; padding:0 40px 96px;}

/* ---------- topic header ---------- */
.topbar{ padding:36px 0 22px; }
.kicker{
  font-family:var(--mono);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--blue); font-weight:600;
  display:flex; align-items:center; gap:12px;
}
.kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--blue);}
.topbar .toprow{ display:flex; align-items:flex-end; gap:26px; margin-top:14px; flex-wrap:wrap; }
.topbar .topic{
  font-family:var(--serif); font-weight:600; font-size:58px; line-height:.96;
  letter-spacing:-.022em; margin:0; white-space:nowrap;
}
.topbar .topmeta{ display:flex; align-items:center; gap:16px; padding-bottom:9px; }
.topbar .topmeta span{ font-family:var(--mono); font-size:13px; color:var(--muted); letter-spacing:.02em; }
.topbar .topmeta b{ color:var(--ink); font-weight:600; }
.topbar .topmeta i{ width:1px; height:13px; background:var(--hair-strong); }
.topbar .topic-sub{
  font-family:var(--serif); font-size:19px; color:var(--ink-soft);
  margin:14px 0 0; max-width:760px; line-height:1.4;
}

/* ---------- brand bar (Plotline) ---------- */
.brandbar{
  display:flex; align-items:center; gap:26px;
  padding:22px 0 18px; border-bottom:1px solid var(--hair-strong);
}
.brand{ display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink); flex:none; }
.logo-mark{ color:var(--ink); display:block; }
.logo-mark svg{ display:block; width:30px; height:26px; }
.logo-word{ font-family:var(--serif); font-weight:600; font-size:25px; letter-spacing:-.02em; line-height:1; }
.logo-tld{ font-family:var(--mono); font-weight:500; font-size:13px; color:var(--muted); letter-spacing:0; margin-left:1px; }
.brand-nav{ margin-left:auto; display:flex; gap:22px; }
.brand-nav a{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); text-decoration:none; transition:color .14s; }
.brand-nav a:hover{ color:var(--ink); }
.brand-tag{ margin-left:auto; font-family:var(--mono); font-size:11px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted); }

/* ---------- "tracking" pill (current story) ---------- */
.switch{ position:relative; }
.switch-btn{
  background:var(--card); border:1px solid var(--hair-strong); border-radius:999px;
  padding:7px 15px 7px 16px; display:flex; align-items:center; gap:10px; cursor:default;
}
.switch-cap{ font-family:var(--mono); font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); }
.switch-topic{ font-family:var(--serif); font-weight:600; font-size:16px; letter-spacing:-.01em; color:var(--ink); }

/* ---------- home: hero + story index ---------- */
.hero{ padding:60px 0 50px; border-bottom:1px solid var(--hair); margin-bottom:38px; }
.hero-h1{ font-family:var(--serif); font-weight:600; font-size:72px; line-height:.98;
  letter-spacing:-.025em; margin:18px 0 0; max-width:13ch; }
.hero-sub{ font-family:var(--serif); font-size:20px; line-height:1.5; color:var(--ink-soft);
  max-width:680px; margin:22px 0 0; }
.index-head{ display:flex; align-items:baseline; gap:14px; margin-bottom:22px; }
.ih-title{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink); }
.ih-count{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--faint); }
.story-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(360px, 1fr)); gap:18px; }
.story-card{
  display:flex; flex-direction:column; text-decoration:none; color:var(--ink);
  background:var(--card); border:1px solid var(--card-edge); border-radius:4px;
  padding:24px 24px 20px; box-shadow:0 1px 0 rgba(40,32,18,.03);
  transition:box-shadow .16s, border-color .16s, transform .16s;
}
.story-card:hover{ border-color:var(--hair-strong); transform:translateY(-2px);
  box-shadow:0 20px 40px -26px rgba(40,32,18,.4); }
.sc-top{ display:flex; align-items:center; justify-content:space-between; }
.sc-cat{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); }
.sc-go{ font-family:var(--mono); font-size:15px; color:var(--faint); transition:color .16s, transform .16s; }
.story-card:hover .sc-go{ color:var(--ink); transform:translateX(3px); }
.sc-topic{ font-family:var(--serif); font-weight:600; font-size:30px; letter-spacing:-.015em;
  line-height:1.04; margin:12px 0 0; }
.sc-dek{ font-size:14px; color:var(--ink-soft); line-height:1.5; margin:10px 0 0; text-wrap:pretty; }
.sc-drift{ display:flex; align-items:center; gap:14px; margin:20px 0 0;
  padding:14px 0 0; border-top:1px solid var(--hair); }
.sc-svg{ width:150px; height:46px; flex:none; }
.sc-arc-txt{ display:flex; flex-direction:column; gap:5px; }
.sc-arc-label{ font-family:var(--serif); font-style:italic; font-size:14.5px; color:var(--ink); line-height:1.22; }
.sc-arc-cap{ font-family:var(--mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.sc-facts{ display:flex; gap:18px; margin-top:18px; padding-top:14px; border-top:1px solid var(--hair); }
.sc-facts span{ font-family:var(--mono); font-size:11.5px; color:var(--muted); }
.sc-facts b{ color:var(--ink); font-weight:600; }

/* discovery watchlist (auto-promoted topic, page still building) */
.story-card.building{ cursor:default; background:repeating-linear-gradient(
    -45deg, var(--card), var(--card) 11px, rgba(132,124,108,.045) 11px, rgba(132,124,108,.045) 22px); }
.story-card.building:hover{ transform:none; box-shadow:0 1px 0 rgba(40,32,18,.03); border-color:var(--card-edge); }
.story-card.building .sc-topic{ color:var(--ink-soft); }
.sc-badge{ font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); border:1px solid var(--hair-strong); border-radius:999px; padding:3px 9px; }
.sc-build{ display:flex; align-items:center; gap:9px; margin:20px 0 0; padding:14px 0 0;
  border-top:1px solid var(--hair); font-size:13px; color:var(--muted); line-height:1.45; }
.sc-build-dot{ width:8px; height:8px; border-radius:50%; flex:none; background:var(--blue);
  box-shadow:0 0 0 0 rgba(47,93,128,.5); animation:scPulse 1.8s ease-out infinite; }
@keyframes scPulse{ 0%{ box-shadow:0 0 0 0 rgba(47,93,128,.45); } 70%{ box-shadow:0 0 0 7px rgba(47,93,128,0); } 100%{ box-shadow:0 0 0 0 rgba(47,93,128,0); } }

/* ---------- tabs ---------- */
.tabs{
  display:flex; align-items:flex-end; gap:4px;
  border-bottom:2px solid var(--ink);
}
.tab{
  appearance:none; -webkit-appearance:none; background:none; border:none;
  display:flex; align-items:center; gap:12px;
  padding:12px 22px 14px; cursor:pointer; position:relative;
  transition:background .15s;
}
.tab:first-child{ padding-left:6px; }
.tab + .tab{ border-left:1px solid var(--hair); }
.tab-ico{ color:var(--faint); flex:none; transition:color .15s, transform .15s; }
.tab-ico svg{ display:block; width:38px; height:24px; }
.tab-ico circle{ fill:currentColor; }
.tab-txt{ display:flex; flex-direction:column; align-items:flex-start; line-height:1.05; }
.tab-name{
  font-family:var(--serif); font-weight:600; font-size:23px; letter-spacing:-.012em;
  color:var(--muted); transition:color .15s;
}
.tab-sub{
  font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--faint); margin-top:4px; transition:color .15s;
}
.tab:hover .tab-name{ color:var(--ink-soft); }
.tab:hover .tab-ico{ color:var(--muted); }
.tab.active .tab-name{ color:var(--ink); }
.tab.active .tab-sub{ color:var(--blue); }
.tab.active .tab-ico{ color:var(--blue); }
.tab.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:3px; background:var(--blue);
}
.tab-desc{
  margin-left:auto; align-self:center; max-width:430px; text-align:right;
  font-size:13px; color:var(--muted); line-height:18px; margin-bottom:8px;
  /* fixed footprint (exactly 3 lines) so switching tabs never reflows the row;
     full text is exposed via the title tooltip when it overflows */
  height:54px; overflow:hidden;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
}
.tab-desc b{ color:var(--ink-soft); font-weight:600; }

/* ---------- stage (graph front & center) ---------- */
.stage{
  background:var(--card);
  border:1px solid var(--card-edge); border-top:none;
  border-radius:0 0 4px 4px;
  box-shadow:var(--shadow);
  padding:30px 26px 18px;
  min-height:540px;
}
.panel{ display:none; width:100%; }
.panel.active{ display:block; }
.viz-body{ position:relative; }
.viz-head{ display:flex; justify-content:flex-end; align-items:center; padding:10px 6px 4px; }
.viz-plot{ position:relative; }
.viz svg, .panel svg{ display:block; width:100%; height:auto; }

/* ---------- key (bottom) ---------- */
.keybar{
  display:flex; align-items:flex-start; justify-content:space-between; gap:36px;
  margin-top:24px; padding-top:20px; border-top:1px solid var(--hair);
}
.keybar .keys{ display:flex; align-items:flex-start; gap:38px; flex-wrap:wrap; }
.keybar .grp{ display:flex; flex-direction:column; }
.keybar .grp .t{ font-family:var(--mono); font-size:10px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.keybar .scale{ display:flex; gap:0; }
.keybar .scale .seg{ width:30px; height:11px; }
.keybar .scale-labels{ display:flex; justify-content:space-between; font-family:var(--mono);
  font-size:10px; color:var(--muted); letter-spacing:.04em; margin-top:5px; }
.keybar .sz{ display:flex; align-items:center; gap:9px; }
.keybar .sz .d{ border-radius:50%; background:var(--faint); }
.keybar .sz-cap{ font-size:12px; color:var(--muted); }
.keybar .mk-o{ font-family:var(--mono); font-size:11.5px; color:var(--blue); }
.keybar .mk-r{ font-family:var(--mono); font-size:11.5px; color:rgb(178,58,46); }
.keybar .mk-a{ font-family:var(--mono); font-size:11.5px; color:var(--muted); }
.keybar .mk-s{ font-family:var(--mono); font-size:11.5px; color:var(--muted); }
.key-hint{
  font-family:var(--mono); font-size:11.5px; color:var(--blue);
  letter-spacing:.02em; margin:2px 0 0; text-align:right; max-width:380px; line-height:1.5;
}

/* ---------- thread legend (Drift) ---------- */
.threadbar{
  display:flex; align-items:center; gap:16px 18px; padding:0 2px 20px; flex-wrap:wrap;
  border-bottom:1px solid var(--hair); margin-bottom:8px;
}
.tb-label{ font-family:var(--mono); font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted); line-height:1.35; flex:none; }
.tb-chips{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{
  appearance:none; -webkit-appearance:none; background:var(--paper);
  border:1px solid var(--hair-strong); border-radius:999px;
  padding:6px 13px 6px 11px; font-family:var(--sans); font-size:13px; color:var(--ink-soft);
  cursor:pointer; display:inline-flex; align-items:center; gap:8px; transition:all .14s;
}
.chip:hover{ border-color:var(--muted); color:var(--ink); }
.chip.on{ background:var(--ink); color:#f6efe2; border-color:var(--ink); }
.chip-dot{ width:10px; height:10px; border-radius:50%; flex:none; }
.chip-n{ font-family:var(--mono); font-size:10px; color:var(--muted); }
.chip.on .chip-n{ color:#bcae97; }
.tb-caption{ flex-basis:100%; font-size:12.5px; color:var(--muted); line-height:1.45; }

/* axis + svg text */
.ax-line{stroke:var(--hair-strong); stroke-width:1;}
.ax-grid{stroke:var(--hair); stroke-width:1; stroke-dasharray:2 4;}
.ax-tick{font-family:var(--mono); font-size:11px; fill:var(--muted);}
.ax-title{font-family:var(--mono); font-size:10px; fill:var(--muted);
  letter-spacing:.16em; text-transform:uppercase;}
.node-label{font-family:var(--sans); font-size:12px; fill:var(--ink); font-weight:500;}
.node-kind{font-family:var(--mono); font-size:9.5px; fill:var(--muted); letter-spacing:.04em;}
.flag{font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;}
/* Influence — lineage tree */
.net-title{font-family:var(--mono); font-size:11px; letter-spacing:.14em; fill:var(--muted);}
.net-col{font-family:var(--mono); font-size:10px; letter-spacing:.16em; fill:var(--muted); text-anchor:middle;}
.net-name{font-family:var(--sans); font-size:12px; font-weight:600; fill:var(--ink); paint-order:stroke; stroke:var(--card); stroke-width:3px; stroke-linejoin:round;}
.net-sub{font-family:var(--sans); font-size:10px; font-weight:500; fill:var(--muted); letter-spacing:.01em; paint-order:stroke; stroke:var(--card); stroke-width:3px; stroke-linejoin:round;}
.node-by{font-family:var(--mono); font-size:9.5px; font-weight:500; fill:#a9881f; letter-spacing:.02em; paint-order:stroke; stroke:var(--card); stroke-width:3px; stroke-linejoin:round;}
.lane-label{font-family:var(--sans); font-size:13px; fill:var(--ink); font-weight:600;}
.lane-sub{font-family:var(--mono); font-size:9.5px; fill:var(--muted); letter-spacing:.02em;}
circle.sel{stroke:var(--ink); stroke-width:3;}

/* Influence — tier filter bar + node bundling */
.netbar{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; padding:0 2px 18px; margin-bottom:6px; border-bottom:1px solid var(--hair); }
.nb-label{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); flex:none; }
.nb-chips{ display:flex; gap:7px; flex-wrap:wrap; }
.nb-chip{ appearance:none; -webkit-appearance:none; cursor:pointer; background:var(--paper); border:1px solid var(--hair-strong); border-radius:999px; padding:5px 12px; font-family:var(--sans); font-size:12px; color:var(--muted); transition:all .13s; }
.nb-chip:hover{ color:var(--ink); border-color:var(--muted); }
.nb-chip.on{ background:var(--ink); color:#f6efe2; border-color:var(--ink); }
.nb-all{ appearance:none; -webkit-appearance:none; cursor:pointer; background:none; border:none; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); margin-left:auto; }
.nb-all:hover{ text-decoration:underline; }
.bundle{ cursor:pointer; }
.bundle-collapse{ cursor:pointer; }
.bundle-collapse text:hover{ fill:var(--ink); }

/* ---------- drill-down controls ---------- */
.nt-btn{
  appearance:none; -webkit-appearance:none; cursor:pointer;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em;
  padding:7px 14px; border-radius:999px; transition:all .14s;
  background:var(--paper); border:1px solid var(--hair-strong); color:var(--ink-soft);
}
.nt-btn:hover{ border-color:var(--muted); color:var(--ink); }
.nt-btn.primary{ background:var(--ink); color:#f6efe2; border-color:var(--ink); }
.nt-btn.primary:hover{ background:#000; }

/* arc / lanes segmented toggle */
.nt-seg{ display:inline-flex; border:1px solid var(--hair-strong); border-radius:999px;
  overflow:hidden; background:var(--paper); flex:none; }
.nt-segbtn{
  appearance:none; -webkit-appearance:none; cursor:pointer; border:0; background:transparent;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  padding:6px 14px; color:var(--muted); transition:all .14s;
}
.nt-segbtn:hover{ color:var(--ink); }
.nt-segbtn.on{ background:var(--ink); color:#f6efe2; }
.chip-all{ font-family:var(--mono); font-size:10.5px; letter-spacing:.08em;
  text-transform:uppercase; padding:6px 13px; }

/* end-of-line thread label on the arc */
.thread-tag{ font-family:var(--sans); font-size:11.5px; font-weight:600; }

/* narrative-break markers */
.brk-flag{ font-family:var(--mono); font-size:9.5px; letter-spacing:.14em;
  text-transform:uppercase; fill:#3a342b; font-weight:600; }
.brk-sub{ font-family:var(--mono); font-size:10px; fill:var(--ink-soft); letter-spacing:.02em; }
.brk-pre{ font-family:var(--mono); font-size:8.5px; letter-spacing:.1em;
  text-transform:uppercase; fill:#a59c8c; }

/* LLM rationale in the detail card */
.dc-why{ font-family:var(--serif); font-style:italic; font-size:13px; line-height:1.45;
  color:#e6dccb; margin:10px 0 2px; }
.dc-why-src{ display:block; font-family:var(--mono); font-style:normal; font-size:9.5px;
  letter-spacing:.04em; color:#bcae97; margin-top:4px; text-transform:none; }

/* date-range picker */
.daterange{ display:inline-flex; align-items:center; gap:7px; margin-left:auto; flex:none; }
.daterange .dr-lab{ font-family:var(--mono); font-size:10px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--muted); }
.daterange input[type=date]{
  font-family:var(--mono); font-size:11.5px; color:var(--ink); background:var(--paper);
  border:1px solid var(--hair-strong); border-radius:8px; padding:4px 8px; cursor:pointer;
}
.daterange input[type=date]:hover{ border-color:var(--muted); }
.daterange .dr-reset{
  appearance:none; -webkit-appearance:none; cursor:pointer; margin-left:2px;
  font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  padding:6px 11px; border-radius:999px; transition:all .14s;
  background:var(--paper); border:1px solid var(--hair-strong); color:var(--ink-soft);
}
.daterange .dr-reset:hover{ border-color:var(--muted); color:var(--ink); }

/* ---------- Level 3 detail card ---------- */
.detail-card{
  position:absolute; top:14px; right:14px; width:330px; z-index:30;
  background:var(--ink); color:#f3ecdd; border-radius:6px; padding:18px 18px 16px;
  box-shadow:0 24px 50px -22px rgba(20,16,8,.6); font-family:var(--sans);
}
.dc-close{ position:absolute; top:10px; right:11px; background:none; border:none;
  color:#9a8f79; font-size:14px; cursor:pointer; line-height:1; }
.dc-close:hover{ color:#f3ecdd; }
.dc-kind{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:#bcae97;
  display:flex; align-items:center; gap:7px; margin-bottom:9px; }
.dc-sw{ width:9px; height:9px; border-radius:50%; }
.dc-outlet{ font-weight:600; color:#d9ccb2; }

/* sourced-paper masthead monogram (deep-dive box + tooltips) */
.outlet-logo{ display:inline-flex; align-items:center; justify-content:center;
  width:var(--lg,22px); height:var(--lg,22px); border-radius:4px; flex:none;
  background:var(--paper); color:var(--ink);
  font-family:var(--serif); font-weight:600; line-height:1;
  font-size:calc(var(--lg,22px) * 0.62); }
.dc-head{ font-family:var(--serif); font-size:18px; line-height:1.25; color:#fdf8ee; margin-bottom:6px; }
.dc-by{ font-family:var(--mono); font-size:10px; color:#bcae97; margin-bottom:14px; }
.dc-k{ font-family:var(--mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase;
  color:#a89c84; margin:12px 0 6px; }
.dc-meter{ position:relative; height:7px; border-radius:4px; margin-top:2px;
  background:linear-gradient(90deg,#2f6f9e,#aaa08e,#b23a2e); }
.dc-fill{ display:none; }
.dc-needle{ position:absolute; top:-3px; width:3px; height:13px; border-radius:2px;
  background:#fdf8ee; transform:translateX(-50%); box-shadow:0 0 0 1px rgba(0,0,0,.3); }
.dc-scale{ display:flex; justify-content:space-between; font-family:var(--mono);
  font-size:9px; color:#8d8169; margin-top:5px; letter-spacing:.02em; }
.dc-chips{ display:flex; flex-wrap:wrap; gap:6px; }
.dc-chip{ font-size:11.5px; color:#e7dcc6; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1); border-radius:999px; padding:4px 10px 4px 8px;
  display:inline-flex; align-items:center; gap:6px; }
.dc-cdot{ width:8px; height:8px; border-radius:50%; }
.dc-sub{ color:#8d8169; }
.dc-next{ margin-top:14px; padding-top:12px; border-top:1px solid rgba(255,255,255,.08); }
.dc-next[data-id]{ cursor:pointer; }
.dc-nextlink{ display:block; font-size:13px; color:#e7dcc6; margin-top:3px; }
.dc-next[data-id]:hover .dc-nextlink{ color:#fff; text-decoration:underline; }
.dc-end span:last-child{ display:block; font-size:12px; color:#8d8169; margin-top:3px; }
.dc-open{ display:block; margin-top:15px; text-align:center; text-decoration:none;
  font-family:var(--mono); font-size:11px; letter-spacing:.05em;
  background:rgba(255,255,255,.08); color:#fdf8ee; padding:9px; border-radius:5px;
  border:1px solid rgba(255,255,255,.12); transition:background .14s; }
.dc-open:hover{ background:rgba(255,255,255,.16); }

/* hover dimming via class on the svg root */
.dim .fadeable{opacity:.16; transition:opacity .18s;}
.fadeable{transition:opacity .18s;}
.hot{opacity:1 !important;}
.node-hit{cursor:pointer;}
.edge-hit{cursor:help;}

/* ---------- tooltip ---------- */
.tip{
  position:absolute; pointer-events:none; z-index:20;
  background:var(--ink); color:#f6efe2;
  border-radius:4px; padding:13px 15px 14px; width:296px;
  box-shadow:0 18px 40px -16px rgba(20,15,5,.6);
  opacity:0; transform:translateY(4px); transition:opacity .13s, transform .13s;
  font-size:12.5px; line-height:1.42;
}
.tip.on{opacity:1; transform:translateY(0);}
.tip .t-top{display:flex; align-items:center; gap:8px; margin-bottom:8px;}
.tip .t-sw{width:10px;height:10px;border-radius:50%; flex:none;}
.tip .t-outlet{font-weight:600; font-size:13.5px;}
.tip .t-kind{font-family:var(--mono); font-size:9.5px; color:#bcae97;
  letter-spacing:.08em; text-transform:uppercase; margin-left:auto;}
.tip .t-head{font-family:var(--serif); font-size:15px; line-height:1.28; color:#fdf8ee; margin:2px 0 11px;}
.tip .t-meta{display:flex; gap:16px; border-top:1px solid rgba(255,255,255,.14); padding-top:9px;}
.tip .t-meta .m{display:flex; flex-direction:column; gap:2px;}
.tip .t-meta .mk{font-family:var(--mono); font-size:9px; letter-spacing:.1em;
  text-transform:uppercase; color:#a89c84;}
.tip .t-meta .mv{font-size:12px; color:#f1e9da;}
.tip .t-frame{font-weight:600;}
/* linkage (edge) tooltip */
.tip .t-link{font-size:13.5px; color:#fdf8ee;}
.tip .t-link b{font-weight:600;}
.tip .t-arrow{color:#bcae97; margin:0 4px;}
.tip .t-evlabel{font-family:var(--mono); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:#a89c84; margin-bottom:6px;}
.tip .t-thread{font-size:13px; color:#fdf8ee; margin-bottom:9px;}
.tip .t-thread b{font-weight:600;}
.tip .t-phrase{font-family:var(--serif); font-style:italic; color:#e7d9bf;}
.tip .t-by{font-family:var(--mono); font-size:10px; color:#bcae97; margin:-4px 0 8px; letter-spacing:.02em;}
.tip .t-open{font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase;
  color:#a89c84; margin-top:9px; padding-top:7px; border-top:1px solid rgba(255,255,255,.08);}
.tip .t-evtext{font-family:var(--serif); font-size:14px; line-height:1.5; color:#efe7d8;}
.tip .t-sig{margin-top:12px; padding-top:11px; border-top:1px solid rgba(255,255,255,.14);}
.tip .t-siglabel{font-family:var(--mono); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:#a89c84;}
.tip .t-sigval{display:block; margin-top:5px; font-family:var(--serif); font-size:14px; color:#cdbf7e;}

footer.note{
  font-family:var(--mono); font-size:11px; color:var(--faint);
  letter-spacing:.04em; padding-top:14px; border-top:1px solid var(--hair);
  display:flex; justify-content:space-between;
}
