/* ============================================================
   Holocron — an SW5e explorer
   Aesthetic: a warm, dark archival artifact. Carved-stone display
   type, a single amber glow, faceted crystalline edges.
   ============================================================ */

:root {
  --ink:        #0c0a08;
  --ink-2:      #14110c;
  --ink-3:      #1c1812;
  --ink-4:      #251f17;
  --edge:       rgba(228,172,92,.16);
  --edge-lit:   rgba(228,172,92,.42);
  --parch:      #e8dec7;
  --parch-soft: #cabfa3;
  --parch-dim:  #8d8369;
  --amber:      #e6a849;
  --amber-lit:  #f8d28c;
  --kyber:      #82c8d8;
  --crimson:    #cf5742;

  --display: 'Marcellus', 'Times New Roman', serif;
  --body:    'Newsreader', Georgia, serif;
  --mono:    'IBM Plex Mono', ui-monospace, monospace;

  --notch: 11px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { height: 100%; }

body {
  background:
    radial-gradient(120% 70% at 50% -8%, rgba(230,168,73,.13), transparent 60%),
    radial-gradient(80% 50% at 88% 4%, rgba(130,200,216,.06), transparent 70%),
    var(--ink);
  color: var(--parch);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.66;
  -webkit-font-smoothing: antialiased;
}

/* fine film-grain overlay for atmosphere */
.grain {
  position: fixed; inset: 0; z-index: 999; pointer-events: none;
  opacity: .035; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

::selection { background: rgba(230,168,73,.28); color: var(--amber-lit); }

a { color: inherit; text-decoration: none; }

/* ---- top bar ---------------------------------------------------------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 26px;
  padding: 0 26px; height: 66px;
  background: linear-gradient(var(--ink), rgba(12,10,8,.86));
  border-bottom: 1px solid var(--edge);
  backdrop-filter: blur(7px);
}
.brand { display: flex; align-items: center; gap: 11px; flex-shrink: 0; }
.sigil {
  width: 30px; height: 30px; color: var(--amber);
  filter: drop-shadow(0 0 7px rgba(230,168,73,.55));
  animation: hover 7s ease-in-out infinite;
}
@keyframes hover { 50% { transform: translateY(-2px) rotate(2deg); } }
.wordmark {
  font-family: var(--display); font-size: 23px; letter-spacing: .14em;
  color: var(--parch); text-transform: uppercase;
}

.searchwrap { position: relative; flex: 1; max-width: 640px; }
#q {
  width: 100%; height: 40px; padding: 0 38px 0 16px;
  background: var(--ink-3); color: var(--parch);
  border: 1px solid var(--edge); border-radius: 2px;
  font-family: var(--mono); font-size: 13.5px; letter-spacing: .02em;
  transition: border-color .18s, box-shadow .18s;
}
#q::placeholder { color: var(--parch-dim); }
#q:focus {
  outline: none; border-color: var(--edge-lit);
  box-shadow: 0 0 0 1px var(--edge-lit), 0 0 24px rgba(230,168,73,.12);
}
.hint {
  position: absolute; right: 9px; top: 9px;
  width: 22px; height: 22px; display: grid; place-items: center;
  font-family: var(--mono); font-size: 12px; color: var(--parch-dim);
  border: 1px solid var(--edge); border-radius: 3px;
}

/* ---- layout ----------------------------------------------------------- */
.layout {
  display: grid; grid-template-columns: minmax(0,1fr) 312px;
  max-width: 1280px; margin: 0 auto; min-height: calc(100vh - 66px);
}
#view { padding: 40px 44px 120px; min-width: 0; }
.thread {
  border-left: 1px solid var(--edge);
  padding: 34px 26px; position: sticky; top: 66px;
  height: calc(100vh - 66px); overflow-y: auto;
}

/* ---- shared bits ------------------------------------------------------ */
.kicker {
  font-family: var(--mono); font-size: 11px; letter-spacing: .26em;
  text-transform: uppercase; color: var(--amber);
}
.facet, .chip, .typechip {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .12em;
  text-transform: uppercase;
}
.divider {
  display: flex; align-items: center; gap: 14px; margin: 36px 0 20px;
  color: var(--parch-dim);
}
.divider::before, .divider::after {
  content: ""; height: 1px; flex: 1; background: var(--edge);
}
.divider span {
  font-family: var(--mono); font-size: 11px; letter-spacing: .24em;
  text-transform: uppercase;
}
.divider::before { flex: 0 0 18px; }

/* faceted card corners */
.facetcard {
  background: var(--ink-2); border: 1px solid var(--edge);
  clip-path: polygon(var(--notch) 0, 100% 0, 100% calc(100% - var(--notch)),
    calc(100% - var(--notch)) 100%, 0 100%, 0 var(--notch));
}

/* ---- home ------------------------------------------------------------- */
.hero { text-align: center; padding: 56px 0 30px; position: relative; }
.crystal {
  width: 116px; height: 116px; margin: 0 auto 30px; color: var(--amber);
  filter: drop-shadow(0 0 26px rgba(230,168,73,.4));
  animation: spin 26s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.hero h1 {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(40px, 7vw, 72px); letter-spacing: .07em;
  text-transform: uppercase; line-height: 1;
}
.hero h1 em {
  display: block; font-size: 15px; letter-spacing: .42em; font-style: normal;
  color: var(--amber); margin-top: 16px;
}
.hero p {
  max-width: 480px; margin: 22px auto 0; color: var(--parch-soft);
  font-size: 18px;
}

.intents {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px; margin-top: 14px;
}
.intent {
  display: block; padding: 22px 20px; cursor: pointer;
  background: var(--ink-2); border: 1px solid var(--edge);
  clip-path: polygon(var(--notch) 0, 100% 0, 100% 100%,
    0 100%, 0 var(--notch));
  transition: transform .16s, border-color .16s, background .16s;
}
.intent:hover {
  transform: translateY(-3px); border-color: var(--edge-lit);
  background: var(--ink-3);
}
.intent .glyph { font-size: 24px; color: var(--amber); }
.intent h3 {
  font-family: var(--display); font-weight: 400; font-size: 21px;
  margin: 12px 0 4px; letter-spacing: .02em;
}
.intent p { font-size: 14.5px; color: var(--parch-dim); line-height: 1.5; }

.statline {
  display: flex; gap: 30px; justify-content: center; flex-wrap: wrap;
  margin-top: 40px; color: var(--parch-dim);
}
.statline b {
  font-family: var(--display); font-size: 30px; color: var(--parch);
  font-weight: 400; display: block;
}
.statline span { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; }

/* ---- search results --------------------------------------------------- */
.results-head { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.results-head h2 {
  font-family: var(--display); font-weight: 400; font-size: 30px;
}
.results-head .count { color: var(--parch-dim); font-family: var(--mono); font-size: 12px; }

.typefilter { display: flex; flex-wrap: wrap; gap: 7px; margin: 18px 0 26px; }
.typechip {
  padding: 5px 11px; cursor: pointer; color: var(--parch-soft);
  background: var(--ink-2); border: 1px solid var(--edge);
  transition: color .14s, border-color .14s, background .14s;
}
.typechip:hover { border-color: var(--edge-lit); color: var(--parch); }
.typechip.on {
  background: rgba(230,168,73,.14); border-color: var(--edge-lit);
  color: var(--amber-lit);
}
.typechip i { font-style: normal; opacity: .55; margin-left: 6px; }

.hit {
  display: grid; grid-template-columns: 138px 1fr; gap: 20px;
  padding: 16px 4px; border-bottom: 1px solid var(--edge); cursor: pointer;
  transition: background .14s;
  animation: rise .4s both;
}
.hit:hover { background: rgba(230,168,73,.04); }
.hit:hover .hit-name { color: var(--amber-lit); }
.hit-type { padding-top: 3px; }
.hit-name {
  font-family: var(--display); font-size: 21px; transition: color .14s;
}
.hit-sub {
  font-family: var(--mono); font-size: 11px; letter-spacing: .04em;
  color: var(--parch-dim); margin-top: 3px;
}
.hit-snip { color: var(--parch-soft); font-size: 15px; margin-top: 6px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; }
@keyframes rise { from { opacity: 0; transform: translateY(8px); } }

/* type colour coding — restrained, mostly amber-family */
.t { color: var(--amber); border-color: var(--edge); }
.t.power, .t.maneuver, .t.feature { color: var(--kyber); }
.t.monster { color: var(--crimson); }
.t.rule, .t.reference-table, .t.condition,
.t.armor-property, .t.weapon-property { color: var(--parch-dim); }
.t.equipment, .t.enhanced-item, .t.starship-equipment { color: #c9a86b; }

.tag-pill {
  display: inline-block; padding: 4px 9px; border: 1px solid currentColor;
  border-radius: 2px; line-height: 1;
}

/* ---- document view ---------------------------------------------------- */
.doc { max-width: 760px; animation: rise .4s both; }
.doc-top { display: flex; align-items: flex-start; gap: 16px; }
.doc-top .grow { flex: 1; }
.doc h1 {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(34px, 5vw, 52px); line-height: 1.04;
  letter-spacing: .015em; margin: 10px 0 8px;
}
.doc-sub {
  font-family: var(--mono); font-size: 12px; letter-spacing: .06em;
  color: var(--amber);
}
.facets { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 14px; }
.facets .facet {
  padding: 4px 9px; color: var(--parch-soft);
  border: 1px solid var(--edge); background: var(--ink-2);
}

.pin {
  flex-shrink: 0; font-family: var(--mono); font-size: 11px;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 9px 14px; cursor: pointer; color: var(--parch-soft);
  background: var(--ink-2); border: 1px solid var(--edge);
  transition: all .15s;
}
.pin:hover { border-color: var(--edge-lit); color: var(--parch); }
.pin.on { background: rgba(230,168,73,.16); border-color: var(--edge-lit);
  color: var(--amber-lit); }

.portraits { display: flex; gap: 12px; flex-wrap: wrap; margin: 26px 0 4px; }
.portraits img {
  height: 188px; width: auto; border: 1px solid var(--edge);
  background: var(--ink-3); filter: saturate(.92);
}

/* prose body */
.prose { margin-top: 20px; }
.prose h1, .prose h2, .prose h3, .prose h4 {
  font-family: var(--display); font-weight: 400; letter-spacing: .02em;
  margin: 30px 0 10px; color: var(--parch);
}
.prose h1 { font-size: 27px; } .prose h2 { font-size: 23px; }
.prose h3 { font-size: 20px; } .prose h4 { font-size: 17px; color: var(--amber); }
.prose p { margin: 12px 0; }
.prose ul, .prose ol { margin: 12px 0 12px 22px; }
.prose li { margin: 5px 0; }
.prose strong { color: var(--amber-lit); font-weight: 600; }
.prose em strong, .prose strong em { color: var(--amber); }
.prose hr { border: none; border-top: 1px solid var(--edge); margin: 24px 0; }
.prose blockquote {
  border-left: 2px solid var(--edge-lit); padding-left: 16px;
  color: var(--parch-soft); font-style: italic; margin: 14px 0;
}
.prose table {
  border-collapse: collapse; width: 100%; margin: 16px 0;
  font-family: var(--mono); font-size: 12.5px;
}
.prose th, .prose td {
  border: 1px solid var(--edge); padding: 6px 10px; text-align: left;
}
.prose th {
  background: var(--ink-3); color: var(--amber);
  text-transform: uppercase; letter-spacing: .08em; font-size: 11px;
}
.prose tr:nth-child(even) td { background: rgba(255,255,255,.012); }
.prose code {
  font-family: var(--mono); font-size: .85em; color: var(--kyber);
  background: var(--ink-3); padding: 1px 5px; border-radius: 2px;
}

/* cross-reference links inside prose */
a.xref {
  color: var(--kyber); border-bottom: 1px dotted rgba(130,200,216,.5);
  transition: color .12s, border-color .12s;
}
a.xref:hover { color: #b9e6f0; border-bottom-color: var(--kyber); }

/* panels: decisions, connections, codex, backlinks */
.panel { margin: 26px 0; padding: 20px 22px; }
.panel > .kicker { display: block; margin-bottom: 14px; }

.decision { margin: 14px 0; }
.decision .d-label {
  font-family: var(--display); font-size: 18px; color: var(--parch);
}
.decision .d-text { font-size: 14.5px; color: var(--parch-dim); margin-top: 3px; }

.linkrow { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 9px; }
.node {
  display: inline-flex; align-items: baseline; gap: 7px; cursor: pointer;
  padding: 6px 11px; background: var(--ink-3); border: 1px solid var(--edge);
  transition: border-color .14s, background .14s, transform .14s;
}
.node:hover {
  border-color: var(--edge-lit); background: var(--ink-4);
  transform: translateY(-1px);
}
.node .n-name { font-family: var(--body); font-size: 15px; }
.node .n-type {
  font-family: var(--mono); font-size: 9px; letter-spacing: .1em;
  text-transform: uppercase;
}
.conn-group { margin: 16px 0; }
.conn-group .rel {
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--parch-dim);
}
.morelink {
  font-family: var(--mono); font-size: 11px; color: var(--amber);
  cursor: pointer; align-self: center; padding: 6px 4px;
}
.morelink:hover { color: var(--amber-lit); }

.codex { display: grid; grid-template-columns: auto 1fr; gap: 6px 18px; }
.codex dt {
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--parch-dim); padding-top: 3px;
}
.codex dd { color: var(--parch); }

/* ---- the character thread -------------------------------------------- */
.thread h2 {
  font-family: var(--mono); font-size: 11px; letter-spacing: .24em;
  text-transform: uppercase; color: var(--amber); margin-bottom: 4px;
}
.thread .sub { font-size: 13.5px; color: var(--parch-dim); margin-bottom: 22px; }
.thread-empty {
  font-size: 14px; color: var(--parch-dim); font-style: italic;
  line-height: 1.6;
}
.slot {
  display: flex; align-items: baseline; gap: 9px; padding: 11px 0;
  border-bottom: 1px solid var(--edge);
}
.slot .mark {
  font-family: var(--mono); font-size: 13px; color: var(--amber);
}
.slot.empty .mark { color: var(--parch-dim); }
.slot .s-body { flex: 1; min-width: 0; }
.slot .s-name {
  font-family: var(--display); font-size: 17px; cursor: pointer;
}
.slot .s-name:hover { color: var(--amber-lit); }
.slot.empty .s-name { font-family: var(--body); font-size: 14px;
  color: var(--parch-dim); font-style: italic; }
.slot .s-type {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--parch-dim);
}
.slot .drop {
  cursor: pointer; color: var(--parch-dim); font-size: 16px;
  line-height: 1; padding: 2px 4px;
}
.slot .drop:hover { color: var(--crimson); }

.nextup {
  margin-top: 22px; padding: 16px; background: var(--ink-2);
  border: 1px solid var(--edge);
  clip-path: polygon(9px 0, 100% 0, 100% 100%, 0 100%, 0 9px);
}
.nextup .kicker { display: block; margin-bottom: 7px; }
.nextup p { font-size: 14.5px; color: var(--parch-soft); }
.nextup.ready { border-color: var(--edge-lit);
  background: rgba(230,168,73,.08); }
.nextup.ready .kicker { color: var(--amber-lit); }

.loading {
  display: grid; place-items: center; height: 60vh;
  font-family: var(--mono); font-size: 12px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--parch-dim);
}
.loading .crystal { width: 64px; height: 64px; margin-bottom: 22px; }

.empty { color: var(--parch-dim); font-style: italic; padding: 40px 0; }

/* ---- species grid ----------------------------------------------------- */
.facet-rail {
  display: flex; flex-wrap: wrap; gap: 20px 32px; align-items: flex-start;
  padding: 18px 22px; margin: 18px 0 28px;
}
.facet-group { display: flex; flex-direction: column; gap: 9px; }
.facet-group .label {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--amber);
}
.fchips { display: flex; flex-wrap: wrap; gap: 6px; }
.fchip {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em;
  text-transform: uppercase; padding: 5px 10px; cursor: pointer;
  color: var(--parch-soft); background: var(--ink-3);
  border: 1px solid var(--edge); transition: color .14s, border-color .14s,
  background .14s;
}
.fchip:hover { border-color: var(--edge-lit); color: var(--parch); }
.fchip.on {
  background: rgba(230,168,73,.16); border-color: var(--edge-lit);
  color: var(--amber-lit);
}
.fchip i { font-style: normal; opacity: .5; margin-left: 7px; }
.fclear {
  align-self: center; cursor: pointer; padding: 6px 4px;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--crimson);
}
.fclear:hover { color: #e07a68; }

.sp-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(156px, 1fr));
}
.sp-card {
  display: flex; flex-direction: column; padding: 12px; cursor: pointer;
  background: var(--ink-2); border: 1px solid var(--edge);
  clip-path: polygon(10px 0, 100% 0, 100% calc(100% - 10px),
    calc(100% - 10px) 100%, 0 100%, 0 10px);
  transition: transform .16s, border-color .16s, background .16s;
  animation: rise .4s both;
}
.sp-card:hover {
  transform: translateY(-4px); border-color: var(--edge-lit);
  background: var(--ink-3);
}
.sp-card:hover .sp-name { color: var(--amber-lit); }
.sp-portrait {
  height: 190px; margin-bottom: 11px; overflow: hidden;
  display: grid; place-items: center;
  background:
    radial-gradient(62% 52% at 50% 36%, rgba(230,168,73,.12), transparent 72%),
    var(--ink-3);
}
.sp-portrait img {
  max-height: 100%; max-width: 100%; object-fit: contain;
  filter: saturate(.93) drop-shadow(0 6px 15px rgba(0,0,0,.55));
}
.sp-portrait.empty { font-size: 38px; color: var(--edge-lit); }
.sp-name {
  font-family: var(--display); font-size: 18px; line-height: 1.14;
  transition: color .14s;
}
.sp-meta {
  font-family: var(--mono); font-size: 9px; letter-spacing: .03em;
  color: var(--parch-dim); margin-top: 4px;
}
.sp-abil { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 9px; }
.sp-abil span {
  font-family: var(--mono); font-size: 8.5px; letter-spacing: .07em;
  padding: 2px 5px; color: var(--kyber);
  border: 1px solid rgba(130,200,216,.32); border-radius: 2px;
}

