/* =========================================================================
   FISCAL PLINKO — Papers, Please-adjacent bureaucratic dread
   ========================================================================= */
:root{
  --ink:#2e2a1d;
  --ink-soft:#5d5742;
  --paper:#cfc6a5;
  --paper-hi:#e8e0c5;
  --paper-line:#8a8166;
  --bg:#1d1f26;
  --bg-panel:#262931;
  --red:#a93b3b;
  --green:#3f6b3f;
  --accent:#9b9270;
}

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

html,body{ height:100%; }
body{
  background:var(--bg);
  background-image:
    repeating-linear-gradient(0deg, rgba(0,0,0,.14) 0 1px, transparent 1px 4px);
  font-family:'VT323', monospace;
  color:var(--paper);
  display:flex; align-items:center; justify-content:center;
  min-height:100vh;
  padding:16px;
}

.screen{ display:none; width:100%; max-width:1280px; }
.screen.active{ display:flex; flex-direction:column; align-items:center; gap:12px; }

/* ---- paper documents ---- */
.paper{
  background:var(--paper);
  color:var(--ink);
  border:3px solid #14161b;
  outline:2px solid var(--paper-line);
  outline-offset:-10px;
  box-shadow:0 14px 0 rgba(0,0,0,.45);
  padding:34px 38px 26px;
  width:100%;
  position:relative;
}
.paper::before{
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.04) 0 1px, transparent 1px 3px);
}

.doc-header{ text-align:center; margin-bottom:18px; }
.doc-header.slim{ margin-bottom:10px; }
.doc-crest{ font-size:42px; color:var(--red); }
.doc-agency{ font-size:20px; letter-spacing:2px; color:var(--ink-soft); }
.doc-classification{ font-size:16px; color:var(--red); letter-spacing:3px; margin-top:2px; }
.doc-footer{ margin-top:18px; text-align:center; font-size:15px; color:var(--ink-soft); border-top:2px solid var(--paper-line); padding-top:10px; }

/* ---- title screen ---- */
.title-paper{ max-width:760px; text-align:center; }
.game-title{
  font-size:110px; line-height:.82; letter-spacing:6px;
  color:var(--ink); margin:18px 0 10px;
  text-shadow:5px 5px 0 var(--paper-line);
}
.tagline{ font-size:26px; color:var(--red); margin-bottom:20px; }
.briefing{ text-align:left; font-size:21px; line-height:1.35; max-width:560px; margin:0 auto 24px; }
.briefing p{ margin-bottom:12px; }
.briefing b{ color:var(--red); }
.redact{ background:var(--ink); color:var(--ink); padding:0 4px; }
.fine-print{ font-size:16px; color:var(--ink-soft); }

/* ---- buttons ---- */
.stamp-btn{
  font-family:'VT323', monospace; font-size:30px; letter-spacing:3px;
  background:var(--red); color:var(--paper-hi);
  border:3px solid #6e2424; border-bottom-width:6px;
  padding:10px 34px; cursor:pointer;
  transform:rotate(-1deg);
}
.stamp-btn:hover{ filter:brightness(1.12); }
.stamp-btn:active{ transform:rotate(-1deg) translateY(3px); border-bottom-width:3px; }
.paper-btn{
  font-family:'VT323', monospace; font-size:22px; letter-spacing:2px;
  background:var(--paper-hi); color:var(--ink);
  border:2px solid var(--paper-line); border-bottom-width:5px;
  padding:8px 20px; cursor:pointer;
}
.paper-btn:hover{ background:#fff7dd; }
.paper-btn:active{ translate:0 2px; border-bottom-width:3px; }
.paper-btn.small{ font-size:18px; padding:5px 14px; }
.music-btn{ position:fixed; top:14px; right:14px; z-index:10; opacity:.85; }
.paper-btn:disabled{ opacity:.45; cursor:default; }

/* ---- policy screen ---- */
.policy-paper{ max-width:860px; }
.policy-columns{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:16px;
}
.policy-group{
  border:2px solid var(--paper-line); padding:14px 14px 8px;
}
.policy-group legend{
  font-size:20px; letter-spacing:2px; color:var(--red); padding:0 8px;
}
.lever{ margin-bottom:14px; position:relative; }
.lever.amended::after{
  content:'AMENDED'; position:absolute; top:21px; right:0;
  font-size:12px; color:var(--paper-hi); background:var(--red);
  padding:1px 5px; transform:rotate(2deg); letter-spacing:1px;
}
.lever-head{ display:flex; justify-content:space-between; align-items:baseline; }
.lever-label{ font-size:19px; color:var(--ink); letter-spacing:1px; }
.lever-value{ font-size:19px; color:var(--red); }
.lever-sub{ font-size:14px; color:var(--ink-soft); margin-bottom:3px; }
.lever-sub.live{ color:var(--red); padding-right:62px; }

input[type=range]{
  width:100%; -webkit-appearance:none; appearance:none; height:18px;
  background:transparent; cursor:pointer;
}
input[type=range]::-webkit-slider-runnable-track{
  height:6px; background:var(--paper-line);
  border-top:1px solid #6e6852;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; width:18px; height:18px; margin-top:-6px;
  background:var(--ink); border:2px solid var(--paper-hi);
}
input[type=range]::-moz-range-track{ height:6px; background:var(--paper-line); }
input[type=range]::-moz-range-thumb{
  width:14px; height:14px; border-radius:0;
  background:var(--ink); border:2px solid var(--paper-hi);
}

.toggle-row{
  display:flex; align-items:center; gap:8px; font-size:17px; color:var(--ink);
  cursor:pointer; padding:2px 0;
}
.toggle-row input[type=checkbox]{
  appearance:none; width:17px; height:17px; cursor:pointer;
  background:var(--paper-hi); border:2px solid var(--ink);
}
.toggle-row input[type=checkbox]:checked{
  background:var(--red);
  box-shadow:inset 0 0 0 2px var(--paper-hi);
}

.policy-footer{
  margin-top:18px; display:flex; align-items:center; gap:16px; justify-content:flex-end;
  border-top:2px solid var(--paper-line); padding-top:16px;
}
.no-estimates{ margin-right:auto; font-size:16px; color:var(--ink-soft); font-style:italic; }

/* ---- sim screen ---- */
#screen-sim.active{ gap:8px; }
#sim-canvas{
  width:100%; max-width:1280px; aspect-ratio:1280/800;
  border:3px solid #14161b; box-shadow:0 14px 0 rgba(0,0,0,.45);
  image-rendering:pixelated;
}
.sim-controls{ display:flex; gap:12px; }

