:root{
  --ink:#e8ddc7; --ink-dim:#b3a587; --ink-faint:#7d7259;
  --bg:#14110d; --bg-raised:#1c1812; --bg-panel:#211c15; --bg-hover:#2a2419;
  --line:#3a3225; --line-soft:#2c2619;
  --amber:#d9a441; --amber-bright:#f0bf5e; --amber-deep:#9c6f23;
  --rust:#bb6b3d; --sage:#8a9a6b; --slate:#6b8a9a; --plum:#9a6b8a; --crimson:#c0584f;
  --canon:#8a9a6b; --draft:#a98a5a; --speculative:#9a6b8a;
  --shadow:0 8px 32px rgba(0,0,0,.55); --shadow-sm:0 2px 12px rgba(0,0,0,.4);
  --serif:'Cormorant Garamond',Georgia,serif; --body:'Spectral',Georgia,serif; --mono:'JetBrains Mono',monospace;
  --noise-opacity:.025; --grad-1:rgba(217,164,65,.04); --grad-2:rgba(155,111,138,.03);
  --success:#8a9a6b; --warn:#d9a441; --error:#c0584f; --info:#6b8a9a;
}
/* dark theme = the default archive palette (explicit so toggling back is clean) */
[data-theme="dark"]{
  --ink:#e8ddc7; --ink-dim:#b3a587; --ink-faint:#7d7259;
  --bg:#14110d; --bg-raised:#1c1812; --bg-panel:#211c15; --bg-hover:#2a2419;
  --line:#3a3225; --line-soft:#2c2619;
  --amber:#d9a441; --amber-bright:#f0bf5e; --amber-deep:#9c6f23;
  --rust:#bb6b3d; --sage:#8a9a6b; --slate:#6b8a9a; --plum:#9a6b8a; --crimson:#c0584f;
  --canon:#8a9a6b; --draft:#a98a5a; --speculative:#9a6b8a;
  --shadow:0 8px 32px rgba(0,0,0,.55); --shadow-sm:0 2px 12px rgba(0,0,0,.4);
  --noise-opacity:.025; --grad-1:rgba(217,164,65,.04); --grad-2:rgba(155,111,138,.03);
  --success:#8a9a6b; --warn:#d9a441; --error:#c0584f; --info:#6b8a9a;
}
/* light theme = scribe's daylight — warm parchment, ink-brown text, same amber soul */
[data-theme="light"]{
  --ink:#2f2718; --ink-dim:#6b5d44; --ink-faint:#9a8a6a;
  --bg:#f3ecdb; --bg-raised:#ece3cf; --bg-panel:#e7ddc6; --bg-hover:#ddd0b4;
  --line:#cbbd9c; --line-soft:#dccfb0;
  --amber:#a9781f; --amber-bright:#8a5f12; --amber-deep:#caa14a;
  --rust:#a0552a; --sage:#5f7038; --slate:#41617a; --plum:#7a4a68; --crimson:#a8392f;
  --canon:#5f7038; --draft:#9a6f2a; --speculative:#7a4a68;
  --shadow:0 8px 30px rgba(120,90,30,.18); --shadow-sm:0 2px 10px rgba(120,90,30,.12);
  --noise-opacity:.05; --grad-1:rgba(169,120,31,.05); --grad-2:rgba(122,74,104,.04);
  --success:#5f7038; --warn:#a9781f; --error:#a8392f; --info:#41617a;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  background:var(--bg); color:var(--ink); font-family:var(--body); font-size:15px; line-height:1.6;
  overflow:hidden;
  transition:background-color .35s ease, color .35s ease;
  background-image:
    radial-gradient(ellipse at 20% 10%, var(--grad-1), transparent 50%),
    radial-gradient(ellipse at 80% 90%, var(--grad-2), transparent 50%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--ink-faint)}
button{font-family:inherit;cursor:pointer;color:inherit;background:none;border:none}
input,select,textarea{font-family:inherit;font-size:inherit;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:8px 10px;width:100%;transition:border-color .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--amber)}
textarea{resize:vertical;line-height:1.6;min-height:80px}
label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin:14px 0 5px;font-family:var(--mono)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15}
a{color:var(--amber)}
/* inline icon spans: constrain the SVG to the span's box so it never overflows before titles */
span[style*="inline-flex"]>svg{width:100%;height:100%;display:block}
/* icons prepended directly inside headings: size them to sit beside the text, not dwarf it */
.panel h3>svg{width:19px;height:19px;flex-shrink:0;color:var(--amber)}
.view-title>svg{width:24px;height:24px;flex-shrink:0}
.modal-head h3>svg{width:20px;height:20px;flex-shrink:0;color:var(--amber)}
.detail-section h4>svg{width:14px;height:14px;flex-shrink:0}