/* ---- archetype overview ---------------------------------------------- */
.arch-section { margin-bottom: 34px; }
.arch-section-head {
  display: flex; align-items: baseline; gap: 14px;
  margin-bottom: 14px; padding-bottom: 8px;
  border-bottom: 1px solid var(--edge);
}
.arch-section-head a, .arch-section-head span:first-child {
  font-family: var(--display); font-size: 25px; color: var(--parch);
  letter-spacing: .02em; transition: color .14s;
}
.arch-section-head a:hover { color: var(--amber-lit); }
.arch-count {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--parch-dim);
}
.arch-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(246px, 1fr));
}
.arch-card {
  display: flex; flex-direction: column; gap: 7px; padding: 15px 16px;
  cursor: pointer; background: var(--ink-2); border: 1px solid var(--edge);
  clip-path: polygon(9px 0, 100% 0, 100% calc(100% - 9px),
    calc(100% - 9px) 100%, 0 100%, 0 9px);
  transition: transform .15s, border-color .15s, background .15s;
  animation: rise .4s both;
}
.arch-card:hover {
  transform: translateY(-3px); border-color: var(--edge-lit);
  background: var(--ink-3);
}
.arch-card:hover .arch-name { color: var(--amber-lit); }
.arch-name {
  font-family: var(--display); font-size: 19px; line-height: 1.12;
  transition: color .14s;
}
.arch-card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 8px;
}
.arch-pitch {
  font-size: 13.5px; line-height: 1.5; color: var(--parch-soft);
}
.arch-themes { display: flex; flex-wrap: wrap; gap: 5px; margin-top: auto;
  padding-top: 3px; }
