/* Hero Forge — shared stylesheet.
   Forge theme: black canvas, burning-orange primary, molten-gold secondary. */

:root{
  --bg:#08060a;
  --panel:#0f0c08;
  --panel-2:#1a1610;
  --border:#332818;
  /* Primary accent — name preserved (--red) for API stability across call
     sites, but the hue is now burning orange. */
  --red:#f97316;
  --red-dk:#7c2d12;
  --red-rgb:249,115,22;
  /* Secondary accent: molten gold / amber. */
  --gold:#fbbf24;
  --gold-rgb:251,191,36;
  --text:#f7ebd6;
  --muted:#8b7a65;
  --good:#4ade80;
  --bad:#ef4444;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Roboto',system-ui,sans-serif;min-height:100vh}
body{background:
  radial-gradient(1200px 600px at 20% -10%,rgba(249,115,22,.18),transparent 60%),
  radial-gradient(900px 500px at 120% 10%,rgba(251,191,36,.08),transparent 60%),
  #0f0f10;
}
a{color:var(--gold);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1280px;margin:0 auto;padding:24px}

/* ===== topbar (compact) ===== */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:8px 16px;border:1px solid var(--border);border-radius:10px;
  background:linear-gradient(180deg,rgba(249,115,22,.15),rgba(0,0,0,0)),#141416;
  margin-bottom:14px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand .mark{
  width:32px;height:32px;border-radius:8px;
  background:linear-gradient(135deg,var(--red),var(--gold));
  display:grid;place-items:center;font-family:'Roboto Condensed';font-weight:700;font-size:16px;color:#111;
  box-shadow:0 0 12px rgba(249,115,22,.35);
}
.brand h1{margin:0;font-family:'Roboto Condensed';font-size:17px;letter-spacing:2px;text-transform:uppercase;line-height:1.1}
.brand p{margin:0;color:var(--muted);font-size:11px;letter-spacing:.5px;line-height:1.2}

/* ===== buttons ===== */
.btn{
  background:var(--panel-2);border:1px solid var(--border);color:var(--text);
  padding:9px 16px;border-radius:8px;cursor:pointer;font-family:'Roboto Condensed';letter-spacing:1px;font-size:13px;
  text-transform:uppercase;transition:.12s;
}
.btn:hover{border-color:var(--red);background:#2a2a2e}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn.primary{background:var(--red);border-color:var(--red);color:#fff}
.btn.primary:hover{background:#fb923c}
.btn.ghost{background:transparent}
.btn.small{padding:5px 10px;font-size:11px}

/* ===== generic cards ===== */
.card{
  background:var(--panel);border:1px solid var(--border);border-radius:10px;
  padding:16px;margin-bottom:20px;
}
.card h2{
  font-family:'Roboto Condensed';font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--red);
  margin:0 0 12px;padding-bottom:10px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.card h2::before{content:"";width:8px;height:8px;background:var(--red);border-radius:50%;box-shadow:0 0 10px var(--red)}

/* ===== wizard stepper ===== */
.stepper{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}
.step{
  flex:1 1 120px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--panel);
  font-family:'Roboto Condensed';font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);
  cursor:pointer;transition:.12s;position:relative;min-width:90px;text-align:center;
}
.step .n{display:block;font-size:18px;font-weight:700;color:#3a3a3d;margin-bottom:3px}
.step.active{background:linear-gradient(180deg,rgba(249,115,22,.25),var(--panel));border-color:var(--red);color:#fff}
.step.active .n{color:var(--red)}
.step.done .n{color:var(--gold)}
.step.done::after{content:"✓";position:absolute;right:8px;top:8px;color:var(--good);font-size:12px;font-weight:700}

/* ===== forms ===== */
label.field{display:block;margin-bottom:12px}
label.field .lbl{display:block;color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}
input[type="text"],input[type="number"],select,textarea{
  width:100%;background:#141416;color:var(--text);border:1px solid var(--border);border-radius:6px;
  padding:8px 10px;font-family:inherit;font-size:14px;transition:border-color .12s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--red)}

/* ===== pick-list (race/class cards) ===== */
.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.pick{
  background:var(--panel);border:2px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;
  transition:.12s;position:relative;
}
.pick:hover{border-color:var(--red);transform:translateY(-2px)}
.pick.selected{border-color:var(--gold);background:linear-gradient(180deg,rgba(251,191,36,.08),var(--panel))}
.pick.selected::after{content:"✓";position:absolute;top:8px;right:10px;color:var(--gold);font-size:16px;font-weight:700}
.pick .nm{font-family:'Roboto Condensed';font-size:18px;font-weight:700;margin-bottom:4px}
.pick .sub{color:var(--muted);font-size:11px;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.pick .txt{color:#c6c6c9;font-size:12px;line-height:1.5}

/* ===== point-buy controls ===== */
.abilities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.abil-pb{
  background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center;
}
.abil-pb .lbl{color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}
.abil-pb .val{font-family:'Roboto Condensed';font-size:44px;font-weight:700;color:#fff;line-height:1;display:flex;align-items:center;justify-content:center;gap:6px}
.abil-pb .val .bump{
  width:32px;height:32px;border-radius:50%;background:var(--panel-2);border:1px solid var(--border);color:#fff;
  cursor:pointer;font-size:20px;display:grid;place-items:center;user-select:none;transition:.12s;
}
.abil-pb .val .bump:hover:not(:disabled){border-color:var(--red);background:var(--red-dk)}
.abil-pb .val .bump:disabled{opacity:.2;cursor:not-allowed}
.abil-pb .sub{color:var(--gold);font-size:12px;margin-top:4px;font-family:'Roboto Condensed'}
.abil-pb .final{color:var(--muted);font-size:11px;margin-top:6px}
.abil-pb .final b{color:#fff}

/* ===== character sheet banner (same language as zhavar.html) ===== */
.banner{
  position:relative;display:grid;grid-template-columns:190px 1fr auto;gap:24px;padding:20px;
  border:1px solid var(--border);border-radius:12px;overflow:hidden;
  background:linear-gradient(180deg,rgba(249,115,22,.25),rgba(0,0,0,0)),linear-gradient(180deg,#1a1a1c,#141416);
  margin-bottom:20px;
}
@media(max-width:980px){.banner{grid-template-columns:140px 1fr}}
.portrait{width:170px;height:220px;border-radius:10px;object-fit:cover;border:2px solid var(--red);background:#222;
  box-shadow:0 0 0 4px #0f0f10,0 10px 30px rgba(0,0,0,.6);}
.portrait.ph{display:grid;place-items:center;font-size:60px;color:#444}
.name h1{font-family:'Roboto Condensed',sans-serif;font-size:40px;margin:0;letter-spacing:1px;text-transform:uppercase}
.name h1 small{color:var(--muted);font-weight:400;font-size:14px;letter-spacing:2px;display:block;margin-bottom:4px;text-transform:uppercase}
.subline{color:var(--muted);margin-top:6px;font-size:14px}
.subline b{color:var(--text)}
.tags{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.tag{background:#2b2b2f;border:1px solid var(--border);padding:4px 10px;border-radius:30px;font-size:11px;color:#ddd;text-transform:uppercase;letter-spacing:1px}
.tag.red{background:var(--red-dk);border-color:var(--red)}

/* ===== reworked sheet banner — compact 3-col with HP tracker ===== */
.sheet-banner{
  display:grid;grid-template-columns:130px minmax(0,1fr) 220px;gap:16px;align-items:stretch;
  padding:14px;border:1px solid var(--border);border-radius:12px;margin-bottom:20px;
  background:linear-gradient(180deg,rgba(249,115,22,.18),rgba(0,0,0,0)),linear-gradient(180deg,#1a1a1c,#141416);
}
@media(max-width:760px){.sheet-banner{grid-template-columns:90px 1fr;grid-auto-rows:auto}
  .sheet-banner .sheet-hp{grid-column:1 / -1}
  .banner-stats{grid-template-columns:repeat(3,1fr)}}
.sheet-portrait-wrap{position:relative;width:100%;aspect-ratio:3/4;min-height:0}
.sheet-portrait{width:100%;height:100%;border-radius:10px;object-fit:cover;background:#222;
  border:2px solid var(--red);box-shadow:0 10px 24px rgba(0,0,0,.5);display:block;box-sizing:border-box}
.sheet-portrait.ph{display:grid;place-items:center;font-size:56px;color:#444}
.portrait-upload{
  position:absolute;bottom:6px;right:6px;width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.7);border:1px solid var(--border);display:grid;place-items:center;
  cursor:pointer;font-size:14px;transition:.15s;
}
.portrait-upload:hover{background:var(--red);border-color:var(--red);transform:scale(1.1)}

.sheet-id{min-width:0;display:flex;flex-direction:column;justify-content:space-between;gap:6px}
.sheet-id h1{font-family:'Roboto Condensed';font-size:28px;margin:0;letter-spacing:1px;text-transform:uppercase;line-height:1.05;word-break:break-word}
.sheet-id-line{color:#c6c6c9;margin-top:4px;font-size:13px;line-height:1.45}
.sheet-id-line b{color:var(--text)}
.sheet-id-line.muted{color:var(--muted);font-size:11px}

/* stats strip inside the banner (AC / Init / Speed / BAB / CMB) */
.banner-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;margin-top:8px}
.bs{
  background:#141416;border:1px solid var(--border);border-radius:8px;padding:6px 4px;
  text-align:center;transition:.1s;cursor:pointer;min-width:0;
}
.bs:hover{border-color:var(--red);transform:translateY(-1px)}
.bs .v{font-family:'Roboto Condensed';font-size:22px;font-weight:700;line-height:1;color:#fff}
.bs .v small{font-size:11px;color:var(--muted)}
.bs .l{color:var(--muted);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;margin-top:3px}
.bs .sub{color:#c6c6c9;font-size:10px;margin-top:2px;line-height:1.2}

/* Right column stacks HP on top + compact Active Effects below */
.sheet-right{display:flex;flex-direction:column;gap:8px;min-width:0}
.sheet-hp{
  background:#141416;border:1px solid var(--border);border-radius:10px;padding:8px 10px;
  display:flex;flex-direction:column;gap:4px;min-width:0;
}
.sheet-hp-value{font-family:'Roboto Condensed';font-size:22px;font-weight:700;text-align:center;line-height:1;display:flex;align-items:baseline;justify-content:center;gap:6px}
.sheet-hp-tag{font-size:9px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-left:auto}
.temp-hp{
  display:inline-block;margin-left:6px;font-size:12px;padding:1px 6px;border-radius:8px;
  background:linear-gradient(180deg,rgba(251,191,36,.35),rgba(251,191,36,.15));
  border:1px solid var(--gold);color:var(--gold);vertical-align:middle;
}
/* HP slider — native range element skinned as a gradient bar + thumb */
.hp-slider{
  -webkit-appearance:none;appearance:none;width:100%;height:14px;margin:4px 0;
  background:linear-gradient(90deg,var(--red) 0%,var(--red) var(--hp-pct,100%),#2b2b2f var(--hp-pct,100%),#2b2b2f 100%);
  border-radius:7px;border:1px solid var(--border);cursor:pointer;outline:none;padding:0;
}
.hp-slider:focus{outline:none}
.hp-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;
  background:linear-gradient(180deg,#fff,#d4c7a6);border:2px solid var(--red);
  box-shadow:0 0 8px rgba(var(--red-rgb),.6);cursor:grab;transition:.1s;
}
.hp-slider:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.15)}
.hp-slider::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(180deg,#fff,#d4c7a6);border:2px solid var(--red);
  box-shadow:0 0 8px rgba(var(--red-rgb),.6);cursor:grab;
}
.sheet-hp-controls{display:flex;gap:4px;justify-content:stretch;margin-top:2px}
.sheet-hp-controls .btn{flex:1;padding:5px 0;font-size:11px;min-width:0}
.sheet-xp{display:flex;justify-content:space-between;border-top:1px solid var(--border);padding-top:6px;margin-top:2px}
.sheet-xp .lbl{color:var(--muted);font-size:10px;letter-spacing:2px;text-transform:uppercase}
.sheet-xp .val{font-family:'Roboto Condensed';color:var(--gold);font-weight:700;font-size:14px}

/* ===== stats row ===== */
.stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px}
@media(max-width:980px){.stats-row{grid-template-columns:repeat(3,1fr)}}
.stat{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center;transition:.12s}
.stat:hover{border-color:var(--red);transform:translateY(-2px)}
.stat .big{font-family:'Roboto Condensed';font-size:36px;font-weight:700;line-height:1}
.stat .lbl{color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-top:6px}
.stat .sub{color:#c6c6c6;font-size:12px;margin-top:8px;display:flex;justify-content:space-around}
.stat .sub b{color:var(--text);display:block;font-family:'Roboto Condensed';font-size:16px}

/* ===== ability scores grid ===== */
.abilities{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.abil{background:#141416;border:1px solid var(--border);border-radius:10px;padding:8px 4px;text-align:center;transition:.12s;overflow:hidden;min-width:0}
.abil:hover{border-color:var(--gold)}
.abil .name{color:var(--muted);font-size:9px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.abil .mod{font-family:'Roboto Condensed';font-size:26px;font-weight:700;line-height:1;margin:3px 0}
.abil .score{display:inline-block;background:var(--panel-2);border:1px solid var(--border);border-radius:20px;padding:1px 8px;font-size:11px;color:#bbb}

/* ===== saves ===== */
.saves{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.save{background:#141416;border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center}
.save .lbl{color:var(--muted);font-size:10px;letter-spacing:2px;text-transform:uppercase}
.save .v{font-family:'Roboto Condensed';font-size:26px;font-weight:700;color:var(--gold)}

/* ===== skills ===== */
.skills{columns:2;column-gap:20px}
.skill{break-inside:avoid;padding:6px 8px;display:flex;justify-content:space-between;border-bottom:1px dashed #262628;font-size:13px;border-radius:4px;position:relative}
.skill:hover{background:#202023}
.skill .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#3a3a3d;margin-right:6px;vertical-align:middle}
.skill.trained .dot{background:var(--gold)}
.skill.class .dot{background:var(--red)}
.skill .v{font-family:'Roboto Condensed';color:var(--gold);font-weight:700}

/* ===== tabs (for sheet tabs and feat categories) ===== */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}
.tab{padding:10px 16px;color:var(--muted);cursor:pointer;font-family:'Roboto Condensed';font-size:13px;letter-spacing:2px;
  text-transform:uppercase;border:1px solid transparent;border-bottom:none;border-radius:8px 8px 0 0;transition:.12s}
.tab:hover{color:#ddd;background:rgba(255,255,255,.03)}
.tab.active{color:#fff;background:var(--panel-2);border-color:var(--border);border-bottom:1px solid var(--panel-2);position:relative;top:1px}
.tab.active::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--red)}

/* ===== tooltip ===== */
.tooltip{
  position:fixed;pointer-events:none;z-index:10000;
  background:linear-gradient(180deg,#141416,#0f0f10);
  border:1px solid var(--red);border-radius:10px;
  padding:14px 16px;max-width:380px;
  box-shadow:0 20px 60px rgba(0,0,0,.8);
  font-size:13px;line-height:1.55;color:#ddd;
  opacity:0;transform:translateY(6px);transition:opacity .14s ease,transform .14s ease;
}
.tooltip.show{opacity:1;transform:translateY(0)}
body:has(.modal-backdrop) .tooltip{opacity:0 !important;pointer-events:none}
.tooltip h4{margin:0 0 6px;font-family:'Roboto Condensed';color:var(--red);font-size:15px;letter-spacing:2px;text-transform:uppercase;border-bottom:1px solid var(--border);padding-bottom:6px}
.tooltip .meta{color:var(--gold);font-size:10px;margin:4px 0 8px;letter-spacing:2px;text-transform:uppercase}
.tooltip .row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;border-bottom:1px dashed #26262a}
.tooltip .row:last-child{border-bottom:0}
.tooltip .row span:first-child{color:var(--muted)}
.tooltip .row span:last-child{color:#fff;font-family:'Roboto Condensed';font-weight:700}
.tooltip p{margin:6px 0 0;color:#c6c6c9;font-size:12px}

/* ===== roll flash ===== */
.roll-flash{
  position:fixed;z-index:20000;pointer-events:none;
  left:50%;top:30%;transform:translate(-50%,-50%);
  background:linear-gradient(180deg,#141416,#0a0a0b);
  border:2px solid var(--red);border-radius:14px;
  padding:18px 32px;min-width:300px;
  box-shadow:0 20px 80px rgba(0,0,0,.8),0 0 60px rgba(249,115,22,.35);
  opacity:0;animation:rollin .3s cubic-bezier(.2,1.2,.4,1) forwards;
}
.roll-flash.nat20{border-color:var(--good);box-shadow:0 20px 80px rgba(0,0,0,.8),0 0 80px rgba(124,207,107,.55)}
.roll-flash.nat1{border-color:var(--bad)}
.roll-flash .lbl{color:var(--muted);font-size:11px;letter-spacing:3px;text-transform:uppercase;text-align:center}
.roll-flash .crit{color:var(--good);font-family:'Roboto Condensed';font-size:13px;letter-spacing:3px;text-transform:uppercase;text-align:center;margin-top:2px}
.roll-flash.nat1 .crit{color:var(--bad)}
.roll-flash .calc{color:#ddd;font-family:'Roboto Condensed';font-size:18px;text-align:center;margin:8px 0}
.roll-flash .calc .die{background:#2b2b2f;border:1px solid var(--border);border-radius:6px;padding:3px 12px;margin:0 3px;font-weight:700}
.roll-flash.nat20 .calc .die{background:var(--good);color:#000;border-color:var(--good)}
.roll-flash.nat1 .calc .die{background:var(--bad);color:#fff}
.roll-flash .total{font-family:'Roboto Condensed';font-size:56px;font-weight:700;color:var(--gold);text-align:center;line-height:1}
.roll-flash.nat20 .total{color:var(--good)}
.roll-flash.nat1 .total{color:var(--bad)}
.roll-flash.fade{animation:rollout .3s ease-in forwards}
@keyframes rollin{0%{opacity:0;transform:translate(-50%,-40%) scale(.6)}100%{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes rollout{from{opacity:1}to{opacity:0;transform:translate(-50%,-62%) scale(1.08)}}

/* ===== roll log ===== */
.roll-log{
  position:fixed;bottom:20px;right:20px;z-index:500;width:300px;
  background:var(--panel);border:1px solid var(--border);border-radius:10px;
  overflow:hidden;transform:translateY(calc(100% - 42px));transition:transform .22s ease;
  box-shadow:0 10px 30px rgba(0,0,0,.5);
}
.roll-log.open{transform:translateY(0)}
.roll-log .hdr{
  padding:12px 14px;background:linear-gradient(90deg,rgba(249,115,22,.25),var(--panel-2));
  color:#fff;font-family:'Roboto Condensed';font-size:12px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--border);
}
.roll-log .hdr::after{content:"▲";color:var(--red);transition:transform .22s;font-size:10px}
.roll-log.open .hdr::after{transform:rotate(180deg)}
.roll-log .list{max-height:340px;overflow-y:auto;padding:4px}
.roll-log .list:empty::before{content:"Click anything highlighted to roll.";color:#555;font-size:12px;font-style:italic;padding:16px;display:block;text-align:center}
.roll-log .entry{padding:7px 10px;border-bottom:1px dashed #26262a;font-size:12px;color:#ccc;display:flex;justify-content:space-between;align-items:center;gap:6px}
.roll-log .entry:last-child{border-bottom:0}
.roll-log .entry .nm{color:#ddd;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.roll-log .entry .formula{color:#777;font-size:10px;font-family:'Roboto Condensed'}
.roll-log .entry .total{font-family:'Roboto Condensed';font-weight:700;color:var(--gold);font-size:18px;min-width:34px;text-align:right}
.roll-log .entry.nat20 .total{color:var(--good)}
.roll-log .entry.nat1 .total{color:var(--bad)}

/* ===== toast ===== */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--panel-2);border:1px solid var(--border);padding:10px 16px;border-radius:8px;z-index:999;transition:.22s;max-width:90vw;font-size:13px}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ===== list items with badges ===== */
.feat-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--panel);cursor:pointer;
  transition:.12s;margin-bottom:6px;
}
.feat-row:hover{border-color:var(--red)}
.feat-row.disabled{opacity:.35;cursor:not-allowed}
.feat-row.disabled:hover{border-color:var(--border)}
.feat-row.picked{border-color:var(--gold);background:linear-gradient(90deg,rgba(251,191,36,.08),var(--panel))}
.feat-row .nm{font-family:'Roboto Condensed';font-weight:700}
.feat-row .cat{color:var(--red);font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-left:8px}
.feat-row .reason{color:var(--bad);font-size:11px;margin-left:8px}

.pill{display:inline-block;padding:2px 8px;border-radius:20px;background:#2b2b2f;border:1px solid var(--border);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:#ccc}
.pill.gold{background:var(--gold);color:#111;border-color:var(--gold)}
.pill.red{background:var(--red);color:#fff;border-color:var(--red)}
.pill.bad{color:var(--bad);background:transparent;border-color:var(--bad)}
[data-tt],[data-tt-html]{cursor:help}
/* Rollable elements get a d20 cursor instead of the default question-mark. */
[data-roll]{
  cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><polygon points='12,2 22,9 18,21 6,21 2,9' fill='%23fbbf24' stroke='%23111' stroke-width='1.5'/><text x='12' y='15' font-size='8' font-family='Arial' fill='%23111' text-anchor='middle' font-weight='bold'>20</text></svg>") 12 12, pointer;
}

/* ===== active effects card ===== */
.effects-card h2{display:flex;align-items:center}
.effects-card.compact{padding:8px 10px;margin:0}
.effects-card.compact h2{font-size:10px;letter-spacing:2px;margin:0 0 6px;padding:0 0 4px;border-bottom:1px solid var(--border)}
.effects-card.compact h2::before{width:6px;height:6px}
.effects-card.compact .effect-chip{font-size:10px;padding:2px 6px}
.effects-card.compact .effects-summary{font-size:9px;padding:3px 6px;margin:4px 0 2px}
.effects-card.compact summary{font-size:10px}
.effects-card.compact .effect-list{max-height:160px}
.effects-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.effect-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;border-radius:16px;font-size:12px;font-weight:600;
  background:linear-gradient(180deg,rgba(251,191,36,.25),rgba(251,191,36,.1));
  border:1px solid var(--gold);color:#ffe9a8;cursor:pointer;transition:.12s;
}
.effect-chip:hover{filter:brightness(1.2)}
.effect-chip.condition{
  background:linear-gradient(180deg,rgba(217,74,74,.25),rgba(217,74,74,.1));
  border-color:var(--bad);color:#ffbfbf;
}
.effect-chip.bad{background:transparent;border-color:var(--bad);color:var(--bad)}
.effect-chip .x{
  display:inline-grid;place-items:center;width:16px;height:16px;border-radius:50%;
  background:rgba(0,0,0,.3);font-size:14px;line-height:1;color:#fff;border:none;cursor:pointer;
}
.effect-chip .x:hover{background:var(--bad)}
.effects-summary{color:var(--muted);font-size:11px;margin:6px 0 4px;padding:6px 10px;
  background:#141416;border-radius:6px;font-family:'Roboto Condensed';letter-spacing:1px}
.effect-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}
.effect-row{
  display:flex;justify-content:space-between;align-items:center;gap:6px;
  padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:#141416;
  cursor:pointer;font-size:12px;transition:.1s;
}
.effect-row:hover{border-color:var(--gold);background:#1b1b1d}
.effect-row.cond:hover{border-color:var(--bad)}
.effect-row.picked{border-color:var(--gold);background:linear-gradient(90deg,rgba(251,191,36,.15),#141416)}
.effect-row.cond.picked{border-color:var(--bad);background:linear-gradient(90deg,rgba(217,74,74,.15),#141416)}
.effect-row .nm{font-family:'Roboto Condensed';font-weight:600}
.effect-row .src{color:var(--muted);font-size:10px;letter-spacing:1px;text-transform:uppercase}

/* ===== spell / power cards on the sheet ===== */
.cast-card{
  background:#141416;border:1px solid var(--border);border-radius:6px;
  padding:10px 12px;display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;font-size:13px;cursor:pointer;
  transition:.12s;
}
.cast-card:hover{border-color:var(--red);transform:translateY(-1px)}
.cast-card.on{
  background:linear-gradient(90deg,rgba(251,191,36,.15),#141416);
  border-color:var(--gold);box-shadow:0 0 12px rgba(251,191,36,.25);
}
.cast-name{font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cast-tags{display:flex;flex-wrap:wrap;gap:3px;justify-self:end}
.cast-dc{color:var(--red);font-family:'Roboto Condensed';font-size:12px;font-weight:700}
.mod-tag{
  display:inline-block;font-size:9px;letter-spacing:1px;text-transform:uppercase;
  padding:2px 7px;border-radius:10px;background:#2b2b2f;color:#bbb;border:1px solid var(--border);
  font-family:'Roboto Condensed';font-weight:600;
}
.mod-tag.def{background:rgba(124,207,107,.15);color:#9ccf8b;border-color:#3d6b35}
.mod-tag.off{background:rgba(249,115,22,.18);color:#e6a3a3;border-color:var(--red-dk)}
.mod-tag.abl{background:rgba(251,191,36,.15);color:#e4cb7a;border-color:#9a7b1c}
.mod-tag.bad{background:rgba(217,74,74,.2);color:#f0b5b5;border-color:var(--bad)}
.mod-tag.time{background:rgba(120,160,220,.15);color:#aac6e8;border-color:#3a567e}

/* ===== modal / cast dialog ===== */
.modal-backdrop{
  position:fixed;inset:0;z-index:5000;display:grid;place-items:center;
  background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
  animation:modalFade .15s ease;padding:20px;
}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal{
  background:linear-gradient(180deg,#1a1a1c,#141416);
  border:1px solid var(--red);border-radius:12px;
  box-shadow:0 30px 80px rgba(0,0,0,.8),0 0 60px rgba(249,115,22,.25);
  padding:18px 20px;width:min(560px,95vw);max-height:90vh;overflow-y:auto;
  animation:modalPop .2s cubic-bezier(.2,1.2,.4,1);display:flex;flex-direction:column;
}
.modal.modal-lg{
  width:80vw;height:80vh;max-width:1200px;max-height:90vh;
}
@keyframes modalPop{from{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:none}}
.modal-hdr{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:12px;flex-shrink:0}
.modal-ftr{display:flex;justify-content:flex-end;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border);flex-shrink:0}
.modal-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:24px;flex:1 1 auto;min-height:0;overflow:hidden}
.modal-left{display:flex;flex-direction:column;overflow-y:auto;padding-right:4px}
.modal-right{background:#0f0f10;border:1px solid var(--border);border-radius:10px;padding:14px 18px;overflow-y:auto}
.spell-stats{display:grid;grid-template-columns:1fr 1fr;gap:4px 18px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.spell-stats .row{display:flex;justify-content:space-between;gap:10px;font-size:12px;padding:3px 0}
.spell-stats .row span:first-child{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:10px;align-self:center}
.spell-stats .row span:last-child{color:#fff;font-family:'Roboto Condensed';font-weight:600;text-align:right}
.spell-short{color:var(--gold);font-size:13px;font-style:italic;margin:0 0 10px;line-height:1.5}
.spell-desc{color:#d5d5d8;font-size:13px;line-height:1.6}
.spell-desc p{margin:0 0 10px}
.spell-desc p:last-child{margin-bottom:0}
.spell-desc b{color:var(--red)}
@media(max-width:900px){
  .modal.modal-lg{width:95vw;height:90vh}
  .modal-body{grid-template-columns:1fr;gap:14px;overflow-y:auto}
  .modal-left,.modal-right{overflow:visible}
}

/* ===== augment panel inside cast dialog ===== */
.augment-box{
  background:linear-gradient(180deg,rgba(249,115,22,.08),rgba(251,191,36,.05));
  border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:14px;
}
.augment-hdr{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:10px;font-size:11px}
.augment-hdr .tag.gold{background:rgba(251,191,36,.15);border-color:var(--gold);color:var(--gold)}
.augment-hdr .tag.bad{background:rgba(217,74,74,.2);border-color:var(--bad);color:var(--bad)}
.augment-rules{font-size:12px;color:#c6c6c9;background:#141416;border-radius:6px;padding:8px 10px;margin-bottom:10px;line-height:1.5}
.augment-rules .rule{padding:2px 0}
.augment-slider{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.augment-slider label{flex:1;display:block}
.augment-slider input[type="range"]{
  width:100%;margin-top:4px;accent-color:var(--red);
}
.augment-max-btn{display:flex;gap:4px}
.metapsionic-row{margin-top:10px}
.meta-chip{
  background:var(--panel-2);border:1px solid var(--border);color:var(--text);
  padding:5px 10px;border-radius:16px;font-size:11px;cursor:pointer;
  font-family:'Roboto Condensed';letter-spacing:1px;text-transform:uppercase;
  transition:.1s;
}
.meta-chip:hover{border-color:var(--red)}
.meta-chip.on{background:var(--red-dk);border-color:var(--red);color:#fff;box-shadow:0 0 10px rgba(249,115,22,.4)}
.meta-chip.disabled,.meta-chip:disabled{opacity:.3;cursor:not-allowed}
.augment-bonus{
  margin-top:12px;padding:8px 12px;border-radius:6px;font-size:12px;
  background:rgba(124,207,107,.12);border:1px solid var(--good);color:#c0e9b5;
}

.mod-list{display:flex;flex-direction:column;gap:6px}
.mod-row{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr) 64px 32px;gap:8px;align-items:center;
  background:#141416;border:1px solid var(--border);border-radius:8px;padding:6px 8px;
  transition:.1s;
}
.mod-row:hover{border-color:var(--gold)}
.mod-row .check{display:flex;justify-content:center;align-items:center}
.mod-row select,.mod-row input[type="number"]{
  background:#0f0f10;border:1px solid var(--border);color:var(--text);
  border-radius:6px;padding:6px 8px;font-size:12px;width:100%;
}
.mod-row input[type="number"]{font-family:'Roboto Condensed';font-weight:700;color:var(--gold);text-align:center}
.mod-row .btn{border:none;background:transparent;color:var(--muted);padding:4px}
.mod-row .btn:hover{color:var(--bad)}

/* ================== actions / attack rows ================== */
.actions-heading{
  font-family:'Roboto Condensed';color:var(--red);letter-spacing:2px;
  text-transform:uppercase;font-size:13px;margin:0 0 10px;
}
.action-row{
  padding:10px 12px;background:#141416;border:1px solid var(--border);
  border-radius:8px;margin-bottom:6px;
  display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;
}
.action-row.out-of-ammo{opacity:.55}
.action-hdr b{font-family:'Roboto Condensed';font-size:14px;color:#f7ebd6}
.action-hdr .meta{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.action-chips{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}
.atk-chip,.dmg-chip,.ammo-chip{
  font-family:'Roboto Condensed';font-weight:700;font-size:12px;
  padding:3px 8px;border-radius:4px;border:1px solid var(--border);
  background:#1a1a1c;cursor:pointer;user-select:none;
  transition:.1s;
}
.atk-chip{color:var(--gold)}
.atk-chip:hover{background:rgba(251,191,36,.18);border-color:var(--gold)}
.dmg-chip{color:var(--red)}
.dmg-chip:hover{background:rgba(249,115,22,.18);border-color:var(--red)}
.ammo-chip{color:var(--muted);cursor:default;background:transparent;border-color:transparent}
.ammo-chip.empty{color:var(--bad)}

/* ================== consumables ================== */
.consumable-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px;
}
.consumable{
  background:#141416;border:1px solid var(--border);border-radius:8px;
  padding:8px 10px;display:flex;flex-direction:column;gap:4px;
}
.consumable .cname{font-family:'Roboto Condensed';font-weight:700;font-size:12px;color:#f7ebd6}
.consumable .cmeta{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.consumable .btn{margin-top:4px;align-self:flex-start;font-size:11px;padding:3px 8px}

/* ================== encumbrance bar ================== */
.encumbrance-bar{
  height:10px;width:100%;margin:8px 0 4px;border-radius:5px;
  background:#1a1a1c;border:1px solid var(--border);
  position:relative;overflow:hidden;
}
.encumbrance-bar::before{
  content:"";position:absolute;inset:0;
  background:var(--enc-col,linear-gradient(90deg,var(--good),#84cc16));
  width:var(--enc-pct,0%);transition:width .25s ease, background .2s ease;
}
.enc-ticks{
  display:flex;justify-content:space-between;font-size:10px;
  color:var(--muted);letter-spacing:1px;text-transform:uppercase;
}
.warn-pill{
  background:rgba(251,191,36,.12);color:var(--gold);
  border:1px solid rgba(251,191,36,.4);border-radius:6px;
  padding:6px 10px;font-size:12px;margin-top:10px;
}

/* ================== landing: user chip + public gallery thumbs ================== */
.user-chip{
  display:flex;align-items:center;gap:8px;
  padding:4px 8px 4px 4px;border:1px solid var(--border);border-radius:999px;
  background:#141416;
}
.user-chip img{
  width:28px;height:28px;border-radius:50%;display:block;
}
.user-chip .avatar-fallback{
  width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  background:var(--red);color:#fff;font-weight:700;font-size:14px;
}
.user-chip .user-name{font-size:12px;color:#ddd;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.pick-thumb{
  display:block;width:100%;height:120px;object-fit:cover;border-radius:6px;margin-bottom:8px;
  border:1px solid var(--border);background:#0a0a0a;
}

/* Card with portrait on the right.  The .pick itself is a grid so the image
 * stretches floor-to-ceiling on the right half; card body lives on the left. */
.pick-with-portrait{
  display:grid;grid-template-columns:1fr 120px;gap:12px;align-items:stretch;
  padding:0;overflow:hidden;
}
.pick-with-portrait .pick-body{
  padding:14px 14px 14px 16px;min-width:0;
}
.pick-with-portrait .pick-portrait{
  width:120px;height:100%;object-fit:cover;display:block;
  border-left:1px solid var(--border);background:#0a0a0a;
}

.view-only-chip{
  display:inline-block;background:rgba(251,191,36,.12);color:var(--gold);
  border:1px solid rgba(251,191,36,.4);border-radius:999px;
  padding:2px 10px;font-size:11px;letter-spacing:2px;margin-left:10px;vertical-align:middle;
}

.visibility-select{
  background:#141416;color:var(--text);border:1px solid var(--border);
  border-radius:6px;padding:6px 10px;font-size:12px;font-family:inherit;cursor:pointer;
}
.visibility-select:hover{border-color:var(--gold)}

.migrate-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:1000;
  background:var(--panel-2);border-top:2px solid var(--gold);
  padding:14px 20px;display:flex;gap:20px;align-items:center;justify-content:space-between;
  box-shadow:0 -8px 24px rgba(0,0,0,.5);
}
.migrate-banner .migrate-copy{font-size:13px;color:#ddd;flex:1}
.migrate-banner .migrate-copy b{display:block;color:var(--gold);font-family:'Roboto Condensed';font-size:14px;margin-bottom:2px;letter-spacing:1px}
.migrate-banner .migrate-actions{display:flex;gap:8px}

/* ================== landing: marketing page ================== */

.section-title{
  font-family:'Roboto Condensed';font-size:13px;letter-spacing:4px;text-transform:uppercase;
  color:var(--red);margin:28px 0 14px;padding-bottom:10px;
  border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;
}
.section-title::before{content:"";width:8px;height:8px;background:var(--red);border-radius:50%;box-shadow:0 0 10px var(--red)}

/* --- Hero --- */
.hero{
  position:relative;overflow:hidden;
  border:1px solid var(--border);border-radius:14px;
  padding:48px 32px 36px;margin-bottom:28px;
  background:linear-gradient(180deg,#141416,#0f0c08);
  isolation:isolate;
}
.hero-bg{
  position:absolute;inset:-20%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 70% at 15% 20%,rgba(249,115,22,.35),transparent 70%),
    radial-gradient(50% 60% at 85% 100%,rgba(251,191,36,.22),transparent 70%),
    radial-gradient(40% 50% at 50% 120%,rgba(249,115,22,.18),transparent 70%);
  animation:heroGlow 16s ease-in-out infinite alternate;
}
@keyframes heroGlow{
  from{transform:translate3d(0,0,0) scale(1)}
  to{transform:translate3d(-2%,1%,0) scale(1.04)}
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    repeating-linear-gradient(120deg,rgba(249,115,22,.03) 0 2px,transparent 2px 8px);
  mask-image:linear-gradient(180deg,black 30%,transparent 100%);
  -webkit-mask-image:linear-gradient(180deg,black 30%,transparent 100%);
}
.hero-inner{max-width:820px;margin:0 auto;text-align:center;position:relative;z-index:1}
.hero-eyebrow{
  display:inline-block;padding:4px 12px;border-radius:999px;
  background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.4);
  color:var(--gold);font-family:'Roboto Condensed';font-size:11px;letter-spacing:3px;
  text-transform:uppercase;margin-bottom:18px;
}
.hero-title{
  font-family:'Roboto Condensed';font-weight:700;
  font-size:clamp(40px,7vw,74px);line-height:1.02;letter-spacing:1px;
  text-transform:uppercase;margin:0 0 16px;color:#fff;
  text-shadow:0 4px 30px rgba(249,115,22,.35);
}
.hero-accent{
  color:var(--red);
  background:linear-gradient(180deg,#ffb077,#f97316 60%,#c2410c);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-accent2{
  background:linear-gradient(180deg,#fde68a,#fbbf24 60%,#b45309);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-sub{
  color:#d0c6b3;font-size:17px;line-height:1.6;max-width:640px;margin:0 auto 28px;
}
.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.btn.lg{
  padding:14px 22px;font-size:14px;border-radius:10px;
  display:inline-flex;align-items:center;gap:10px;
}
.btn.primary.lg{
  background:linear-gradient(180deg,#fb923c,#ea580c);border-color:#c2410c;
  box-shadow:0 8px 28px rgba(249,115,22,.35),inset 0 1px 0 rgba(255,255,255,.2);
}
.btn.primary.lg:hover{background:linear-gradient(180deg,#fdba74,#f97316);transform:translateY(-1px)}
.g-icon{
  display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;
  background:#fff;color:#444;font-weight:700;font-family:'Roboto Condensed';font-size:13px;
}
.hero-badges{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;
  max-width:640px;margin:0 auto;
}
@media(max-width:640px){.hero-badges{grid-template-columns:repeat(2,1fr)}}
.hero-badge{
  padding:10px 12px;border:1px solid var(--border);border-radius:10px;
  background:rgba(20,20,22,.6);backdrop-filter:blur(2px);
  display:flex;flex-direction:column;gap:2px;align-items:flex-start;
}
.hero-badge b{font-family:'Roboto Condensed';color:var(--gold);font-size:15px;letter-spacing:1px}
.hero-badge span{color:var(--muted);font-size:11px;letter-spacing:1px;text-transform:uppercase}

.hero-strip{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  margin-top:36px;opacity:.55;
  mask-image:linear-gradient(90deg,transparent,black 20%,black 80%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,black 20%,black 80%,transparent);
}
.hero-strip img{
  width:58px;height:78px;object-fit:cover;border-radius:8px;
  border:1px solid var(--border);filter:grayscale(.2) saturate(.9);
}

/* --- Feature grid --- */
.features{margin-bottom:8px}
.feature-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;
  margin-bottom:24px;
}
.feature-card{
  background:var(--panel);border:1px solid var(--border);border-radius:12px;
  padding:18px 18px 16px;transition:.15s;position:relative;overflow:hidden;
}
.feature-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:2px;
  background:linear-gradient(90deg,var(--red),var(--gold));
  opacity:0;transition:.15s;
}
.feature-card:hover{transform:translateY(-2px);border-color:var(--red)}
.feature-card:hover::before{opacity:1}
.feature-icon{
  display:inline-grid;place-items:center;width:40px;height:40px;border-radius:10px;
  background:linear-gradient(180deg,rgba(249,115,22,.2),rgba(251,191,36,.05));
  border:1px solid rgba(249,115,22,.4);font-size:20px;margin-bottom:10px;
}
.feature-card h3{
  font-family:'Roboto Condensed';font-size:15px;letter-spacing:2px;text-transform:uppercase;
  margin:0 0 6px;color:#f7ebd6;
}
.feature-card p{color:#c6c6c9;font-size:13px;line-height:1.6;margin:0}

/* --- How it works --- */
.how-it-works{margin-bottom:8px}
.how-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;
}
@media(max-width:860px){.how-grid{grid-template-columns:1fr}}
.how-step{
  background:var(--panel);border:1px solid var(--border);border-radius:12px;
  padding:22px 20px;position:relative;
}
.how-num{
  position:absolute;top:-14px;left:20px;
  display:grid;place-items:center;width:36px;height:36px;border-radius:50%;
  background:linear-gradient(180deg,#fb923c,#ea580c);color:#fff;
  font-family:'Roboto Condensed';font-weight:700;font-size:18px;
  box-shadow:0 6px 20px rgba(249,115,22,.4);border:2px solid var(--bg);
}
.how-step h3{
  font-family:'Roboto Condensed';font-size:17px;letter-spacing:2px;text-transform:uppercase;
  margin:10px 0 8px;color:#fff;
}
.how-step p{color:#c6c6c9;font-size:13px;line-height:1.6;margin:0 0 12px}

/* --- About card sources --- */
.about-card p{color:#c6c6c9;font-size:13px;line-height:1.7;margin:0 0 14px}
.source-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;
  margin-bottom:14px;
}
.source{
  display:flex;flex-direction:column;gap:2px;
  padding:10px 12px;background:#141416;border:1px solid var(--border);border-radius:8px;
  transition:.12s;text-decoration:none;
}
.source:hover{border-color:var(--gold);text-decoration:none;transform:translateY(-1px)}
.source b{font-family:'Roboto Condensed';color:var(--gold);font-size:13px;letter-spacing:1px}
.source span{color:var(--muted);font-size:11px;letter-spacing:1px;text-transform:uppercase}
.legal{color:var(--muted);font-size:11px;font-style:italic;line-height:1.6;margin:10px 0 0 !important}

/* --- Landing footer --- */
.landing-footer{
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:20px 4px 10px;color:var(--muted);font-size:12px;
  border-top:1px solid var(--border);margin-top:8px;
}
.landing-footer a{color:var(--muted)}
.landing-footer a:hover{color:var(--gold)}
