/* Ankh-Morpork: A Matter of Influence — broadsheet-by-gaslight theme. No external assets. */

:root {
  --bg: #161210;
  --panel: #211a14;
  --panel2: #2a221a;
  --ink: #e8dcc0;
  --ink-dim: #a89878;
  --gold: #c9a227;
  --red: #b3422e;
  --warn: #c07a2c;
  --mom: #7a5ea8;
  --fear: #8a3030;
  --rule: #4a3c2c;
  --serif: Georgia, 'Times New Roman', serif;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: var(--serif); font-size: 15px; line-height: 1.45;
}

#app { display: flex; flex-direction: column; height: 100vh; }
#app.dim { filter: blur(2px) brightness(0.5); pointer-events: none; }

/* ---------- header ---------- */
header {
  background: var(--panel); border-bottom: 3px double var(--rule);
  padding: 8px 16px; display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap;
}
#masthead { font-size: 22px; letter-spacing: 1px; color: var(--gold); font-variant: small-caps; }
#masthead small { color: var(--ink-dim); font-size: 12px; letter-spacing: 0; font-variant: normal; }
#dateline { color: var(--ink-dim); font-style: italic; }
#apPips { color: var(--gold); font-size: 18px; letter-spacing: 3px; }
header .spacer { flex: 1; }
header button {
  font-family: var(--serif); background: var(--panel2); color: var(--ink);
  border: 1px solid var(--rule); padding: 6px 14px; cursor: pointer; font-size: 15px;
}
header button:hover { border-color: var(--gold); color: var(--gold); }
#endTurnBtn { background: var(--gold); color: #1a1410; font-weight: bold; }
#endTurnBtn:disabled { opacity: 0.4; cursor: default; }

/* ---------- layout ---------- */
main { flex: 1; display: grid; grid-template-columns: 260px 1fr 360px; min-height: 0; }
.panel { overflow-y: auto; padding: 12px; }
#leftPanel { background: var(--panel); border-right: 1px solid var(--rule); }
#centerPanel { background: var(--bg); display: flex; flex-direction: column; min-height: 0; }
#rightPanel { background: var(--panel); border-left: 1px solid var(--rule); display: flex; flex-direction: column; min-height: 0; }
#newsFeed { flex: 1; overflow-y: auto; padding: 12px 20px; }
#rightContent { flex: 1; overflow-y: auto; padding: 10px; }

