:root{--bg-deep: #0e1320;--bg-ink: #111725;--panel: rgba(16, 20, 31, .78);--panel-strong: rgba(21, 27, 42, .92);--line: rgba(255, 255, 255, .08);--text: #edf1f7;--muted: #9ba7bf;--gold: #efc061;--rust: #e16b42;--teal: #62c5c2;--shadow: 0 30px 90px rgba(0, 0, 0, .34)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Georgia,Times New Roman,serif;color:var(--text);background:radial-gradient(circle at top,rgba(239,192,97,.18),transparent 30%),radial-gradient(circle at 85% 20%,rgba(98,197,194,.12),transparent 22%),linear-gradient(180deg,#1b2235,#0d121b)}button,input,select{font:inherit}button{border:0;border-radius:999px;background:linear-gradient(135deg,var(--gold),#f4d59b);color:#12151c;cursor:pointer;padding:.95rem 1.4rem;font-weight:700;transition:transform .14s ease,box-shadow .14s ease}button:hover{transform:translateY(-1px);box-shadow:0 12px 28px #efc0612e}button:disabled{cursor:default;opacity:.6;transform:none}.ghost-button{background:#ffffff14;color:var(--text)}.landing-page{min-height:100vh;display:grid;grid-template-columns:1.35fr minmax(340px,420px)}.map-shell{position:relative;overflow:hidden;padding:3rem;display:flex;align-items:center}.login-map-frame{width:min(100%,980px);padding:1.5rem;border-radius:34px;background:radial-gradient(circle at 30% 25%,rgba(239,192,97,.14),transparent 22%),radial-gradient(circle at 80% 30%,rgba(98,197,194,.12),transparent 18%),#ffffff08;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff0a}.login-map-grid{display:grid;grid-template-columns:repeat(13,minmax(0,1fr));grid-template-rows:repeat(7,minmax(48px,auto));gap:.55rem}.login-state-tile{min-height:62px;border-radius:18px;padding:.55rem;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,#efc0612e,#62c5c21a),#121927f2;border:1px solid rgba(255,255,255,.12);box-shadow:0 14px 36px #0000002e}.login-state-tile-marked{background:linear-gradient(180deg,#e16b423d,#efc06129),#121927fa}.login-state-code{font-size:.76rem;font-weight:700;letter-spacing:.08em;color:#ffffffc7}.login-marker{display:inline-flex;align-items:center;gap:.45rem;padding:.22rem .5rem;border-radius:999px;background:#080a12a6;border:1px solid rgba(255,255,255,.08);width:fit-content}.login-marker i{width:.55rem;height:.55rem;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px #efc06129}.login-marker strong{font-size:.72rem;font-weight:700;color:#ffffffe6}.map-overlay{position:absolute;left:4rem;bottom:4rem;width:min(34rem,calc(100% - 6rem))}.eyebrow,.panel-kicker{margin:0 0 .5rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold)}.lede,.body-copy,.support-line,.selection-line{color:var(--muted);line-height:1.6}.map-overlay h1,.login-header h2,.dashboard-header h1,.panel-headline h2,.hero-panel-top h2{margin:0;font-weight:600}.map-overlay h1{font-size:clamp(2.8rem,5vw,4.8rem);line-height:.96;max-width:10ch}.login-card,.panel{background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.login-card{margin:2rem;border-radius:28px;padding:2rem;align-self:center}.login-form,.create-form{display:grid;gap:1rem}.login-form label,.create-form label{display:grid;gap:.55rem}.login-form span{color:var(--muted)}select,input{border-radius:16px;border:1px solid var(--line);padding:.95rem 1rem;color:var(--text);background:#0a0e17d1}.error-line{color:#ffb4a1}.dashboard{min-height:100vh;padding:2rem}.dashboard-header{display:flex;align-items:start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.dashboard-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:1.25rem}.panel{border-radius:24px;padding:1.4rem}.hero-panel{grid-column:1 / -1;background:linear-gradient(135deg,rgba(239,192,97,.12),transparent 40%),linear-gradient(180deg,rgba(255,255,255,.04),transparent),var(--panel-strong)}.hero-panel-top,.panel-headline{display:flex;align-items:start;justify-content:space-between;gap:1rem}.token-pill{padding:.45rem .8rem;border:1px solid rgba(255,255,255,.12);border-radius:999px;color:var(--muted)}.metrics{margin-top:1.25rem;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.metric-card{padding:1rem;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.metric-card span{display:block;color:var(--muted);margin-bottom:.4rem}.metric-card strong{font-size:2rem}.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-bottom:.5rem}.candidate-toggle{display:flex;align-items:center;gap:.6rem;padding:.8rem .95rem;border-radius:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.candidate-toggle input{width:1rem;height:1rem;margin:0}.game-created{margin-top:1rem;padding:1rem;border-radius:18px;background:#62c5c214;border:1px solid rgba(98,197,194,.18)}.instruction-strip,.instruction-list{margin:1rem 0;padding:1rem 1.1rem;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--muted);line-height:1.6}.instruction-list p{margin:.25rem 0}.status-pill{padding:.45rem .8rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);color:var(--muted)}.status-pill-ready{color:#fff6d9;border-color:#efc06159;background:#efc0611f}.plan-actions{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.75rem}.resolve-callout{border:1px solid rgba(239,192,97,.4)}.resolve-callout:not(:disabled){animation:resolvePulse 1s ease-in-out infinite;background:linear-gradient(135deg,var(--gold),#f4d59b);color:#12151c}.status-callout{margin:1rem 0 0;padding:.9rem 1rem;border-radius:16px;color:#fff4db;background:#62c5c21a;border:1px solid rgba(98,197,194,.22)}.status-callout-ready{background:#efc06129;border-color:#efc06157;color:#fff7e6}.map-panel{background:linear-gradient(135deg,rgba(98,197,194,.1),transparent 38%),linear-gradient(180deg,rgba(255,255,255,.03),transparent),#121724eb}.live-map-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(240px,.8fr);gap:1rem;align-items:start}.tile-map{display:grid;grid-template-columns:repeat(13,minmax(0,1fr));grid-template-rows:repeat(7,minmax(32px,auto));gap:.35rem}.state-tile{min-height:46px;border-radius:12px;border:1px solid rgba(255,255,255,.12);color:#11161f;padding:.35rem .4rem;display:flex;flex-direction:column;justify-content:space-between;align-items:start;box-shadow:none}.state-tile span,.state-tile small{color:#11161f}.state-tile span{font-weight:700}.state-tile small{font-size:.72rem}.scoreboard{display:grid;gap:.8rem}.score-card{padding:.9rem 1rem;border-radius:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);display:grid;gap:.2rem}.score-card-title{display:flex;align-items:center;gap:.55rem}.score-card-title i{width:14px;height:14px;border-radius:50%;display:inline-block}.rank-list{list-style:none;padding:0;margin:1rem 0 0;display:grid;gap:.75rem}.rank-list li{display:flex;justify-content:space-between;gap:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.08)}.rank-list span{color:var(--muted)}.turn-log{display:grid;gap:1rem}.turn-log-entry,.turn-log-history{padding:1rem;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.turn-log-head{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.7rem}.turn-log-head span{color:var(--muted)}.turn-log-lines{margin:0;padding-left:1.1rem;display:grid;gap:.45rem;color:var(--muted)}@keyframes resolvePulse{0%,to{transform:translateY(0);box-shadow:0 0 #efc06100}50%{transform:translateY(-1px) scale(1.02);box-shadow:0 0 0 10px #efc06114}}.loading-shell{min-height:100vh;display:grid;place-items:center;font-size:1.2rem}@media (max-width: 1100px){.landing-page,.dashboard-grid{grid-template-columns:1fr}.map-shell{min-height:56vh}.login-map-grid{gap:.4rem}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 700px){.dashboard,.map-shell,.login-card{padding:1.2rem;margin:0}.dashboard-header,.hero-panel-top,.panel-headline{display:grid}.metrics,.checkbox-grid,.live-map-layout{grid-template-columns:1fr}.login-map-grid,.tile-map{grid-template-columns:repeat(7,minmax(0,1fr))}.login-state-tile{min-height:56px}.map-overlay{position:static;margin-top:1rem;width:auto}}