.arch-themes span {
  font-family: var(--mono); font-size: 8.5px; letter-spacing: .07em;
  text-transform: uppercase; padding: 2px 6px; color: var(--parch-dim);
  border: 1px solid var(--edge);
}
.arch-cast {
  font-family: var(--mono); font-size: 8.5px; letter-spacing: .07em;
  text-transform: uppercase; padding: 2px 6px;
  border: 1px solid currentColor; border-radius: 2px;
}
.arch-cast.force { color: var(--kyber); }
.arch-cast.tech { color: #c9a86b; }

/* ---- class browser --------------------------------------------------- */
.cls-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.cls-art {
  height: 168px; margin: -15px -16px 4px; overflow: hidden;
  display: grid; place-items: center;
  background:
    radial-gradient(60% 54% at 50% 34%, rgba(230,168,73,.13), transparent 72%),
    var(--ink-3);
  border-bottom: 1px solid var(--edge);
}
.cls-art img {
  max-height: 100%; max-width: 100%; object-fit: contain;
  filter: saturate(.93) drop-shadow(0 6px 15px rgba(0,0,0,.55));
}
.cls-meta {
  font-family: var(--mono); font-size: 9px; letter-spacing: .03em;
  color: var(--parch-dim);
}

/* ---- powers browser -------------------------------------------------- */
.pw-list { display: flex; flex-direction: column; }
.pw-row {
  display: grid; align-items: center; gap: 12px;
  grid-template-columns: 62px 46px 1fr auto 132px;
  padding: 9px 12px; border-bottom: 1px solid var(--edge);
  cursor: pointer; animation: rise .4s both;
  transition: background .14s;
}
.pw-row:hover { background: rgba(230,168,73,.05); }
.pw-row:hover .pw-name { color: var(--amber-lit); }
.pw-lvl {
  font-family: var(--mono); font-size: 9px; letter-spacing: .06em;
  text-transform: uppercase; color: var(--parch-dim);
}
.pw-type {
  font-family: var(--mono); font-size: 8.5px; letter-spacing: .07em;
  text-transform: uppercase; padding: 2px 5px; justify-self: start;
  border: 1px solid currentColor; border-radius: 2px;
}
.pw-type.force { color: var(--kyber); }
.pw-type.tech { color: #c9a86b; }
.pw-name {
  font-family: var(--display); font-size: 17px; color: var(--parch);
  transition: color .14s;
}
.pw-tags { display: flex; flex-wrap: wrap; gap: 5px; justify-self: end; }
.pw-align, .pw-conc {
  font-family: var(--mono); font-size: 8px; letter-spacing: .07em;
  text-transform: uppercase; padding: 2px 5px; border: 1px solid var(--edge);
  color: var(--parch-dim);
}
.pw-align.light { color: #e6a849; border-color: rgba(230,168,73,.42); }
.pw-align.dark { color: #d2674f; border-color: rgba(210,103,79,.42); }
.pw-align.universal { color: var(--kyber); border-color: rgba(130,200,216,.42); }
.pw-range {
  font-family: var(--mono); font-size: 9.5px; color: var(--parch-dim);
  text-align: right; overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap;
}

/* feats / monsters / items rows — variants of the .pw-row layout */
.feat-row { grid-template-columns: 1fr auto 90px; }
.item-row { grid-template-columns: 64px 1fr auto 160px; }

/* compare toggle on class & archetype cards */
.arch-head-r { display: flex; align-items: center; gap: 8px; }
.cmp-tog {
  width: 20px; height: 20px; flex-shrink: 0; cursor: pointer;
  display: grid; place-items: center; border-radius: 2px;
  font-size: 12px; line-height: 1; color: var(--parch-dim);
  border: 1px solid var(--edge); transition: color .14s, border-color .14s;
}
.cmp-tog:hover { color: var(--amber); border-color: var(--edge-lit); }
.cmp-tog.on {
  color: var(--ink-3); background: var(--amber); border-color: var(--amber);
}

/* level-by-level timeline on class & archetype pages */
.timeline { display: flex; flex-direction: column; }
.tl-row {
  display: grid; grid-template-columns: 40px 1fr; gap: 12px;
  align-items: start; padding: 9px 0; border-top: 1px solid var(--edge);
}
.tl-row:first-child { border-top: none; }
.tl-lvl {
  font-family: var(--mono); font-size: 14px; color: var(--amber);
  text-align: right; padding-top: 2px;
}

/* the floating compare tray */
.cmpbar {
  position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%);
  z-index: 50; display: flex; align-items: center; gap: 14px;
  padding: 10px 16px; background: var(--ink-3);
  border: 1px solid var(--edge-lit); box-shadow: 0 8px 30px rgba(0,0,0,.55);
  font-family: var(--mono); font-size: 11px;
}
.cmpbar[hidden] { display: none; }
.cmpbar-n {
  color: var(--amber); letter-spacing: .1em; text-transform: uppercase;
  white-space: nowrap;
}
.cmpbar-names {
  color: var(--parch-soft); max-width: 260px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cmpbar-go { color: var(--kyber); white-space: nowrap; }
.cmpbar-go:hover { color: var(--amber-lit); }
.cmpbar-hint { color: var(--parch-dim); white-space: nowrap; }
.cmpbar-x { color: var(--parch-dim); cursor: pointer; white-space: nowrap; }
.cmpbar-x:hover { color: #e07a68; }

/* the compare view */
.cmp-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(var(--cols, 2), minmax(0, 1fr));
}
.cmp-col {
  display: flex; flex-direction: column; gap: 13px; padding: 16px 17px;
  background: var(--ink-2); border: 1px solid var(--edge);
  clip-path: polygon(9px 0, 100% 0, 100% calc(100% - 9px),
    calc(100% - 9px) 100%, 0 100%, 0 9px);
}
.cmp-name {
  font-family: var(--display); font-size: 21px; line-height: 1.12;
  color: var(--parch); transition: color .14s;
}
.cmp-name:hover { color: var(--amber-lit); }
.cmp-sub {
  font-family: var(--mono); font-size: 10px; color: var(--parch-dim);
  margin-top: -8px;
}
.cmp-field { display: flex; flex-direction: column; gap: 5px; font-size: 14px; }
.cmp-empty { color: var(--parch-dim); font-size: 13px; }
.cmp-drop {
  font-family: var(--mono); font-size: 10px; letter-spacing: .04em;
  color: var(--parch-dim); cursor: pointer; margin-top: auto; padding-top: 4px;
}
.cmp-drop:hover { color: #e07a68; }

/* role badges + complexity dots — shared by cards and the doc panel */
.roles { display: flex; flex-wrap: wrap; gap: 4px; }
.role {
  font-family: var(--mono); font-size: 9px; letter-spacing: .1em;
  text-transform: uppercase; padding: 3px 7px; border: 1px solid;
  border-radius: 2px; white-space: nowrap;
}
.role-defender   { color: #82c8d8; border-color: rgba(130,200,216,.42); }
.role-striker    { color: #d2674f; border-color: rgba(210,103,79,.42); }
.role-skirmisher { color: #e6a849; border-color: rgba(230,168,73,.42); }
.role-controller { color: #9a9fd6; border-color: rgba(154,159,214,.42); }
.role-support    { color: #8fb98a; border-color: rgba(143,185,138,.42); }
.role-specialist { color: #b3a585; border-color: rgba(179,165,133,.42); }
.cx { letter-spacing: 2px; font-size: 10px; white-space: nowrap; }
.cx .cx-o { color: var(--parch-dim); opacity: .6; }
.cx-1 { color: #8fb98a; }
.cx-2 { color: var(--amber); }
.cx-3 { color: #d2674f; }

/* the at-a-glance card panel on a document page */
.cardpanel { display: flex; flex-direction: column; gap: 15px; }
.cp-pitch {
  font-family: var(--display); font-size: 21px; line-height: 1.36;
  color: var(--parch);
}
.cp-stats { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.cp-cx { display: flex; align-items: center; gap: 8px; }
.cp-cx-lbl {
  font-family: var(--mono); font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--parch-dim);
}
.cp-lbl {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--amber); margin-right: 8px;
}
.cp-transform {
  display: grid; gap: 5px; padding: 12px 15px;
  background: var(--ink-3); border-left: 2px solid var(--edge-lit);
}
.cp-sig { font-size: 14.5px; color: var(--parch-soft); }
.cp-heads {
  display: flex; gap: 10px; align-items: flex-start; padding: 11px 14px;
  background: rgba(207,87,66,.08); border: 1px solid rgba(207,87,66,.3);
  font-size: 14px; color: var(--parch-soft);
}
.cp-heads-mark {
  color: var(--crimson); font-family: var(--mono); font-weight: 600;
  flex-shrink: 0;
}
.cp-foot { display: flex; flex-direction: column; gap: 11px; }
.cp-pairs { font-size: 14px; color: var(--parch-soft); }

/* ---- responsive ------------------------------------------------------- */
@media (max-width: 940px) {
  .layout { grid-template-columns: 1fr; }
  .thread {
    position: static; height: auto; border-left: none;
    border-top: 1px solid var(--edge);
  }
  #view { padding: 30px 22px 90px; }
  .hit { grid-template-columns: 1fr; gap: 5px; }
  .pw-row {
    grid-template-columns: 56px 1fr;
    column-gap: 10px; row-gap: 4px;
  }
  .pw-lvl  { grid-row: 1; grid-column: 1; }
  .pw-name { grid-row: 1; grid-column: 2; }
  .pw-type { grid-row: 2; grid-column: 1; }
  .pw-tags { grid-row: 2; grid-column: 2; justify-self: start; }
  .pw-range { grid-row: 3; grid-column: 1 / 3; text-align: left; }
  .cmp-grid { grid-template-columns: 1fr; }
  .cmpbar { left: 12px; right: 12px; transform: none; gap: 10px;
    flex-wrap: wrap; justify-content: center; }
  .cmpbar-names { max-width: 100%; }
}