/* ===== App shell ===== */
#app{display:flex;flex-direction:column;height:100vh}
.topbar{
  display:flex;align-items:center;gap:18px;padding:10px 20px;
  background:linear-gradient(180deg,var(--bg-raised),var(--bg-panel));
  border-bottom:1px solid var(--line);flex-shrink:0;z-index:50;
}
.brand{display:flex;align-items:baseline;gap:10px;cursor:default;user-select:none}
.brand .glyph{font-family:var(--serif);font-size:26px;color:var(--amber);font-weight:700;letter-spacing:.04em}
.brand .sub{font-family:var(--mono);font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-faint)}
.world-name-field{
  font-family:var(--serif);font-size:20px;font-weight:600;background:transparent;border:none;
  color:var(--ink);width:auto;min-width:200px;padding:4px 8px;border-radius:4px;
}
.world-name-field:hover{background:var(--bg-hover)}
.world-name-field:focus{background:var(--bg);border:1px solid var(--amber)}
.topbar-spacer{flex:1}
.tb-btn{
  display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border:1px solid var(--line);
  border-radius:5px;font-size:12px;letter-spacing:.04em;color:var(--ink-dim);transition:all .18s;white-space:nowrap;
}
.tb-btn:hover{border-color:var(--amber);color:var(--ink);background:var(--bg-hover)}
.tb-btn.primary{background:var(--amber-deep);border-color:var(--amber);color:#1a1408;font-weight:500}
.tb-btn.primary:hover{background:var(--amber);color:#14110d}
.tb-btn svg{width:14px;height:14px}
.tb-btn.icon-only{padding:7px 9px}
.tb-btn.icon-only svg{width:16px;height:16px}
/* show the icon for the theme you'll switch TO: dark shows sun, light shows moon */
.tb-btn#btnTheme svg:nth-child(1){display:none} /* sun */
.tb-btn#btnTheme svg:nth-child(2){display:block} /* moon */
[data-theme="light"] .tb-btn#btnTheme svg:nth-child(1){display:block}
[data-theme="light"] .tb-btn#btnTheme svg:nth-child(2){display:none}

/* ===== Layout body ===== */
.body-row{display:flex;flex:1;overflow:hidden}
.sidebar{
  width:228px;flex-shrink:0;background:var(--bg-raised);border-right:1px solid var(--line);
  display:flex;flex-direction:column;overflow-y:auto;
}
.nav-section{padding:14px 0 6px}
.nav-label{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);padding:4px 18px 8px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:8px 18px;font-size:13.5px;color:var(--ink-dim);
  transition:all .15s;border-left:2px solid transparent;cursor:pointer;position:relative;
}
.nav-item:hover{background:var(--bg-hover);color:var(--ink)}
.nav-item.active{background:linear-gradient(90deg,rgba(217,164,65,.12),transparent);color:var(--amber-bright);border-left-color:var(--amber)}
.nav-item .ico{width:17px;height:17px;flex-shrink:0;opacity:.85}
.nav-item .count{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--ink-faint);background:var(--bg);padding:1px 7px;border-radius:9px}
.nav-item.active .count{color:var(--amber);background:rgba(217,164,65,.12)}

/* main content */
.main{flex:1;overflow-y:auto;position:relative}
.view{display:none;padding:26px 32px 80px;max-width:1400px;margin:0 auto;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.view-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;border-bottom:1px solid var(--line-soft);padding-bottom:16px;gap:20px;flex-wrap:wrap}
.view-title{font-size:30px;color:var(--ink);display:flex;align-items:center;gap:13px}
.view-title .dot{width:9px;height:9px;border-radius:50%;background:var(--amber)}
.view-sub{font-size:13px;color:var(--ink-faint);font-style:italic;margin-top:3px}
.view-actions{display:flex;gap:9px;flex-wrap:wrap}

