*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Avenir Next,Segoe UI,system-ui,sans-serif;background:#1c2733;color:#ecf0f1}button{font:inherit;border:none;border-radius:8px;padding:10px 16px;background:#e67e22;color:#fff;font-weight:600;cursor:pointer}button:hover:not(:disabled){filter:brightness(1.1)}button:disabled{opacity:.45;cursor:not-allowed}button.secondary{background:#46627f}input{font:inherit;padding:9px 12px;border-radius:8px;border:1px solid #46627f;background:#15202b;color:#ecf0f1}.muted{color:#95a5a6;font-size:.9em}.error-text{color:#e74c3c}.home{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px}.home h1{font-size:2.6rem;margin:0}.tagline{color:#95a5a6;margin-top:0}.home-card{background:#243447;border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:14px;width:min(420px,90vw)}.home-card label{display:flex;flex-direction:column;gap:6px}.join-row,.share-row{display:flex;gap:8px}.join-row input,.share-row input{flex:1;text-transform:uppercase}.share-row input{text-transform:none;font-size:.85em}.room-code{font-family:ui-monospace,monospace;letter-spacing:2px;background:#15202b;padding:2px 8px;border-radius:6px}.lobby-players{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.lobby-players li{background:#15202b;border-radius:8px;padding:8px 12px}.game{height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:14px;padding:8px 14px;background:#15202b}.brand{font-weight:700}.turn-banner{margin-left:auto;padding:4px 12px;border-radius:999px;background:#46627f;font-size:.9em}.turn-banner.yours{background:#e67e22;font-weight:700}.offline-pill{background:#c0392b;border-radius:999px;padding:4px 10px;font-size:.8em}.game-main{flex:1;display:flex;min-height:0;gap:10px;padding:10px}.board{flex:1;min-width:0;height:100%}.board-bg{fill:#2e4258}.route{cursor:pointer}.route.claimed{cursor:default}.route.claimable:hover rect{stroke:#ffd54f;stroke-width:2px}.city circle{fill:#f5f5f5;stroke:#263238;stroke-width:1.5}.city text{font-size:11px;fill:#eceff1;paint-order:stroke;stroke:#1c2733;stroke-width:3px;font-weight:600;pointer-events:none}.sidebar{width:280px;display:flex;flex-direction:column;gap:8px;min-height:0}.players{background:#243447;border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:4px}.player{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;font-size:.85em}.player.current{background:#46627f}.player .pname{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player .pstats{white-space:nowrap;font-size:.9em;color:#cfd8dc}.chip{width:13px;height:13px;border-radius:50%;display:inline-block;flex-shrink:0;border:1px solid rgba(255,255,255,.5)}.final-round{background:#c0392b;border-radius:8px;text-align:center;padding:6px;font-size:.85em;font-weight:700}.log{flex:1;background:#243447;border-radius:10px;padding:10px;overflow-y:auto;font-size:.82em;display:flex;flex-direction:column;gap:4px;min-height:60px}.log-line{color:#b0bec5}.chat-line{color:#ecf0f1}.chat-form input{width:100%}.hand-panel{display:flex;gap:16px;padding:10px 14px;background:#15202b;align-items:stretch;flex-wrap:wrap}.draw-area{display:flex;flex-direction:column;gap:4px}.draw-label{font-size:.75em;text-transform:uppercase;letter-spacing:1px;color:#95a5a6}.face-up-row{display:flex;gap:8px}.card{width:52px;height:72px;border-radius:8px;border:2px solid rgba(0,0,0,.35);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.3em;padding:0;position:relative}.card.deck{background:repeating-linear-gradient(45deg,#34495e,#34495e 6px,#2c3e50 6px,#2c3e50 12px);font-size:.7em;gap:4px}.card.ticket-deck{background:repeating-linear-gradient(-45deg,#7d6608,#7d6608 6px,#9a7d0a 6px,#9a7d0a 12px);font-size:.7em;gap:4px}.card .count{font-size:.85rem;font-weight:700;background:#00000073;color:#fff;border-radius:999px;padding:1px 7px}.hand-card{cursor:default}.my-area{flex:1;display:flex;gap:16px;min-width:0;align-items:center}.my-cards{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.my-tickets{display:flex;flex-direction:column;gap:4px;max-height:96px;overflow-y:auto;margin-left:auto}.ticket{display:flex;justify-content:space-between;gap:12px;background:#243447;border-radius:6px;padding:4px 10px;font-size:.8em;min-width:220px}.ticket.done{background:#1e8449}.ticket.failed{background:#922b21}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#243447;border-radius:14px;padding:22px;width:min(440px,92vw);max-height:86vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.modal.wide{width:min(640px,94vw)}.modal h2,.modal h3{margin:0}.ticket-choices{display:flex;flex-direction:column;gap:8px}.ticket-choice{display:flex;align-items:center;gap:10px;background:#15202b;border-radius:8px;padding:10px 12px;cursor:pointer;border:2px solid transparent}.ticket-choice.on{border-color:#e67e22}.ticket-choice span{flex:1}.claim-options{display:flex;flex-direction:column;gap:8px}.claim-option{display:flex;gap:4px;background:#15202b;padding:8px;justify-content:center}.mini-card{width:26px;height:36px;border-radius:4px;border:1px solid rgba(0,0,0,.4);display:inline-flex;align-items:center;justify-content:center;font-size:.9em}.results{width:100%;border-collapse:collapse}.results th,.results td{padding:6px 10px;text-align:left;border-bottom:1px solid #46627f}.results .neg{color:#e74c3c}.ticket-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;font-size:.9em}.toast{position:fixed;bottom:130px;left:50%;transform:translate(-50%);background:#c0392b;padding:10px 18px;border-radius:10px;font-weight:600;z-index:100;box-shadow:0 4px 16px #0006}@media(max-width:900px){.game-main{flex-direction:column;overflow-y:auto}.board{height:auto}.sidebar{width:100%}}
