:root{--ink:#19323a;--muted:#61777a;--paper:#fffdf8;--line:#d6e3df;--blue:#3379b7;--orange:#df8255;--neutral:#f4e0a3;--green:#1e746e}
.site-header,.site-footer{width:100%;max-width:none;padding-left:clamp(1.25rem,4vw,3rem);padding-right:clamp(1.25rem,4vw,3rem)}
.game-layout{display:grid;grid-template-columns:350px minmax(0,1fr);width:100%;max-width:none;min-height:calc(100svh - 86px);margin:0;overflow:hidden;background:var(--paper)}
.game-sidebar{padding:36px 28px;border-right:1px solid var(--line);background:var(--paper)}.eyebrow{margin:0 0 8px;color:#af563e;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase}.game-sidebar h1{margin:0;font-size:48px;letter-spacing:-2px;line-height:1}.intro{color:var(--muted);line-height:1.5}.scoreboard{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:25px 0}.scoreboard div{padding:12px;border-radius:10px;background:#eef6f4}.scoreboard div+div{background:#fff1e9}.scoreboard span,.round{display:block;color:var(--muted);font-size:12px;font-weight:700}.scoreboard strong{display:block;margin-top:2px;font-size:30px;line-height:1}.panel,.rules{margin-top:16px;padding:17px;border:1px solid var(--line);border-radius:10px;background:#fff}.panel h2,.rules h2{margin:3px 0 8px;font-size:18px}.panel p{margin:0;color:var(--muted);line-height:1.45}button{width:100%;padding:11px;border:1px solid #b8cac7;border-radius:7px;background:#fff;color:var(--ink);font:inherit;font-weight:700;cursor:pointer}button:hover:not(:disabled){border-color:var(--green)}button:disabled{cursor:not-allowed;opacity:.5}.selected-panel{min-height:75px}.rules ol{margin:10px 0 0;padding-left:21px;color:var(--muted);font-size:14px;line-height:1.55}.restart{margin-top:18px;color:var(--muted);font-size:14px}.board{position:relative;display:grid;grid-template-rows:auto minmax(0,1fr);gap:15px;padding:26px;background:linear-gradient(145deg,#d7f0eb,#a5d5dd);min-width:0}.board-topline{display:flex;align-items:center;justify-content:space-between;gap:16px}.legend{display:flex;flex-wrap:wrap;gap:14px;color:#385b62;font-size:13px}.legend i{display:inline-block;width:10px;height:10px;margin-right:4px;border-radius:50%}.blue{background:var(--blue)}.orange{background:var(--orange)}.neutral{background:var(--neutral)}.message{max-width:440px;margin:0;padding:9px 12px;border-radius:7px;background:#ffffffa8;color:#34565b;font-size:14px;text-align:right}#map{width:min(100%,1000px);max-height:650px;justify-self:center;align-self:center;background:#76b8c4;border-radius:12px;box-shadow:inset 0 0 0 1px #559eaa}.route{fill:none;stroke:#f8f1d5;stroke-width:6;stroke-linecap:round;opacity:.8}.route.available{stroke:#fff;stroke-width:10;opacity:1;filter:drop-shadow(0 0 4px #fff)}.island{stroke:#24464b;stroke-width:3;cursor:pointer;transition:transform .15s,filter .15s}.island:hover{filter:brightness(1.08)}.island.source{stroke:#fff;stroke-width:7;filter:drop-shadow(0 0 7px #fff)}.island.target{stroke:#fff;stroke-width:6;stroke-dasharray:6 4;filter:drop-shadow(0 0 6px #fff)}.label,.bonus{pointer-events:none;text-anchor:middle;fill:var(--ink);font-size:12px;font-weight:800}.bonus{fill:#fff8d4;font-size:23px;paint-order:stroke;stroke:#805d10;stroke-width:3px;stroke-linejoin:round}.outcome{position:absolute;inset:18px;z-index:4;display:grid;place-items:center;padding:30px;background:#173e50c9;backdrop-filter:blur(4px)}.outcome>div{width:min(100%,470px);padding:34px;border:1px solid #fff8;border-radius:18px;background:#fffdf8;color:var(--ink);box-shadow:0 18px 50px #102d3988;text-align:center}.outcome p{margin:0}.outcome-kicker,#outcome-kicker{color:#687b7c;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase}.outcome h2{margin:8px 0 10px;font-size:34px;letter-spacing:-1.5px}.outcome button{margin-top:22px;background:var(--green);border-color:var(--green);color:#fff}.outcome[data-tone="loss"]>div{background:#fff3ed}.outcome[data-tone="draw"]>div{background:#fff9dc}.outcome[hidden]{display:none}@media(max-width:900px){.game-layout{grid-template-columns:1fr}.game-sidebar{border-right:0;border-bottom:1px solid var(--line)}.board{min-height:600px}.board-topline{align-items:flex-start;flex-direction:column}.message{text-align:left}#map{width:100%;max-height:none}.outcome{inset:12px}}@media(max-width:500px){.game-sidebar,.board{padding:24px 16px}.game-sidebar h1{font-size:42px}.scoreboard{margin:20px 0}.outcome h2{font-size:28px}}