/* ===== Inspector panel (right) ===== */
.inspector{
  width:0;flex-shrink:0;background:var(--bg-panel);border-left:1px solid var(--line);
  overflow:hidden;transition:width .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;
}
.inspector.open{width:380px}
.insp-inner{width:380px;display:flex;flex-direction:column;height:100%}
.insp-head{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;flex-shrink:0}
.insp-head .close{margin-left:auto;width:26px;height:26px;border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);transition:all .15s}
.insp-head .close:hover{background:var(--bg-hover);color:var(--ink)}
.insp-body{padding:6px 18px 24px;overflow-y:auto;flex:1}

/* ===== Buttons & chips ===== */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border:1px solid var(--line);border-radius:5px;font-size:13px;color:var(--ink-dim);transition:all .16s}
.btn:hover{border-color:var(--amber);color:var(--ink);background:var(--bg-hover)}
.btn.sm{padding:5px 11px;font-size:12px}
.btn.amber{background:var(--amber-deep);border-color:var(--amber);color:#1a1408;font-weight:500}
.btn.amber:hover{background:var(--amber);color:#14110d}
.btn.danger:hover{border-color:var(--crimson);color:var(--crimson)}
.btn svg{width:14px;height:14px}
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-family:var(--mono);letter-spacing:.03em;border:1px solid var(--line);color:var(--ink-dim)}
.chip.canon{background:rgba(138,154,107,.13);border-color:rgba(138,154,107,.4);color:#a9bb88}
.chip.draft{background:rgba(169,138,90,.13);border-color:rgba(169,138,90,.4);color:#c4a373}
.chip.speculative{background:rgba(154,107,138,.13);border-color:rgba(154,107,138,.4);color:#bb88a9}

/* ===== Entity grid / cards ===== */
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.search-box{position:relative;flex:1;min-width:220px;max-width:420px}
.search-box input{padding-left:34px}
.search-box svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink-faint)}
.filter-pill{padding:6px 13px;border:1px solid var(--line);border-radius:20px;font-size:12px;color:var(--ink-dim);transition:all .15s;white-space:nowrap}
.filter-pill:hover{border-color:var(--ink-faint);color:var(--ink)}
.filter-pill.on{background:rgba(217,164,65,.14);border-color:var(--amber);color:var(--amber-bright)}

.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:14px}
.ent-card{
  background:linear-gradient(160deg,var(--bg-raised),var(--bg-panel));border:1px solid var(--line);
  border-radius:8px;padding:15px 16px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;
}
.ent-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--type-color,var(--amber));opacity:.7}
.ent-card:hover{border-color:var(--amber);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.ent-card .ec-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:7px}
.ent-card .ec-type{font-family:var(--mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--type-color,var(--amber))}
.ent-card h3{font-size:19px;color:var(--ink);margin-bottom:5px;line-height:1.1}
.ent-card .ec-desc{font-size:12.5px;color:var(--ink-faint);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:32px}
.ent-card .ec-foot{display:flex;align-items:center;gap:8px;margin-top:11px;flex-wrap:wrap}
.ent-card .ec-rel{font-family:var(--mono);font-size:10px;color:var(--ink-faint)}

.empty{text-align:center;padding:70px 20px;color:var(--ink-faint)}
.empty .big{font-family:var(--serif);font-size:23px;color:var(--ink-dim);margin-bottom:8px}
.empty svg{width:54px;height:54px;opacity:.3;margin-bottom:18px}

/* ===== Detail / inspector fields ===== */
.field-group{margin-bottom:4px}
.detail-section{margin:18px 0}
.detail-section h4{font-size:13px;font-family:var(--mono);font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.detail-section h4::after{content:'';flex:1;height:1px;background:var(--line-soft)}
.rel-list{display:flex;flex-direction:column;gap:6px}
.rel-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg);border:1px solid var(--line-soft);border-radius:5px;font-size:12.5px}
.rel-row .rel-type{font-family:var(--mono);font-size:10px;color:var(--amber);min-width:78px}
.rel-row .rel-target{color:var(--ink);cursor:pointer;flex:1}
.rel-row .rel-target:hover{color:var(--amber-bright);text-decoration:underline}
.rel-row .rel-x{color:var(--ink-faint);width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:3px}
.rel-row .rel-x:hover{color:var(--crimson);background:var(--bg-hover)}
.tag-input-wrap{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:6px;border:1px solid var(--line);border-radius:5px;background:var(--bg)}
.tag{display:inline-flex;align-items:center;gap:5px;background:var(--bg-hover);border:1px solid var(--line);padding:2px 8px;border-radius:12px;font-size:11px;color:var(--ink-dim)}
.tag .x{cursor:pointer;color:var(--ink-faint)}
.tag .x:hover{color:var(--crimson)}
.tag-input-wrap input{border:none;background:none;width:auto;flex:1;min-width:80px;padding:2px}