/* ---------- stats ---------- */
#playerName { font-size: 18px; color: var(--gold); font-variant: small-caps; }
#playerBg { color: var(--ink-dim); font-style: italic; margin-bottom: 8px; }
.moneyRow { font-size: 18px; margin: 8px 0; }
.stat { margin: 6px 0; }
.statLabel { font-size: 12px; color: var(--ink-dim); }
.statVal { float: right; font-size: 12px; color: var(--ink); }
.barTrack { height: 7px; background: #0e0b08; border: 1px solid var(--rule); margin-top: 2px; }
.barFill { height: 100%; background: var(--ink-dim); }
.barFill.gold { background: var(--gold); }
.barFill.danger { background: var(--red); }
.barFill.warn { background: var(--warn); }
.barFill.mom { background: var(--mom); }
.barFill.fear { background: var(--fear); }
.rule { border: none; border-top: 1px solid var(--rule); margin: 10px 0; }
.statline { font-size: 14px; margin: 3px 0; }
.flagline { margin-top: 8px; font-size: 12px; color: var(--gold); font-style: italic; }

/* ---------- tabs ---------- */
.tabRow { display: flex; border-bottom: 2px solid var(--rule); background: var(--panel); }
.tabRow button {
  flex: 1; font-family: var(--serif); font-size: 14px; padding: 8px 4px;
  background: none; border: none; color: var(--ink-dim); cursor: pointer; font-variant: small-caps;
}
.tabRow button.active { color: var(--gold); border-bottom: 2px solid var(--gold); margin-bottom: -2px; }

/* ---------- news ---------- */
.turnRule { text-align: center; color: var(--ink-dim); font-style: italic; font-size: 12px; margin: 14px 0 6px; }
.newsItem { border-bottom: 1px solid #2c2419; padding: 8px 0; }
.newsHead { font-weight: bold; letter-spacing: 0.4px; }
.newsBody { color: var(--ink); margin-top: 2px; }
.newsFn { color: var(--ink-dim); font-size: 12.5px; font-style: italic; margin-top: 4px; padding-left: 12px; }
.nEvent .newsHead { color: var(--gold); }
.nNews .newsHead { color: var(--ink); }
.nAction .newsHead { color: #8fae6a; }
.nChoice .newsHead { color: #c9a227; }
.nLedger .newsHead { color: var(--ink-dim); }
.nLedger .newsBody { font-size: 13px; color: var(--ink-dim); }
.nAudit .newsHead, .nAudit .newsBody { color: #888; font-style: normal; letter-spacing: 0; }
.nDeath .newsHead { color: #9db4c9; }
.nDeath .newsFn {
  font-variant: small-caps; font-style: normal; letter-spacing: 1.5px; color: #b8cfe4; font-size: 13px;
}

/* ---------- right panel cards & actions ---------- */
.groupHead {
  font-variant: small-caps; color: var(--gold); border-bottom: 1px solid var(--rule);
  margin: 12px 0 6px; font-size: 14px; letter-spacing: 1px;
}
.actionBtn {
  display: block; width: 100%; text-align: left; margin: 4px 0; padding: 7px 10px;
  background: var(--panel2); border: 1px solid var(--rule); color: var(--ink);
  font-family: var(--serif); cursor: pointer; font-size: 14px;
}
.actionBtn:hover:not(:disabled) { border-color: var(--gold); }
.actionBtn.blocked { opacity: 0.45; cursor: default; }
.abLabel { font-weight: bold; }
.abCost { float: right; color: var(--ink-dim); font-size: 12px; }
.abDesc { display: block; color: var(--ink-dim); font-size: 12.5px; margin-top: 2px; }
.card {
  background: var(--panel2); border: 1px solid var(--rule); padding: 8px 10px; margin: 5px 0;
}
.card.person { cursor: pointer; }
.card.person:hover { border-color: var(--gold); }
.cardTitle { font-weight: bold; color: var(--ink); }
.cardSub { color: var(--ink-dim); font-size: 12.5px; }
.cardDesc { font-size: 13.5px; margin-top: 3px; }
.traitGrid {
  display: grid; grid-template-columns: auto auto auto auto; gap: 2px 12px;
  font-size: 13px; margin: 8px 0; color: var(--ink-dim);
}
.traitGrid b { color: var(--ink); text-align: right; }

/* ---------- modal ---------- */
#modalWrap {
  position: fixed; inset: 0; background: rgba(10, 8, 6, 0.75);
  display: none; align-items: center; justify-content: center; z-index: 50;
}
#modalWrap.show { display: flex; }
#modal {
  background: var(--panel); border: 2px solid var(--rule); outline: 1px solid #0e0b08;
  max-width: 620px; width: 92%; max-height: 84vh; display: flex; flex-direction: column;
  box-shadow: 0 8px 40px rgba(0,0,0,0.7);
}
#modalTitle {
  padding: 12px 18px; font-weight: bold; color: var(--gold); letter-spacing: 0.5px;
  border-bottom: 3px double var(--rule); font-size: 17px;
}
#modalBody { padding: 14px 18px; overflow-y: auto; }
#modalButtons { padding: 10px 18px 16px; display: flex; flex-direction: column; gap: 6px; }
.modalBtn {
  font-family: var(--serif); font-size: 15px; text-align: left; padding: 9px 12px;
  background: var(--panel2); border: 1px solid var(--rule); color: var(--ink); cursor: pointer;
}
.modalBtn:hover:not(:disabled) { border-color: var(--gold); color: var(--gold); }
.modalBtn.blocked { opacity: 0.45; cursor: default; }
.pickerList { display: flex; flex-direction: column; gap: 4px; max-height: 50vh; overflow-y: auto; }
.pickBtn {
  font-family: var(--serif); font-size: 14px; text-align: left; padding: 7px 10px;
  background: var(--panel2); border: 1px solid var(--rule); color: var(--ink); cursor: pointer;
}
.pickBtn:hover { border-color: var(--gold); }
.chronList { font-size: 13.5px; color: var(--ink-dim); max-height: 30vh; overflow-y: auto; }
.modList { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.modItem {
  display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: start;
  padding: 10px; background: var(--panel2); border: 1px solid var(--rule);
}
.modTitle { color: var(--gold); font-weight: bold; }
.modStatus {
  min-width: 72px; text-align: center; padding: 4px 7px; border: 1px solid var(--rule);
  color: var(--ink-dim); font-size: 12px;
}
.modStatus.on { color: var(--gold); border-color: var(--gold); }
.modStatus.locked { opacity: 0.6; }

/* ---------- toast ---------- */
#toast {
  position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%) translateY(120%);
  background: var(--panel2); border: 1px solid var(--gold); color: var(--ink);
  padding: 10px 18px; max-width: 640px; transition: transform 0.25s; z-index: 60;
  font-size: 14px;
}
#toast.show { transform: translateX(-50%) translateY(0); }

/* ---------- new game ---------- */
#newGame {
  position: fixed; inset: 0; background: var(--bg); z-index: 40; display: none;
  overflow-y: auto; padding: 30px 20px;
}
#newGame.show { display: block; }
.ngInner { max-width: 860px; margin: 0 auto; }
.ngTitle { font-size: 34px; color: var(--gold); font-variant: small-caps; text-align: center; letter-spacing: 2px; }
.ngSub { text-align: center; color: var(--ink-dim); font-style: italic; margin-bottom: 24px; }
.ngRow { display: flex; gap: 12px; margin: 14px 0; flex-wrap: wrap; justify-content: center; }
.ngRow input {
  font-family: var(--serif); font-size: 16px; padding: 8px 12px;
  background: var(--panel2); border: 1px solid var(--rule); color: var(--ink); min-width: 260px;
}
#bgCards { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 10px; margin: 16px 0; }
.bgCard { background: var(--panel2); border: 1px solid var(--rule); padding: 12px; cursor: pointer; }
.bgCard:hover { border-color: var(--ink-dim); }
.bgCard.sel { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold); }
.ngButtons { display: flex; gap: 12px; justify-content: center; margin: 20px 0; }
.ngButtons button {
  font-family: var(--serif); font-size: 17px; padding: 10px 26px; cursor: pointer;
  background: var(--gold); color: #1a1410; border: none; font-weight: bold;
}
.ngButtons button#continueBtn { background: var(--panel2); color: var(--ink); border: 1px solid var(--rule); }
.ngFoot { text-align: center; color: var(--ink-dim); font-size: 12px; font-style: italic; margin-top: 18px; }