/* ---- results screen ---- */
.results-paper{ max-width:1000px; }
.results-grid{
  display:grid; grid-template-columns:1fr auto 1fr; gap:20px; align-items:center;
  margin:10px 0 6px;
}
.results-grid.two-scores{ grid-template-columns:1fr 1fr; align-items:start; }
.result-stat{ text-align:center; }
.stat-label{ font-size:20px; letter-spacing:2px; color:var(--ink-soft); }
.stat-value{ font-size:64px; line-height:1; color:var(--ink); }
.stat-delta{ font-size:20px; }
.stat-delta.good{ color:var(--green); }
.stat-delta.bad{ color:var(--red); }

.grade-box{ display:flex; justify-content:center; }
.grade-stamp{
  font-size:84px; line-height:1; padding:14px 26px;
  border:6px solid var(--red); color:var(--red);
  transform:rotate(-7deg);
  text-shadow:2px 2px 0 rgba(0,0,0,.1);
}
.grade-stamp.green{ border-color:var(--green); color:var(--green); }
.grade-stamp.small{
  display:inline-block; font-size:52px; padding:6px 20px;
  border-width:5px; margin-top:12px; transform:rotate(-5deg);
}
.score-name{ font-size:16px; letter-spacing:2px; color:var(--ink-soft); margin-top:8px; }

.verdict-line{ text-align:center; font-size:24px; color:var(--ink); margin:6px 0 14px; }

.bin-summary{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-bottom:14px; }
.bin-chip{ font-size:17px; padding:4px 10px; color:var(--paper-hi); letter-spacing:1px; }
.bin-0{ background:#8c2f2f; } .bin-1{ background:#a3552c; } .bin-2{ background:#7a7340; }
.bin-3{ background:#4e6e4e; } .bin-4{ background:#3d6b6e; }

.persona-table{
  width:100%; border-collapse:collapse; font-size:17px; margin-bottom:18px;
}
.persona-table th{
  text-align:left; font-size:15px; letter-spacing:1px; color:var(--ink-soft);
  border-bottom:2px solid var(--paper-line); padding:4px 8px;
}
.persona-table td{ padding:4px 8px; border-bottom:1px solid rgba(138,129,102,.4); }
.persona-table td .sub{ display:block; font-size:13px; color:var(--ink-soft); }
.persona-table tr.pov td{ background:rgba(169,59,59,.12); }
.persona-table .neg{ color:var(--red); }
.persona-table .pos{ color:var(--green); }

.share-row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

@media (max-width:900px){
  .policy-columns{ grid-template-columns:repeat(2,1fr); }
  .game-title{ font-size:64px; }
  .results-grid{ grid-template-columns:1fr; }
}

/* ---- policy info tooltips ---- */
.info-icon{
  display:inline-block; position:relative;
  width:16px; height:16px; margin-left:7px;
  border:2px solid var(--ink-soft); color:var(--ink-soft);
  font-size:13px; line-height:13px; text-align:center;
  vertical-align:2px; cursor:help;
}
.info-icon:hover, .info-icon:focus{
  border-color:var(--red); color:var(--red); outline:none;
}
.info-tip{
  display:none; position:absolute; left:-12px; top:24px; z-index:40;
  width:290px; padding:10px 12px;
  background:#2e2a1d; color:var(--paper-hi);
  border:2px solid var(--paper-line);
  font-size:15px; line-height:1.35; letter-spacing:.4px;
  text-align:left; white-space:normal;
  box-shadow:5px 5px 0 rgba(0,0,0,.4);
}
.info-icon:hover .info-tip, .info-icon:focus .info-tip{ display:block; }
.lever:nth-last-child(-n+2) .info-tip{ top:auto; bottom:24px; }

/* ---- Build Canada memo callout ---- */
.memo-callout{
  position:relative; display:flex; align-items:center; gap:18px;
  margin-top:18px; padding:14px 16px 14px 18px;
  background:var(--paper-hi);
  border:2px dashed var(--paper-line);
}
.memo-tag{
  position:absolute; top:-10px; left:14px;
  background:var(--red); color:var(--paper-hi);
  font-size:13px; letter-spacing:2px; padding:2px 8px;
  transform:rotate(-1deg);
}
.memo-body{ font-size:17px; line-height:1.35; color:var(--ink); }
.memo-body a{ color:var(--red); white-space:nowrap; }
.memo-callout .paper-btn{ flex-shrink:0; }
.memo-callout.slim{ margin:0 0 16px; }

.share-url-out{
  display:none; width:100%; max-width:560px; margin:10px auto 0;
  font-family:'VT323', monospace; font-size:18px; text-align:center;
  background:var(--paper-hi); color:var(--ink);
  border:2px solid var(--paper-line); padding:6px 10px;
}