/* ===== Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(8,6,3,.7);backdrop-filter:blur(3px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px;animation:fade .2s}
.modal-overlay.open{display:flex}
.modal{background:var(--bg-raised);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow);width:100%;max-width:560px;max-height:88vh;display:flex;flex-direction:column;animation:pop .25s cubic-bezier(.34,1.4,.64,1)}
.modal.wide{max-width:780px}
@keyframes pop{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:none}}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.modal-head h3{font-size:21px}
.modal-head .close{margin-left:auto;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--ink-faint)}
.modal-head .close:hover{background:var(--bg-hover);color:var(--ink)}
.modal-body{padding:18px 22px;overflow-y:auto}
.modal-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}

.type-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.type-opt{display:flex;flex-direction:column;align-items:center;gap:7px;padding:15px 10px;border:1px solid var(--line);border-radius:8px;transition:all .16s;text-align:center}
.type-opt:hover{border-color:var(--amber);background:var(--bg-hover)}
.type-opt svg{width:26px;height:26px;color:var(--to-color,var(--amber))}
.type-opt .tn{font-size:13px;color:var(--ink)}
.type-opt .td{font-size:10.5px;color:var(--ink-faint);line-height:1.3}

/* ===== Graph ===== */
.graph-wrap{position:relative;height:calc(100vh - 200px);min-height:480px;border:1px solid var(--line);border-radius:10px;background:radial-gradient(ellipse at center,var(--bg-raised),var(--bg));overflow:hidden}
#graphSvg{width:100%;height:100%;cursor:grab}
#graphSvg:active{cursor:grabbing}
.graph-node circle{cursor:pointer;transition:r .15s}
.graph-node text{font-family:var(--body);font-size:11px;fill:var(--ink-dim);pointer-events:none;text-anchor:middle}
.graph-node:hover text{fill:var(--ink)}
.graph-link{stroke:var(--line);stroke-width:1.5;opacity:.5}
.graph-link.hl{stroke:var(--amber);opacity:.9;stroke-width:2}
.graph-legend{position:absolute;top:14px;left:14px;background:rgba(28,24,18,.9);border:1px solid var(--line);border-radius:8px;padding:11px 14px;font-size:11px}
.graph-legend .lg-row{display:flex;align-items:center;gap:8px;margin:4px 0}
.graph-legend .lg-dot{width:10px;height:10px;border-radius:50%}
.graph-controls{position:absolute;top:14px;right:14px;display:flex;flex-direction:column;gap:6px}
.graph-controls button{width:34px;height:34px;background:rgba(28,24,18,.92);border:1px solid var(--line);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--ink-dim);font-size:18px}
.graph-controls button:hover{border-color:var(--amber);color:var(--amber)}

/* ===== Timeline ===== */
.tl-wrap{position:relative;padding:20px 0}
.tl-axis{position:relative;margin-left:140px;border-left:2px solid var(--line);padding-left:0}
.era-band{position:relative;margin-bottom:6px}
.era-head{display:flex;align-items:center;gap:10px;margin:22px 0 12px;margin-left:-140px}
.era-head .era-bar{width:128px;text-align:right;padding-right:12px;font-family:var(--serif);font-size:17px;color:var(--amber);font-weight:600}
.era-head .era-years{font-family:var(--mono);font-size:10px;color:var(--ink-faint)}
.tl-event{position:relative;margin-left:-140px;display:flex;gap:0;margin-bottom:9px;align-items:flex-start}
.tl-event .tl-date{width:128px;text-align:right;padding-right:20px;font-family:var(--mono);font-size:11px;color:var(--ink-dim);padding-top:9px;flex-shrink:0}
.tl-event .tl-node{position:absolute;left:128px;top:11px;width:13px;height:13px;border-radius:50%;background:var(--amber);border:2px solid var(--bg);transform:translateX(-6px);z-index:2}
.tl-event .tl-card{margin-left:24px;background:var(--bg-raised);border:1px solid var(--line);border-radius:7px;padding:11px 15px;flex:1;cursor:pointer;transition:all .16s}
.tl-event .tl-card:hover{border-color:var(--amber);transform:translateX(2px)}
.tl-event .tl-card h4{font-size:16px;color:var(--ink);margin-bottom:3px}
.tl-event .tl-card p{font-size:12.5px;color:var(--ink-faint)}
.tl-event .tl-card .tl-tags{margin-top:7px;display:flex;gap:6px;flex-wrap:wrap}