/* ---------- city map ---------- */
.mapBox { position: relative; width: 100%; height: 100%; min-height: 420px; }
#cityMap { width: 100%; height: 100%; display: block; touch-action: none; background: #dbcaa2;
  border: 1px solid var(--rule); cursor: grab; }
#cityMap:active { cursor: grabbing; }
/* street & district labels drawn into the parchment */
.stName { fill: #5a4a30; font-family: var(--serif); font-size: 7.5px; font-style: italic;
  letter-spacing: 0.3px; opacity: 0.85; }
.halfName { fill: #6b5836; font-family: var(--serif); font-size: 26px; font-style: italic;
  letter-spacing: 3px; opacity: 0.35; text-anchor: middle; }
/* place markers, tuned for the light parchment */
.mkGlyph { fill: #b8902a; stroke: #4a3a10; stroke-width: 1.5; }
.mk-landmark .mkGlyph { fill: #8a3b2b; stroke: #3a1812; }
.mk-hall .mkGlyph { fill: #caa64a; stroke: #5a4410; }
.mk-district .mkGlyph { fill: #cdbb93; stroke: #6b5836; }
.mk:hover .mkGlyph { fill: #fff; }
.mkLabel { fill: #2b2014; font-family: var(--serif); font-size: 13px; font-weight: bold;
  paint-order: stroke; stroke: #e7dcbe; stroke-width: 3.5; }
.mk-district .mkLabel { fill: #5a4a30; font-weight: normal; font-style: italic; }
.mkBadge { fill: var(--red); stroke: #2b1a10; stroke-width: 1; }
.mkCount { fill: #fff; font-family: var(--serif); font-size: 11px; font-weight: bold; }
.mkPlayer { fill: none; stroke: #8a3b2b; stroke-width: 3; opacity: 0.95;
  animation: mkpulse 1.8s ease-out infinite; }
.mkOwnedRing { fill: none; stroke: #caa64a; stroke-width: 3; stroke-dasharray: 4 3; opacity: 0.9; }
.mkUnknown { fill: #cabb92; font-family: var(--serif); font-size: 34px; font-weight: bold; opacity: 0.6; }
/* merely "Heard Of" — a faint, rumoured marker */
.mkHeard .mkGlyph { opacity: 0.45; fill: #b7a576; stroke: #6b5836; }
.mkHeard:hover .mkGlyph { opacity: 0.8; fill: #fff; }
.mkLabelHeard { fill: #6b5836; font-weight: normal; font-style: italic; opacity: 0.85; }
/* familiarity rings: Familiar (thin) and Connected (brighter) */
.mkFamRing { fill: none; opacity: 0.9; }
.mkFamRing.fam-3 { stroke: #b8902a; stroke-width: 2; stroke-dasharray: 2 3; }
.mkFamRing.fam-4 { stroke: #e0b83a; stroke-width: 2.5; }
/* place notebook: familiarity track + perks + remembered events */
.famTrack { display: flex; gap: 2px; margin: 10px 0; }
.famStep { flex: 1; text-align: center; font-size: 9.5px; color: var(--ink-dim);
  font-variant: small-caps; letter-spacing: 0.3px; }
.famStep .famPip { display: block; height: 4px; border-radius: 2px; margin-bottom: 3px;
  background: var(--rule); }
.famStep.on .famPip { background: var(--gold); }
.famStep.on .famName { color: var(--ink); }
.famStep.cur .famName { color: var(--gold); font-weight: bold; }
.famPerks { margin: 8px 0; }
.famPerk { font-size: 12.5px; color: var(--ink-dim); padding: 1px 0; }
.famPerk.got { color: var(--ink); }
.placeMem { margin-top: 2px; }
.placeMemRow { font-size: 12.5px; color: var(--ink-dim); font-style: italic; padding: 2px 0;
  border-bottom: 1px dotted var(--rule); }
.bizGlyph { fill: #caa64a; stroke: #4a3a10; stroke-width: 1.2; }
.bizMk:hover .bizGlyph { fill: #fff; }
.bizCoin { fill: #2b1a08; font-family: var(--serif); font-size: 11px; font-weight: bold; }
@keyframes mkpulse { 0% { r: 14px; opacity: 0.9; } 100% { r: 26px; opacity: 0; } }
.mk.pulse .mkGlyph { animation: mkflash 1.2s ease-out 2; }
@keyframes mkflash { 0%,100% { fill: var(--panel2); } 50% { fill: var(--gold); } }
/* map bubbles: event pins + opportunity orbs */
.bubRing { fill: none; stroke-width: 2.5; transform-origin: center;
  animation: bubpulse 1.6s ease-out infinite; }
.bubCore { stroke: #2b1a10; stroke-width: 1.2; }
.bubGlyph { fill: #20160c; font-family: var(--serif); font-size: 12px; font-weight: bold; }
.bub-event .bubRing { stroke: #b3422e; } .bub-event .bubCore { fill: #b3422e; }
.bub-ap   .bubRing { stroke: #caa64a; } .bub-ap   .bubCore { fill: #e9c64a; }
.bub-gold .bubRing { stroke: #d8a23a; } .bub-gold .bubCore { fill: #f0c454; }
.bub-intel .bubRing { stroke: #5e7790; } .bub-intel .bubCore { fill: #88a6c0; }
.bub-lead .bubRing { stroke: #8a3b2b; } .bub-lead .bubCore { fill: #c06a4a; }
.bub:hover .bubCore { stroke: #fff; stroke-width: 2; }
@keyframes bubpulse { 0% { stroke-opacity: 0.9; r: 10px; } 100% { stroke-opacity: 0; r: 20px; } }

.mapHud { position: absolute; right: 10px; top: 10px; display: flex; gap: 6px; align-items: center; }
.mapHud button { font-family: var(--serif); width: 34px; height: 34px; font-size: 18px;
  background: var(--panel2); color: var(--ink); border: 1px solid var(--rule); cursor: pointer; }
.mapHud button:hover { border-color: var(--gold); color: var(--gold); }
.mapHint { position: absolute; left: 10px; bottom: -2px; color: var(--ink-dim); font-size: 11px;
  font-style: italic; background: rgba(16,13,10,0.7); padding: 2px 6px; white-space: nowrap; }

/* ---------- progression: level / title / ambition ---------- */
.levelBox { background: #1c160f; border: 1px solid var(--rule); padding: 8px 10px; margin-bottom: 10px; }
.levelTitle { color: var(--gold); font-variant: small-caps; font-size: 16px; letter-spacing: 0.5px; }
.levelMeta { color: var(--ink-dim); font-size: 11px; margin: 2px 0 4px; }
.barFill.noto { background: linear-gradient(90deg, #c9a227, #e9c64a); }
.ambitionLine { font-size: 12px; color: var(--ink-dim); margin-top: 6px; font-style: italic; }
.ambitionLine b { color: var(--ink); font-style: normal; }
.perkRow { display: flex; align-items: center; gap: 8px; margin: 8px 0 2px; }
.upgradeBtn { flex: 1; font-family: var(--serif); background: var(--panel2); color: var(--ink);
  border: 1px solid var(--rule); padding: 6px 8px; cursor: pointer; font-size: 13px; }
.upgradeBtn:hover { border-color: var(--gold); color: var(--gold); }
.perkPts { font-size: 12px; color: var(--ink-dim); }
.perkPts.has { color: var(--gold); font-weight: bold; }
.perkBank { font-size: 11px; color: var(--ink-dim); font-style: italic; margin-bottom: 6px; }
.ppHeader { margin: 8px 0; padding: 6px 9px; background: #1c160f; border: 1px solid var(--rule); font-size: 13px; }
.ppHeader b { color: var(--gold); }
.perkCard { background: var(--panel2); border: 1px solid var(--rule); border-left: 3px solid var(--rule);
  padding: 7px 10px; margin: 5px 0; }
.perkCard.owned { border-left-color: var(--gold); }
.perkTop { display: flex; justify-content: space-between; align-items: center; }
.perkName { font-weight: bold; color: var(--ink); }
.perkLvl { color: var(--gold); font-size: 12px; }
.perkBuy { font-family: var(--serif); background: var(--gold); color: #1a1410; border: none;
  padding: 4px 12px; cursor: pointer; font-weight: bold; font-size: 12px; }
.perkBuy:disabled { background: var(--panel); color: var(--ink-dim); cursor: default; border: 1px solid var(--rule); }
.perkDesc { color: var(--ink-dim); font-size: 12.5px; margin-top: 3px; }
.barTrack.big { height: 11px; margin-top: 5px; }

/* header achievements button + tab dot */
#achBtn { font-size: 13px; }
#achCount { color: var(--ink-dim); font-size: 12px; }
.tabDot { display: none; width: 7px; height: 7px; border-radius: 50%; background: var(--gold);
  margin-left: 4px; vertical-align: middle; }

/* ---------- Ambitions / objectives dashboard ---------- */
.goalsIntro { padding: 6px 4px 12px; border-bottom: 1px solid var(--rule); margin-bottom: 8px; }
.goalsCalling { color: var(--gold); font-variant: small-caps; font-size: 18px; }
.goalsBlurb { color: var(--ink-dim); font-style: italic; margin-top: 2px; }
.goalsHead { font-variant: small-caps; color: var(--gold); letter-spacing: 1px; font-size: 13px;
  margin: 16px 0 6px; border-bottom: 1px solid var(--rule); padding-bottom: 3px; }
.goalsFoot { color: var(--ink-dim); font-size: 12px; font-style: italic; margin: 14px 4px; }
.objCard { background: var(--panel2); border: 1px solid var(--rule); border-left: 3px solid var(--rule);
  padding: 8px 11px; margin: 6px 0; }
.objCard.chosen { border-left-color: var(--gold); }
.objCard.done { opacity: 0.7; border-left-color: #6f8f4f; }
.objTop { display: flex; justify-content: space-between; align-items: baseline; }
.objTitle { font-weight: bold; color: var(--ink); }
.objCard.done .objTitle { color: #9fc070; }
.objNum { color: var(--ink-dim); font-size: 12px; }
.objHint { color: var(--ink-dim); font-size: 12.5px; margin: 3px 0 6px; }

/* ---------- Social Register ---------- */
.regHeader { text-align: center; padding: 8px 4px 14px; border-bottom: 1px solid var(--rule); margin-bottom: 10px; }
.regRank { font-size: 46px; color: var(--gold); font-variant: small-caps; line-height: 1; }
.regRankSub { color: var(--ink-dim); font-size: 13px; }
.regBlurb { color: var(--ink-dim); font-size: 12.5px; font-style: italic; max-width: 520px; margin: 8px auto 0; }
/* search + filter controls */
.regControls { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.regSearch { background: var(--panel2); border: 1px solid var(--rule); color: var(--ink);
  font-family: var(--serif); padding: 8px 10px; font-size: 14px; width: 100%; box-sizing: border-box; }
.regSearch:focus { outline: none; border-color: var(--gold); }
.regFilters { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.regFiltBtn { background: var(--panel2); border: 1px solid var(--rule); color: var(--ink-dim);
  font-family: var(--serif); font-variant: small-caps; padding: 5px 12px; cursor: pointer; font-size: 13px; }
.regFiltBtn:hover { border-color: var(--gold); }
.regFiltBtn.on { color: var(--gold); border-color: var(--gold); background: rgba(201,162,39,0.12); }
.regFaction { background: var(--panel2); border: 1px solid var(--rule); color: var(--ink);
  font-family: var(--serif); padding: 5px 8px; font-size: 13px; margin-left: auto; }
.regList { display: flex; flex-direction: column; gap: 3px; }
.regRow { display: grid; grid-template-columns: 34px 1fr auto; align-items: center; gap: 8px;
  padding: 4px 6px; font-size: 13px; border-bottom: 1px solid var(--rule); }
.regRow.me { background: rgba(201,162,39,0.16); outline: 1px solid var(--gold); border-radius: 2px; }
.regPos { color: var(--ink-dim); font-size: 12px; }
.regBody { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.regNameLine { display: flex; align-items: baseline; gap: 7px; min-width: 0; }
.regName { color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 0 1 auto; }
.regMeta { color: var(--ink-dim); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1 1 auto; }
.regRow.me .regName { color: var(--gold); font-weight: bold; }
.regRow.legend .regName { color: #b8cfe4; }
.regRow.threat .regName { color: #d98a6a; }
.regBarWrap { background: #0e0b08; border: 1px solid var(--rule); height: 10px; position: relative; }
.regBar { display: block; height: 100%; background: var(--ink-dim); }
.regRow.me .regBar { background: linear-gradient(90deg, #c9a227, #e9c64a); }
.regRow.legend .regBar { background: #5e7790; }
.regScore { color: var(--ink-dim); font-size: 12px; text-align: right; }
.regEmpty { text-align: center; color: var(--ink-dim); font-style: italic; padding: 16px 4px; }

/* ---------- celebratory toasts ---------- */
.toast-level { border-color: var(--gold); background: #2a2110; box-shadow: 0 0 24px rgba(201,162,39,0.4); }
.toast-obj { border-color: #6f8f4f; }
.toast-ach { border-color: #c9a227; background: #241d10; }
#toast b { color: var(--gold); }

/* ---------- achievements viewer ---------- */
.achGrid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 8px; }
.achItem { background: #181308; border: 1px solid var(--rule); padding: 7px 9px; opacity: 0.5; }
.achItem.got { opacity: 1; border-color: var(--gold); }
.achName { font-weight: bold; color: var(--ink); font-size: 13.5px; }
.achItem.got .achName { color: var(--gold); }
.achDesc { color: var(--ink-dim); font-size: 12px; margin-top: 2px; }

/* ---------- welcome + endgame ---------- */
.welcomeList { margin: 4px 0; }
.welcomeObj { background: var(--panel2); border-left: 3px solid var(--gold); padding: 6px 10px; margin: 4px 0; font-size: 13.5px; }
.endStat { background: #1c160f; border: 1px solid var(--rule); padding: 7px 10px; margin: 8px 0; font-size: 13px; color: var(--ink-dim); }
.endStat b { color: var(--gold); }

/* ---------- new game: sections, ambition cards, legacy ---------- */
.ngSectionLabel { font-variant: small-caps; color: var(--gold); letter-spacing: 1px; font-size: 14px;
  margin: 18px 0 6px; border-bottom: 1px solid var(--rule); padding-bottom: 3px; }
.ngSectionLabel small { color: var(--ink-dim); font-variant: normal; letter-spacing: 0; font-style: italic; }
#ambCards { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 10px; }
.bgCard.amb .cardTitle { color: var(--gold); }
#legacyBox { margin-top: 18px; }
.legacyList { display: flex; flex-direction: column; gap: 4px; }
.legacyRow { display: grid; grid-template-columns: 20px 1fr 2fr auto; align-items: center; gap: 8px;
  background: var(--panel2); border: 1px solid var(--rule); padding: 5px 10px; font-size: 13px; }
.legSym { color: var(--gold); }
.legName { color: var(--ink); font-weight: bold; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.legTitle { color: var(--ink-dim); font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.legUse { font-family: var(--serif); background: var(--panel); border: 1px solid var(--rule); color: var(--ink);
  cursor: pointer; font-size: 12px; padding: 4px 10px; }
.legUse:hover { border-color: var(--gold); color: var(--gold); }

/* tablet: collapse to single column, keep panels scrollable */
@media (max-width: 980px) and (min-width: 821px) {
  main { grid-template-columns: 1fr; grid-template-rows: auto 1fr auto; }
  #leftPanel, #rightPanel { max-height: 34vh; }
}

/* ---------- act-on-a-person buttons (in the person card) ---------- */
.personActs { display: flex; flex-direction: column; gap: 5px; margin-top: 4px; }
.personAct { display: flex; flex-direction: column; align-items: flex-start; gap: 1px;
  width: 100%; text-align: left; background: var(--panel2); border: 1px solid var(--rule);
  color: var(--ink); font-family: var(--serif); padding: 10px 12px; cursor: pointer; min-height: 44px; }
.personAct:hover:not(:disabled) { border-color: var(--gold); }
.personAct.blocked, .personAct:disabled { opacity: 0.5; cursor: default; }
.personAct .paLabel { font-weight: bold; font-size: 14px; }
.personAct .paCost { color: var(--ink-dim); font-size: 12px; }

/* ---------- end-of-week summary ---------- */
.wsGrid { display: flex; flex-direction: column; gap: 2px; margin-bottom: 4px; }
.wsRow { display: flex; justify-content: space-between; align-items: baseline; padding: 6px 8px;
  border-bottom: 1px solid #2c2419; font-size: 14px; }
.wsRow span { color: var(--ink-dim); }
.wsRow b { font-variant-numeric: tabular-nums; }
.ws-good b { color: #8fae6a; }
.ws-bad b { color: var(--red); }
.ws-neutral b { color: var(--ink-dim); }
.wsNotes { margin: 4px 0 6px; padding-left: 18px; font-size: 13.5px; color: var(--ink); }
.wsNotes li { margin: 2px 0; }
.groupHead.wsThreat { color: var(--red); }

/* ---------- accessibility + shared (all widths) ---------- */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
.tabRow button[aria-selected="true"] { color: var(--gold); }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important; animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important; scroll-behavior: auto !important;
  }
}

/* the suggested-move card (both layouts) */
.suggestCard {
  display: block; width: 100%; text-align: left; margin: 0 0 12px; padding: 10px 12px; cursor: pointer;
  background: #221a0f; border: 1px solid var(--gold); border-left: 4px solid var(--gold);
  color: var(--ink); font-family: var(--serif);
}
.suggestCard:hover { background: #2a2110; }
.suggestCard .sugTag { display: block; font-size: 10.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); }
.suggestCard .sugLabel { display: block; font-weight: bold; font-size: 15.5px; margin-top: 2px; }
.suggestCard .sugReason { display: block; font-size: 12.5px; color: var(--ink-dim); margin-top: 2px; }
.actionBtn.suggested { border-color: var(--gold); box-shadow: inset 0 0 0 1px var(--gold); }

/* class-triggered reduced motion (Settings toggle, on top of the media query) */
body.reduced-motion *, body.reduced-motion *::before, body.reduced-motion *::after {
  animation-duration: 0.001ms !important; animation-iteration-count: 1 !important;
  transition-duration: 0.001ms !important;
}
/* settings toggles */
.setRow { display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  background: var(--panel2); border: 1px solid var(--rule); color: var(--ink);
  font-family: var(--serif); padding: 12px; margin: 6px 0; cursor: pointer; }
.setRow:hover { border-color: var(--gold); }
.setToggle { flex: 0 0 auto; width: 40px; height: 22px; border-radius: 11px;
  background: #0e0b08; border: 1px solid var(--rule); position: relative; }
.setToggle::after { content: ''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px;
  border-radius: 50%; background: var(--ink-dim); transition: left 0.15s, background 0.15s; }
.setToggle.on { border-color: var(--gold); }
.setToggle.on::after { left: 20px; background: var(--gold); }
.setLbl { display: flex; flex-direction: column; }
.setDesc { color: var(--ink-dim); font-size: 12.5px; margin-top: 2px; }

/* "new edition ready" update banner */
#updateBar { position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%);
  display: none; align-items: center; gap: 12px; z-index: 70;
  background: var(--panel2); border: 1px solid var(--gold); color: var(--ink);
  padding: 10px 14px; font-size: 14px; max-width: 92%; box-shadow: 0 6px 24px rgba(0,0,0,0.6); }
#updateBar.show { display: flex; }
#updateBar button { font-family: var(--serif); background: var(--gold); color: #1a1410;
  border: none; padding: 8px 14px; font-weight: bold; cursor: pointer; min-height: 40px; }
@media (max-width: 820px) { #updateBar { bottom: calc(68px + env(safe-area-inset-bottom)); } }

/* hidden on desktop; the phone layout reveals them */
#mobileNav { display: none; }
.miniStats { display: none; }

/* tablet: single column, panels scroll */
@media (max-width: 980px) and (min-width: 821px) {
  /* (kept from before) */
}

/* ---------- phone: app-like, one section at a time ---------- */
@media (max-width: 820px) {
  #app { height: 100vh; min-height: 100vh; display: flex; flex-direction: column; }
  body { overflow: hidden; -webkit-text-size-adjust: 100%; }

  /* compact sticky top bar */
  header {
    flex: 0 0 auto; align-items: center; gap: 6px 10px; row-gap: 4px;
    padding: 6px 10px; padding-top: calc(6px + env(safe-area-inset-top));
  }
  #masthead { display: none; }
  #dateline { font-size: 11px; font-style: italic; }
  #apPips { font-size: 15px; letter-spacing: 2px; }
  .miniStats { display: inline-flex; gap: 6px; flex-wrap: wrap; }
  .ms-pill { font-size: 11px; color: var(--ink); background: var(--panel2);
    border: 1px solid var(--rule); padding: 2px 6px; border-radius: 3px; white-space: nowrap; }
  .ms-pill.hot { color: #fff; background: var(--red); border-color: var(--red); }
  header button { padding: 8px 12px; min-height: 40px; font-size: 14px; }
  #achBtn { padding: 8px 10px; }
  #endTurnBtn { margin-left: auto; }

  /* the single scrolling content area between top bar and bottom nav */
  main { flex: 1 1 auto; display: block; overflow-y: auto; -webkit-overflow-scrolling: touch; min-height: 0; }
  #leftPanel, #centerPanel, #rightPanel {
    border: none; max-height: none; height: auto; overflow: visible; display: block; min-height: 0;
    padding-bottom: 12px;
  }
  #leftPanel { padding: 12px; }
  #newsFeed, #rightContent { overflow: visible; max-height: none; height: auto; flex: none; }
  #newsFeed { padding: 12px 14px; }

  /* show only the panels relevant to the current section */
  body[data-msec="city"] #leftPanel, body[data-msec="city"] #rightPanel { display: none; }
  body[data-msec="actions"] #leftPanel, body[data-msec="actions"] #centerPanel { display: none; }
  body[data-msec="ambitions"] #leftPanel, body[data-msec="ambitions"] #rightPanel { display: none; }
  body[data-msec="people"] #leftPanel, body[data-msec="people"] #rightPanel { display: none; }
  /* status shows leftPanel (stats) + centerPanel (chronicle) + rightPanel (holdings) */

  /* tab rows: show only the tabs belonging to the current section */
  .tabRow { position: sticky; top: 0; z-index: 5; }
  .tabRow button { display: none; padding: 13px 6px; font-size: 13px; min-height: 44px; }
  body[data-msec="city"] .tabRow button[data-msec~="city"],
  body[data-msec="actions"] .tabRow button[data-msec~="actions"],
  body[data-msec="people"] .tabRow button[data-msec~="people"],
  body[data-msec="ambitions"] .tabRow button[data-msec~="ambitions"],
  body[data-msec="status"] .tabRow button[data-msec~="status"] { display: inline-block; }

  /* roomy tap targets */
  .actionBtn { padding: 12px; min-height: 44px; }
  .modalBtn, .pickBtn { padding: 13px 14px; min-height: 44px; }
  .bgCard, .objCard, .perkCard, .card.person { padding: 12px; }
  .stat { margin: 5px 0; }
  .achGrid { grid-template-columns: 1fr; }
  .ngRow input { min-width: 0; width: 100%; }
  .regRow { grid-template-columns: 30px 1fr auto; }
  .abDesc, .cardSub { color: #b8a989; }   /* lift small-text contrast */

  /* bottom navigation */
  #mobileNav {
    display: flex; flex: 0 0 auto; background: var(--panel); border-top: 2px solid var(--rule);
    padding-bottom: env(safe-area-inset-bottom);
  }
  #mobileNav button {
    flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px;
    background: none; border: none; color: var(--ink-dim); font-family: var(--serif);
    padding: 7px 2px; min-height: 54px; cursor: pointer;
  }
  #mobileNav .navIcon { font-size: 17px; line-height: 1; }
  #mobileNav .navLbl { font-size: 10.5px; letter-spacing: 0.2px; }
  #mobileNav button.on { color: var(--gold); }

  /* modals fit small screens */
  #modal { width: 94%; max-height: 88vh; }
}
