:root{font-family:Inter,Microsoft YaHei,PingFang SC,Segoe UI,sans-serif;color:#172033;background:#edf1f5;font-synthesis:none;text-rendering:geometricPrecision}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{min-height:38px;border:1px solid #cbd5df;border-radius:6px;background:#fff;color:#172033;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 13px;cursor:pointer}button:hover:not(:disabled){border-color:#64748b}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:#1f6f5f;border-color:#1f6f5f;color:#fff}button.ready{background:#26344f;border-color:#26344f;color:#fff}input{width:100%;min-height:38px;border:1px solid #cbd5df;border-radius:6px;padding:8px 10px;background:#fff;color:#172033}label{display:grid;gap:6px;color:#475569;font-size:.9rem}.app-shell{min-height:100vh;padding:18px}.topbar,.game-header,.section-head,.map-toolbar,.header-actions,.button-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar{margin:0 auto 16px;max-width:1440px}.topbar-actions{display:flex;align-items:center;gap:10px}.help-button{min-height:34px;padding:0 12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:18px;background:#0f172a6b}.rules-dialog{width:min(920px,100%);max-height:82vh;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;border:1px solid #cbd5df;border-radius:8px;background:#fff;box-shadow:0 24px 70px #0f172a52}.rules-dialog-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:1px solid #e4eaf1}.rules-dialog-body{overflow:auto;display:grid;gap:14px;padding:18px}.rules-section{display:grid;gap:8px}.rules-section ul{margin:0;padding-left:20px;color:#475569;line-height:1.55}.eyebrow{color:#6b7280;font-size:.74rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin:0}h1{font-size:1.65rem}h2{font-size:1.35rem}h3{font-size:1rem}.status-pill{min-height:32px;display:inline-flex;align-items:center;gap:7px;padding:0 10px;border:1px solid #d8dee7;border-radius:999px;background:#fff;color:#475569;white-space:nowrap}.error-banner{max-width:1440px;margin:0 auto 14px;padding:10px 12px;border-radius:6px;background:#fce7e7;border:1px solid #f5b7b7;color:#8c1d1d}.join-layout,.lobby,.game-grid{max-width:1440px;margin:0 auto}.join-layout{display:grid;grid-template-columns:minmax(320px,460px) minmax(280px,1fr);gap:18px;align-items:start}.join-panel,.note-panel,.room-browser,.control-panel,.players-panel,.player-status-rail,.market-panel,.log-panel,.table-surface,.lobby>section,.lobby>aside{background:#fff;border:1px solid #d9e1ea;border-radius:8px;box-shadow:0 10px 24px #252f3f14}.join-panel,.note-panel,.room-browser,.control-panel,.players-panel,.player-status-rail,.market-panel,.log-panel,.lobby>section,.lobby>aside{padding:16px}.join-panel{display:grid;gap:14px}.account-key-row{display:grid;grid-template-columns:minmax(0,1fr) 42px;gap:8px}.panel-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:8px;background:#e4f3ef;color:#1f6f5f}.note-panel ul{margin:12px 0 0;padding-left:20px;color:#475569;line-height:1.65}.room-browser{display:grid;gap:14px}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.room-card{display:grid;gap:10px;min-height:150px;padding:12px;border:1px solid #dde5ee;border-radius:7px;background:#f8fafc}.room-card.locked{background:#f5f1e6}.room-card-head{display:flex;justify-content:space-between;gap:10px}.room-card-head strong,.room-card-head span,.room-card p{overflow-wrap:anywhere}.room-card-head strong{display:block;font-size:1.08rem}.room-card-head span,.room-card p{color:#64748b;font-size:.84rem}.room-count{min-width:48px;height:28px;display:inline-grid;place-items:center;border:1px solid #d8dee7;border-radius:999px;background:#fff;color:#475569}.room-player-dots{display:flex;min-height:18px;align-items:center;gap:6px}.room-player-dots span{width:13px;height:13px;border-radius:999px;border:2px solid #ffffff;box-shadow:0 0 0 1px #47556933}.room-player-dots span.offline{opacity:.35}.empty-rooms{min-height:160px;display:grid;place-items:center;align-content:center;gap:8px;border:1px dashed #cbd5df;border-radius:8px;color:#64748b;background:#f8fafc}.lobby{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px}.control-panel{display:grid;gap:12px;align-content:start}.seat-grid,.player-list{display:grid;gap:10px;margin-top:14px}.seat-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}.player-card{display:grid;grid-template-columns:16px 1fr;gap:10px;align-items:center;min-height:58px;padding:10px;border-radius:7px;border:1px solid #dde5ee;background:#f8fafc}.player-card.active{border-color:#1f6f5f;background:#edf7f4}.player-card strong,.player-card span,.player-card em{display:block}.player-card span,.player-card em{color:#64748b;font-size:.82rem;font-style:normal;margin-top:3px}.color-dot{width:12px;height:12px;border-radius:999px;box-shadow:0 0 0 3px #fff}.game-grid{display:grid;grid-template-columns:260px minmax(0,1fr) 230px;gap:10px;align-items:start}.table-surface{padding:8px;min-width:0}.game-header{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e5eaf0}.step-banner{display:grid;grid-template-columns:auto repeat(3,minmax(0,1fr));gap:8px;align-items:stretch;margin-bottom:8px}.step-banner>div,.step-banner>p{min-height:42px;display:grid;align-content:center;padding:7px 10px;border:1px solid #d9e1ea;border-radius:7px;background:#f8fafc;color:#475569;font-size:.8rem;line-height:1.3}.step-banner span{color:#64748b;font-size:.72rem}.step-banner strong{color:#172033;font-size:.95rem}.side-rail{display:grid;gap:10px}.player-status-rail{position:sticky;top:12px}.status-list{display:grid;gap:10px;margin-top:12px}.status-card{display:grid;gap:10px;padding:11px;border:1px solid #dde5ee;border-radius:7px;background:#f8fafc}.status-card.active{border-color:#1f6f5f;background:#edf7f4}.status-card.self{box-shadow:inset 3px 0 #26344f}.status-card-head{display:grid;grid-template-columns:14px minmax(0,1fr) auto;align-items:center;gap:8px}.status-card-head strong,.status-card dd{overflow-wrap:anywhere}.status-card-head em{min-width:24px;padding:2px 6px;border-radius:999px;background:#26344f;color:#fff;font-size:.72rem;font-style:normal;text-align:center}.status-card dl{display:grid;gap:7px;margin:0}.status-card dl div{display:grid;grid-template-columns:42px 1fr;gap:8px;align-items:start}.status-card dt{color:#64748b;font-size:.78rem}.status-card dd{margin:0;color:#172033;font-size:.86rem;line-height:1.35}.status-plant-list{display:grid;gap:6px;padding-top:2px}.status-plant-list>span{color:#64748b;font-size:.82rem}.status-plant-list>div{display:grid;grid-template-columns:28px minmax(0,1fr);gap:7px;align-items:center;min-height:28px;padding:5px 6px;border:1px solid #dde5ee;border-radius:6px;background:#fff}.status-plant-list strong{width:24px;height:22px;display:grid;place-items:center;border-radius:5px;background:#26344f;color:#fff;font-size:.76rem}.status-plant-list span{min-width:0;color:#475569;font-size:.78rem;line-height:1.25;overflow-wrap:anywhere}.map-wrap{display:grid;gap:8px}.map-toolbar{align-items:center;min-height:44px}.map-toolbar-left{min-width:0;display:flex;align-items:center;gap:8px}.map-canvas{width:100%;aspect-ratio:720 / 780;border-radius:8px;border:1px solid #cbd5df;background:#f8fafc}.map-canvas.board-photo-map{background:#d5a769;border-color:#80633c}.map-canvas.china-vector-map{background:#d0a764;border-color:#695334}.map-stage{position:relative}.stage-strip{min-width:0;display:flex;align-items:center;gap:14px;padding:8px 10px;border:1px solid #d9e1ea;border-radius:7px;background:#f8fafc}.stage-strip-title{display:flex;align-items:baseline;gap:8px;white-space:nowrap}.stage-strip-title span{color:#64748b;font-size:.76rem}.stage-strip-title strong{font-size:.95rem}.stage-dot-row{min-width:0;display:flex;align-items:center;gap:7px}.stage-dot{width:13px;height:13px;border-radius:50%;border:2px solid #ffffff;box-shadow:0 0 0 1px #47556940}.stage-dot.active{width:16px;height:16px;box-shadow:0 0 0 2px #172033}.map-complexity-badge{min-height:42px;display:grid;grid-template-columns:auto auto;grid-template-rows:auto auto;column-gap:10px;row-gap:3px;align-items:center;padding:7px 10px;border:1px solid #d9e1ea;border-radius:7px;background:#fff;white-space:nowrap}.map-complexity-badge strong{font-size:.88rem}.map-complexity-badge span{color:#64748b;font-size:.78rem}.complexity-meter{grid-column:1 / -1;display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.complexity-meter i{height:4px;border-radius:999px;background:#dbe3ec}.complexity-meter i.on{background:#1f6f5f}.map-board-base{fill:#d7bf82;stroke:#596241;stroke-width:7}.map-land-mass{fill:#b9c58d;stroke:#45543b;stroke-width:3}.map-sea{fill:#3f8fb4;opacity:.92}.map-coastline{fill:none;stroke:#fff2bfb8;stroke-linecap:round;stroke-width:9}.map-island{fill:#7fb36a;stroke:#45543b;stroke-width:2.5}.map-region{opacity:.9;stroke-width:2.4}.map-region.inactive{opacity:.34}.map-river{fill:none;stroke:#2382b16b;stroke-width:6;stroke-linecap:round}.map-river.secondary{stroke-width:5;opacity:.75}.route-shadow{stroke:#f6f2dde6;stroke-width:9;stroke-linecap:round}.route-line{stroke:#4f6064;stroke-width:4;stroke-linecap:round}.edge-cost{font-size:13px;font-weight:700;fill:#334155;paint-order:stroke;stroke:#fff;stroke-width:4px;text-anchor:middle}.city{-webkit-user-select:none;user-select:none}.city.clickable{cursor:pointer}.city.clickable:hover circle:first-of-type{stroke:#1f6f5f}.image-map-city circle:first-of-type{transition:fill .12s ease,stroke .12s ease,stroke-width .12s ease}.image-map-city.clickable:hover circle:first-of-type{fill:#1f6f5f33;stroke:#fff;stroke-width:4px}.vector-map-city circle:first-of-type{fill:#eef7ec;stroke:#31424a;filter:drop-shadow(0 2px 1px rgba(31,41,55,.22))}.vector-map-city.clickable:hover circle:first-of-type{fill:#f8fff4;stroke:#1f6f5f;stroke-width:4px}.city-label-layer{pointer-events:none}.vector-map-city .city-label{font-size:10.5px;stroke-width:4.5px}.city-label{font-size:13px;font-weight:700;fill:#172033;pointer-events:none;paint-order:stroke;stroke:#fff;stroke-linejoin:round;stroke-width:5.5px}.plant-picker,.resource-grid,.mini-plants,.resource-stocks{display:grid;gap:8px}.plant-picker button{display:grid;grid-template-columns:18px minmax(0,1fr);justify-content:space-between;min-height:52px;padding:7px 10px;text-align:left}.plant-picker button>svg{justify-self:center}.plant-picker button>strong{min-width:0;overflow-wrap:anywhere}.plant-picker button>span{grid-column:2;justify-self:start;white-space:normal;color:#475569;font-size:.82rem}.plant-picker button.selected{border-color:#1f6f5f;background:#edf7f4}.resource-grid label{grid-template-columns:1fr 82px;align-items:center}.resource-grid label span{font-size:.85rem}.resource-stocks{grid-template-columns:repeat(4,1fr)}.resource-stocks span,.mini-plants .plant{min-height:32px;display:grid;place-items:center;border:1px solid #dde5ee;border-radius:6px;background:#f8fafc;font-size:.82rem}.mini-plants{grid-template-columns:repeat(4,1fr);margin-top:10px}.mini-plants .plant{gap:2px;padding:6px;text-align:center}.mini-plants .plant span{font-size:.76rem;line-height:1.2}.mini-plants .current{border-color:#1f6f5f;background:#edf7f4}.mini-plants .future{background:#f5f1e6}.log-panel ol{margin:10px 0 0;padding-left:20px;color:#475569;line-height:1.45;font-size:.86rem}.winner{border-color:#c9a227;background:#fff8e5}@media(max-width:1100px){.lobby,.join-layout{grid-template-columns:1fr}.game-grid{grid-template-columns:190px minmax(0,1fr);max-width:1020px}.player-status-rail{position:static;grid-column:1;grid-row:1 / span 2}.status-list{grid-template-columns:1fr}.table-surface,.side-rail{grid-column:2}}@media(max-width:700px){.app-shell{padding:10px}.topbar,.game-header,.map-toolbar,.header-actions,.topbar-actions,.button-row{align-items:stretch;flex-direction:column}.step-banner{grid-template-columns:1fr}.map-toolbar-left{width:100%;align-items:stretch;flex-direction:column}.resource-stocks,.mini-plants{grid-template-columns:repeat(2,1fr)}.game-grid{grid-template-columns:1fr}.player-status-rail,.table-surface,.side-rail{grid-column:auto;grid-row:auto}.status-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stage-strip{flex-wrap:wrap}}