/* ===== Map ===== */
.map-stage{position:relative;height:calc(100vh - 210px);min-height:460px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#1a1610}
#mapCanvas{position:absolute;inset:0;cursor:crosshair}
.map-pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;z-index:5;transition:transform .15s}
.map-pin:hover{transform:translate(-50%,-100%) scale(1.15)}
.map-pin svg{width:26px;height:26px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}
.map-pin .pin-label{position:absolute;left:50%;top:100%;transform:translateX(-50%);white-space:nowrap;font-family:var(--serif);font-size:13px;color:var(--ink);background:rgba(20,17,13,.82);padding:1px 7px;border-radius:4px;margin-top:1px;pointer-events:none}
.map-hint{position:absolute;bottom:14px;left:14px;background:rgba(28,24,18,.9);border:1px solid var(--line);padding:8px 13px;border-radius:7px;font-size:11.5px;color:var(--ink-faint);max-width:280px}
.map-tools{position:absolute;top:14px;left:14px;display:flex;gap:7px;flex-wrap:wrap;max-width:60%}

/* ===== Consistency ===== */
.issue-card{display:flex;gap:13px;padding:14px 16px;border:1px solid var(--line);border-radius:8px;margin-bottom:11px;background:var(--bg-raised);transition:all .16s}
.issue-card:hover{border-color:var(--ink-faint)}
.issue-card .sev{width:7px;border-radius:4px;flex-shrink:0}
.issue-card.warn .sev{background:var(--amber)}
.issue-card.error .sev{background:var(--crimson)}
.issue-card.info .sev{background:var(--slate)}
.issue-card .ic-body{flex:1}
.issue-card .ic-title{font-size:15px;color:var(--ink);margin-bottom:3px;font-family:var(--serif);font-weight:600}
.issue-card .ic-desc{font-size:12.5px;color:var(--ink-dim)}
.issue-card .ic-refs{margin-top:7px;display:flex;gap:7px;flex-wrap:wrap}
.issue-card .ic-ref{font-family:var(--mono);font-size:10px;color:var(--amber);cursor:pointer;border:1px solid var(--line);padding:2px 8px;border-radius:11px}
.issue-card .ic-ref:hover{background:var(--bg-hover)}
.check-clean{text-align:center;padding:54px 20px;color:var(--sage)}
.check-clean svg{width:48px;height:48px;margin-bottom:14px}

/* ===== Systems / dashboard ===== */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:13px;margin-bottom:24px}
.stat-card{background:linear-gradient(160deg,var(--bg-raised),var(--bg-panel));border:1px solid var(--line);border-radius:9px;padding:17px 18px;position:relative;overflow:hidden}
.stat-card .sc-num{font-family:var(--serif);font-size:36px;font-weight:700;color:var(--amber);line-height:1}
.stat-card .sc-lab{font-size:11px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:6px}
.panel{background:var(--bg-raised);border:1px solid var(--line);border-radius:10px;padding:20px;margin-bottom:18px}
.panel h3{font-size:20px;margin-bottom:5px;display:flex;align-items:center;gap:10px}
.panel .panel-sub{font-size:12.5px;color:var(--ink-faint);font-style:italic;margin-bottom:16px}

.sys-card{border:1px solid var(--line);border-radius:8px;padding:14px 16px;margin-bottom:11px;background:var(--bg)}
.sys-card .sys-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.sys-card h4{font-size:16px;color:var(--ink)}
.lang-word-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin-top:10px}
.lang-word{display:flex;justify-content:space-between;gap:8px;padding:6px 10px;background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:5px;font-size:13px}
.lang-word .lw-con{font-family:var(--serif);color:var(--amber);font-style:italic}
.lang-word .lw-gloss{color:var(--ink-faint);font-size:11.5px}

