:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#faf8f4;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}h1,h2,h3{margin:0}button{font-family:inherit;cursor:pointer}.map-display{width:100%;height:100%;overflow:auto;display:flex;align-items:center;justify-content:center;padding:2rem}.map-grid{position:relative}.map-tile-container{position:absolute}.map-tile{width:100%;height:100%;border:2px solid #ccc;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.tile-connections{width:50px;height:50px}.tile-settlement{font-size:.55rem;font-weight:700;color:#8b7355;text-align:center;position:absolute;bottom:2px;left:0;right:0}.tile-blocked .tile-connections line{stroke:#c0392b;opacity:.4}.tile-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.blocked-overlay{color:#c0392b;background:#c0392b1a}.tile-indicator{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700}.fortify-indicator{background:#b8860b;color:#fff}.tile-highlighted{box-shadow:0 0 0 2px gold}.tile-supply-target{box-shadow:0 0 0 2px #2980b9;animation:pulse-supply 1.5s infinite}.tile-supply-target:hover{box-shadow:0 0 0 3px #2980b9;filter:brightness(1.1)}@keyframes pulse-supply{0%,to{box-shadow:0 0 0 2px #2980b9}50%{box-shadow:0 0 8px 2px #2980b9}}.ai-placed{animation:ai-place-pop .5s ease}@keyframes ai-place-pop{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.map-empty-slot{width:100%;height:100%;border:2px dashed #ddd;border-radius:4px;opacity:.4}.slot-highlighted{border-color:#4caf50;background:#4caf5026;opacity:1;cursor:pointer;animation:pulse-slot 1.5s infinite}@keyframes pulse-slot{0%,to{opacity:.7}50%{opacity:1}}.card-wrapper{cursor:pointer;transition:transform .15s,box-shadow .15s;flex-shrink:0}.card-wrapper:hover{transform:translateY(-4px)}.card-wrapper.card-selected{transform:translateY(-8px);filter:brightness(1.1)}.card-wrapper.card-selected .card{box-shadow:0 0 0 3px gold,0 4px 12px #0000004d}.card{width:120px;height:168px;border-radius:6px;overflow:hidden;display:flex;flex-direction:column;background:#fff;box-shadow:0 1px 4px #0003;font-size:.65rem;position:relative}.card-header{padding:4px 6px;color:#fff;font-weight:700;font-size:.6rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px;gap:2px}.card-footer{padding:4px 6px;border-top:1px solid #eee}.flavor-text{font-style:italic;font-size:.55rem;color:#888;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.connection-diagram{width:60px;height:60px}.settlement-badge{font-size:.55rem;font-weight:700;color:#8b7355;text-align:center}.mail-route{text-align:center;font-weight:700;font-size:.6rem}.mail-from,.mail-to{color:#2e8b8b}.mail-arrow{font-size:1rem;color:#aaa}.card-vp-badge{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#2e8b8b;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;z-index:1}.card-icon{font-size:1.5rem}.card-effect{font-size:.5rem;text-align:center;color:#555;line-height:1.3;padding:0 2px}.card-chaos-badge{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#c0392b;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.65rem;z-index:1}.card-back{display:flex;align-items:center;justify-content:center}.card-back-player{background:#3e2723}.card-back-hazard{background:#5d1a1a}.card-back-design{font-size:2rem;opacity:.7}.player-hand-row{display:flex;gap:8px;padding:8px 16px;overflow-x:auto;justify-content:center;align-items:flex-end;min-height:100px}.mail-offer-section{padding:.5rem}.section-title{font-size:.8rem;color:#666;margin-bottom:.5rem}.mail-offer-cards{display:flex;gap:6px;justify-content:center}.mail-offer-card{cursor:pointer}.chaos-tracker{display:flex;align-items:center;gap:.5rem}.chaos-label{font-weight:700;font-size:.8rem}.chaos-bar-container{width:120px;height:12px;background:#444;border-radius:6px;overflow:hidden}.chaos-bar-fill{height:100%;border-radius:6px;transition:width .3s,background .3s}.chaos-safe{background:#4caf50}.chaos-warning{background:#ff9800}.chaos-critical{background:#f44336}.chaos-value{font-size:.8rem;font-weight:700}.scoreboard-section{padding:.5rem}.scoreboard-entry{display:flex;flex-wrap:wrap;justify-content:space-between;padding:.3rem .5rem;font-size:.8rem;border-bottom:1px solid #d0c8b8}.scoreboard-entry.current-turn{background:#8b735526;font-weight:700;border-radius:4px}.player-label{flex:1}.player-vp{font-weight:700;color:#8b7355}.player-details{width:100%;font-size:.65rem;color:#888}.game-log-section{padding:.5rem;flex:1;display:flex;flex-direction:column;min-height:0}.game-log-section .section-title{display:flex;justify-content:space-between;align-items:center}.log-toggle{background:none;border:1px solid #ccc;border-radius:3px;cursor:pointer;font-size:.75rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#666}.log-toggle:hover{background:#eee}.game-log-entries{flex:1;overflow-y:auto;font-size:.7rem;max-height:200px}.log-entry{padding:2px 4px;border-bottom:1px solid #e0d8c8;display:flex;gap:6px}.log-round{color:#8b7355;font-weight:700;flex-shrink:0}.log-message{color:#555}.log-hazard .log-message{color:#c0392b}.log-delivery .log-message{color:#27ae60}.log-supply .log-message{color:#2980b9}.log-placement .log-message{color:#8b7355}.log-empty{color:#aaa;font-style:italic;padding:4px}.scout-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.scout-modal{background:#faf8f4;border-radius:8px;padding:1.5rem 2rem;max-width:600px;width:90%;text-align:center;box-shadow:0 4px 24px #0000004d}.scout-title{color:#2980b9;margin-bottom:.25rem;font-size:1.2rem}.scout-hint{color:#888;font-size:.85rem;margin-bottom:1rem}.scout-cards{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.scout-card-wrapper{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:transform .15s}.scout-card-wrapper:hover{transform:translateY(-4px)}.scout-pick-btn{padding:.3rem 1rem;background:#2980b9;color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.scout-card-wrapper:hover .scout-pick-btn{background:#1a6da0}.hazard-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:900;animation:hazard-fade-in .3s ease}@keyframes hazard-fade-in{0%{opacity:0}to{opacity:1}}.hazard-overlay{text-align:center;animation:hazard-shake .4s ease}@keyframes hazard-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.hazard-overlay-title{color:#c0392b;font-size:1.8rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem;text-shadow:0 0 20px rgba(192,57,43,.6)}.hazard-card-display{display:flex;justify-content:center;margin-bottom:1rem}.hazard-chaos-update{color:#e74c3c;font-size:1.2rem;font-weight:700;margin-bottom:.75rem}.hazard-dismiss-hint{color:#ffffff80;font-size:.8rem;font-style:italic}.tutorial-overlay{position:fixed;bottom:120px;left:50%;transform:translate(-50%);z-index:800;pointer-events:none}.tutorial-tooltip{background:#1a1a2e;color:#e8e0d0;border:2px solid #B8860B;border-radius:12px;padding:16px 20px;max-width:480px;min-width:300px;box-shadow:0 8px 32px #00000080,0 0 20px #b8860b33;pointer-events:auto;animation:tutorial-slide-up .3s ease-out}@keyframes tutorial-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tutorial-message{font-size:.95rem;line-height:1.5;margin-bottom:12px}.tutorial-actions{display:flex;gap:8px;justify-content:flex-end}.tutorial-next-btn{background:#b8860b;color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:.85rem;cursor:pointer;font-weight:700}.tutorial-next-btn:hover{background:#d4a017}.tutorial-skip-btn{background:transparent;color:#888;border:1px solid #555;border-radius:6px;padding:6px 12px;font-size:.75rem;cursor:pointer}.tutorial-skip-btn:hover{color:#ccc;border-color:#888}.tutorial-hl-hand .player-hand,.tutorial-hl-hand-mail .player-hand{box-shadow:0 0 12px 4px #b8860b66}.tutorial-hl-mail-offer .mail-offer-section{box-shadow:0 0 12px 4px #2e8b8b66}.tutorial-hl-chaos-tracker .chaos-tracker{box-shadow:0 0 12px 4px #f4433666}.feedback-prompt{margin-top:1.5rem;background:#f8f5f0;border:1px solid #ddd;border-radius:8px;padding:1.25rem;max-width:400px;width:100%}.feedback-title{margin:0 0 1rem;font-size:1.1rem;color:#333}.feedback-question{margin-bottom:.75rem}.feedback-question label{display:block;font-size:.9rem;font-weight:700;color:#555;margin-bottom:.35rem}.optional{font-weight:400;color:#999;font-size:.8rem}.feedback-stars{display:flex;gap:4px}.star-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#ccc;padding:0 2px}.star-btn.active{color:#f5a623}.feedback-options{display:flex;gap:.5rem}.option-btn{padding:.3rem .75rem;border:1px solid #bbb;background:#fff;border-radius:4px;font-size:.85rem;cursor:pointer;color:#555}.option-btn.active{background:#8b7355;color:#fff;border-color:#8b7355}.feedback-textarea{width:100%;padding:.4rem;border:1px solid #ccc;border-radius:4px;font-size:.85rem;font-family:inherit;resize:vertical;box-sizing:border-box}.feedback-actions{display:flex;gap:.5rem;margin-top:1rem}.feedback-submit-btn{padding:.4rem 1.25rem;background:#8b7355;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;font-weight:700}.feedback-submit-btn:hover{background:#6b5335}.feedback-skip-btn{padding:.4rem 1rem;background:transparent;color:#999;border:1px solid #ccc;border-radius:4px;font-size:.85rem;cursor:pointer}.feedback-skip-btn:hover{color:#666;border-color:#999}.feedback-thanks{text-align:center;color:#2e8b8b;font-weight:700;margin:.5rem 0}.feedback-dismiss-btn{display:block;margin:.75rem auto 0;padding:.3rem 1rem;background:transparent;border:1px solid #ccc;border-radius:4px;cursor:pointer;color:#666}.rules-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.rules-modal{background:#faf8f4;border-radius:8px;padding:2rem;max-width:560px;width:90%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 4px 24px #0000004d}.rules-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.rules-close:hover{background:#eee;color:#333}.rules-title{text-align:center;color:#8b7355;margin-bottom:1.5rem;font-size:1.5rem;letter-spacing:.05em}.rules-section{margin-bottom:1.25rem}.rules-section h3{color:#8b7355;font-size:1rem;margin-bottom:.4rem;border-bottom:1px solid #e0d8c8;padding-bottom:.2rem}.rules-section p{margin:.4rem 0;line-height:1.5;color:#444;font-size:.9rem}.start-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1.5rem}.game-title{font-size:3rem;font-weight:700;letter-spacing:.2em;color:#8b7355}.tagline{font-style:italic;color:#666;font-size:1.1rem}.ai-selector{display:flex;align-items:center;gap:1rem}.ai-selector label{font-weight:700}.ai-buttons{display:flex;gap:.5rem}.ai-buttons button{width:3rem;height:3rem;border:2px solid #8B7355;background:transparent;color:#8b7355;font-size:1.2rem;font-weight:700;cursor:pointer;border-radius:4px}.ai-buttons button.selected{background:#8b7355;color:#fff}.start-button{padding:.75rem 2rem;font-size:1.2rem;font-weight:700;background:#8b7355;color:#fff;border:none;border-radius:4px;cursor:pointer}.start-button:hover{background:#6b5335}.tutorial-start-button{background:#2e8b8b}.tutorial-start-button:hover{background:#1e6b6b}.rules-button{padding:.5rem 1.5rem;font-size:1rem;background:transparent;color:#8b7355;border:2px solid #8B7355;border-radius:4px;cursor:pointer}.rules-button:hover{background:#8b7355;color:#fff}.rules-btn-small{background:none;border:1px solid rgba(255,255,255,.4);color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center}.rules-btn-small:hover{background:#ffffff26}.bonus-action-indicator{background:#f39c12;color:#fff;font-weight:700;font-size:.85rem;padding:.25rem 1rem;border-radius:4px;text-align:center;animation:pulse-bonus 1s infinite;margin-bottom:.5rem}@keyframes pulse-bonus{0%,to{opacity:1}50%{opacity:.7}}.action-button{padding:.4rem 1rem;background:#8b7355;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.action-button:hover{background:#6b5335}.action-hint{color:#ccc;font-size:.85rem;font-style:italic}.action-bar{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}.ai-notification{padding:.4rem 1rem;text-align:center;font-size:.85rem;font-weight:700;animation:ai-notif-slide .3s ease}@keyframes ai-notif-slide{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.ai-notif-route{background:#8b7355;color:#fff}.ai-notif-mail{background:#2e8b8b;color:#fff}.ai-notif-supply{background:#b8860b;color:#fff}.ai-notif-unknown{background:#555;color:#fff}.game-screen{height:100vh;display:flex;flex-direction:column}.game-layout{display:flex;flex-direction:column;height:100%}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#2a2a2a;color:#fff;font-size:.9rem}.main-area{display:flex;flex:1;overflow:hidden}.map-area{flex:1;display:flex;align-items:center;justify-content:center;background:#f5f0e6;overflow:auto}.sidebar{width:280px;display:flex;flex-direction:column;gap:.5rem;padding:.5rem;background:#e8e0d0;overflow-y:auto}.player-hand{padding:.75rem;background:#3e2723;color:#fff;min-height:100px}.placeholder{padding:.5rem;color:#999;font-style:italic;text-align:center}.player-score{padding:.25rem .5rem;font-size:.9rem}.player-score.active{font-weight:700;color:#8b7355}.game-over-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.win-title{color:#2e8b8b;font-size:2.5rem;letter-spacing:.15em}.loss-title{color:#c0392b;font-size:2.5rem;letter-spacing:.15em}.game-over-subtitle{color:#666;font-style:italic}.final-scores{width:100%;max-width:400px}.final-scores h2{text-align:center;margin-bottom:.5rem}.score-entry{display:flex;flex-wrap:wrap;justify-content:space-between;padding:.5rem;border-bottom:1px solid #ddd}.score-entry.winner{background:#f0f8f0;font-weight:700}.score-breakdown{width:100%;font-size:.8rem;color:#888}.game-stats{color:#666;font-size:.9rem;text-align:center}.game-stats p{margin:.25rem 0}