.gen-tree{display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:12.5px}
.gen-node{padding:4px 0;color:var(--ink-dim);white-space:nowrap}
.gen-node .gn-name{color:var(--ink);cursor:pointer}
.gen-node .gn-name:hover{color:var(--amber)}

.econ-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--line-soft)}
.econ-bar{flex:1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden}
.econ-bar div{height:100%;background:linear-gradient(90deg,var(--amber-deep),var(--amber));border-radius:4px}
.econ-row .econ-val{font-family:var(--mono);font-size:11px;color:var(--ink-dim);width:46px;text-align:right}

/* generator output */
.gen-out{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.gen-out .go-word{padding:5px 12px;border:1px solid var(--line);border-radius:6px;font-family:var(--serif);font-size:16px;color:var(--amber);cursor:pointer;transition:all .15s}
.gen-out .go-word:hover{background:var(--bg-hover);border-color:var(--amber)}

/* misc */
.inline-link{color:var(--amber);cursor:pointer;border-bottom:1px dashed rgba(217,164,65,.4)}
.inline-link:hover{border-bottom-style:solid}
.muted{color:var(--ink-faint)}
.center{text-align:center}
.flex{display:flex}.gap{gap:10px}.wrap{flex-wrap:wrap}.aic{align-items:center}.jcb{justify-content:space-between}
.mt{margin-top:14px}.mb{margin-bottom:14px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.divider{height:1px;background:var(--line-soft);margin:18px 0}
.pill-toggle{display:inline-flex;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.pill-toggle button{padding:6px 13px;font-size:12px;color:var(--ink-dim);border-right:1px solid var(--line)}
.pill-toggle button:last-child{border-right:none}
.pill-toggle button.on{background:var(--amber-deep);color:#1a1408}
kbd{font-family:var(--mono);font-size:10px;background:var(--bg);border:1px solid var(--line);border-radius:3px;padding:1px 5px;color:var(--ink-dim)}
/* legacy single toast (kept for compatibility) */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--bg-raised);border:1px solid var(--amber);border-radius:8px;padding:12px 20px;font-size:13.5px;color:var(--ink);box-shadow:var(--shadow);z-index:300;transition:transform .3s cubic-bezier(.34,1.4,.64,1);display:flex;align-items:center;gap:10px}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast svg{width:17px;height:17px;color:var(--amber)}

/* ===== Notification stack ===== */
.note-stack{position:fixed;bottom:22px;right:22px;z-index:400;display:flex;flex-direction:column;gap:10px;max-width:360px;pointer-events:none}
.note{display:flex;align-items:flex-start;gap:11px;background:var(--bg-raised);border:1px solid var(--line);border-left-width:4px;border-radius:9px;padding:12px 14px;box-shadow:var(--shadow);font-size:13.5px;color:var(--ink);pointer-events:auto;transform:translateX(120%);opacity:0;transition:transform .32s cubic-bezier(.34,1.3,.64,1),opacity .32s ease}
.note.in{transform:translateX(0);opacity:1}
.note.out{transform:translateX(120%);opacity:0}
.note-ico{flex-shrink:0;width:19px;height:19px;display:inline-flex;margin-top:1px}
.note-ico svg{width:100%;height:100%}
.note-msg{flex:1;line-height:1.45}
.note-close{flex-shrink:0;width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);opacity:.7}
.note-close svg{width:13px;height:13px}
.note-close:hover{opacity:1;background:var(--bg-hover);color:var(--ink)}
.note-success{border-left-color:var(--success)} .note-success .note-ico{color:var(--success)}
.note-warn{border-left-color:var(--warn)} .note-warn .note-ico{color:var(--warn)}
.note-error{border-left-color:var(--error)} .note-error .note-ico{color:var(--error)}
.note-info{border-left-color:var(--info)} .note-info .note-ico{color:var(--info)}
@media(max-width:520px){.note-stack{left:14px;right:14px;max-width:none;bottom:14px}}

.note-editor{min-height:340px;line-height:1.75;font-size:15.5px;padding:18px 20px}
.note-editor:focus{border-color:var(--line)}
.atlas-detail-img{width:100%;border-radius:8px;border:1px solid var(--line);margin-bottom:12px}

@media print{body{overflow:visible}}
