:root{color-scheme:light;--paper: #efe8d2;--paper-deep: #d7cba7;--ink: #292720;--muted: #726b5c;--line: #a3977b;--green: #3f744b;--red: #a34836;--teal: #2f6764;--shadow: rgba(41, 39, 32, .18);font-family:Georgia,Times New Roman,serif}*{box-sizing:border-box}html,body,#app{height:100%;overflow:hidden;overscroll-behavior:none}body{margin:0;min-height:100%;color:var(--ink);background:linear-gradient(rgba(80,63,38,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(80,63,38,.08) 1px,transparent 1px),#e8dcc0;background-size:28px 28px}button,input,select{font:inherit}.shell{display:grid;grid-template-rows:auto minmax(0,1fr);gap:0;width:100vw;height:100vh;height:100dvh;min-height:0;padding:0}.start-shell,.loading-shell{display:grid;place-items:center;width:100vw;min-height:100vh;min-height:100dvh;padding:20px}.loading-card{display:grid;justify-items:center;gap:14px;width:min(320px,calc(100vw - 32px));padding:22px;border:1px solid rgba(41,39,32,.34);background:#efe8d2fa;box-shadow:0 20px 60px #2927203d;text-align:center}.loading-card h1{margin:0;font-size:28px;line-height:1}.loading-card p{color:var(--muted)}.loading-mark{width:34px;height:34px;border:3px solid rgba(84,76,58,.28);border-top-color:var(--ink);border-radius:50%;animation:loading-spin .9s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.top-strip{display:grid;grid-template-columns:auto auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:8px 12px;border:0;border-bottom:1px solid var(--line);background:#efe8d2f5;box-shadow:0 10px 30px #2927201f;z-index:10}.game-area{display:grid;grid-template-columns:minmax(0,1fr) clamp(280px,24vw,360px);grid-template-rows:minmax(0,1fr);position:relative;height:100%;min-height:0}.board-wrap{position:relative;min-width:0;min-height:0;height:100%;border:0;background:var(--paper);box-shadow:0 16px 44px var(--shadow);overflow:auto;overscroll-behavior:contain;scrollbar-color:#7f755e #d7cba7;scrollbar-width:auto;touch-action:none;-webkit-overflow-scrolling:touch;-webkit-user-select:none;user-select:none}.board-wrap.is-panning,.board-wrap.is-panning canvas{cursor:grabbing}.board-wrap::-webkit-scrollbar{width:20px;height:20px}.board-wrap::-webkit-scrollbar-track{background:#d7cba7;border:1px solid rgba(84,76,58,.26)}.board-wrap::-webkit-scrollbar-thumb{border:4px solid #d7cba7;border-radius:999px;background:#7f755e}.board-wrap::-webkit-scrollbar-thumb:hover{background:#5f5746}.board-wrap::-webkit-scrollbar-corner{background:#d7cba7}canvas{display:block;cursor:crosshair;touch-action:none}.konvajs-content{touch-action:none!important}.map-stage{position:relative;touch-action:pan-x pan-y}.building-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hex-popup{position:absolute;z-index:3;width:220px;padding:10px;border:1px solid rgba(41,39,32,.34);background:#efe8d2f5;box-shadow:0 10px 24px #2927202e;font-size:13px;pointer-events:none}.hex-popup h2{margin-bottom:6px}.map-building-icon{position:absolute;display:grid;place-items:center;width:32px;height:32px;border:3px solid currentColor;border-radius:50%;background:#f5ecd2;color:inherit;transform:translate(-50%,-50%)}.map-building-icon svg{display:block;width:18px;height:18px}.map-building-icon small{position:absolute;left:50%;bottom:-17px;transform:translate(-50%);color:#292720;font-size:10px;font-weight:700}.map-key{position:sticky;left:14px;top:14px;z-index:6;display:flex;flex-wrap:wrap;width:fit-content;gap:8px;margin:14px 0 -54px 14px;padding:8px 10px;border:1px solid rgba(84,76,58,.28);background:#efe8d2eb;font-size:13px}.map-key span{display:inline-flex;align-items:center;gap:6px}.mode-switch{display:inline-grid;grid-template-columns:1fr 1fr 1fr;overflow:hidden;border:1px solid rgba(41,39,32,.35);background:#fff9e3b8}.mode-switch button{min-height:28px;padding:4px 10px;border:0;border-radius:0;background:transparent;font-size:13px}.mode-switch button+button{border-left:1px solid rgba(41,39,32,.24)}.mode-switch button.is-active{background:var(--ink);color:var(--paper)}.map-mode-switch{justify-self:start}.map-mode-switch button{display:grid;grid-template-columns:16px auto;align-items:center;gap:5px;min-height:38px;padding:4px 9px;white-space:nowrap}.map-mode-switch svg{display:block;width:16px;height:16px}.map-mode-switch small{font-size:11px;line-height:1}.map-profile-badge{position:fixed;right:12px;bottom:12px;z-index:30;display:grid;gap:2px;max-width:min(340px,calc(100vw - 24px));padding:8px 10px;border:1px solid rgba(41,39,32,.28);background:#efe8d2f5;box-shadow:0 10px 28px #2927202e;color:var(--ink);font-size:11px;line-height:1.25;pointer-events:none}.map-profile-badge strong{font-size:12px}.language-toggle{display:inline-grid;grid-template-columns:1fr 1fr;overflow:hidden;width:fit-content;border:1px solid rgba(41,39,32,.35);background:#fff9e3b8}.language-toggle button{min-height:30px;padding:4px 9px;border:0;border-radius:0;background:transparent;font-size:12px}.language-toggle button+button{border-left:1px solid rgba(41,39,32,.24)}.language-toggle button.is-active{background:var(--ink);color:var(--paper)}.main-menu{position:relative}.main-menu summary{display:grid;place-items:center;gap:4px;width:38px;height:38px;border:1px solid #6e644d;background:#f5ecd2;cursor:pointer;list-style:none}.main-menu summary::-webkit-details-marker{display:none}.main-menu summary span{display:block;width:18px;height:2px;background:currentColor}.menu-popover{position:absolute;left:0;top:46px;z-index:20;display:grid;gap:10px;width:300px;max-width:calc(100vw - 24px);padding:8px;border:1px solid rgba(41,39,32,.34);background:#efe8d2fa;box-shadow:0 14px 34px #29272038}.menu-game-info{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.menu-game-info div{display:grid;gap:2px;min-width:0;padding:7px;border:1px solid rgba(84,76,58,.22);background:#fffae86b}.menu-game-info span,.menu-player em{color:var(--muted);font-size:11px;font-style:normal}.menu-game-info strong,.menu-player b{min-width:0;overflow:hidden;color:var(--ink);font-size:13px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.menu-player-list{display:grid;gap:5px}.menu-player{display:grid;grid-template-columns:12px minmax(0,1fr) auto;gap:7px;align-items:center;min-width:0}.menu-player i{width:12px;height:12px;border:1px solid rgba(41,39,32,.28);border-radius:50%}.menu-link{display:block;border-top:1px solid rgba(84,76,58,.24);padding:9px 10px;color:var(--ink);text-decoration:none}.menu-link:hover,.menu-link:focus-visible{background:#29272014;outline:none}.start-card{display:grid;gap:12px;width:min(420px,calc(100vw - 32px));max-height:calc(100dvh - 32px);overflow:auto;padding:18px;border:1px solid rgba(41,39,32,.34);background:#efe8d2fa;box-shadow:0 20px 60px #2927203d}.start-card label,.setup-field{display:grid;gap:5px;color:var(--muted);font-size:13px}.start-card h1{margin:0 0 2px;color:var(--ink);font-size:28px;line-height:1}.session-links{display:grid;gap:8px;max-height:220px;overflow:auto;scrollbar-color:#7f755e #d7cba7;scrollbar-width:auto}.session-links:empty{display:none}.session-links input{width:100%;min-width:0;color:var(--ink);font-size:11px}.link-copy-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px}.link-copy-row button{min-width:72px;padding:5px 8px;border:1px solid #6e644d;background:#f5ecd2;color:var(--ink);cursor:pointer;font-size:12px}.link-copy-row button:hover,.link-copy-row button:focus-visible{background:#eadcb9;outline:none}.menu-popover .session-links{max-height:180px}.menu-language,.menu-debug{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;border-top:1px solid rgba(84,76,58,.24);padding:8px 10px 0;color:var(--muted);font-size:12px}.menu-debug input{width:18px;height:18px;margin:0;accent-color:var(--ink)}.player-slots{display:grid;gap:7px}.player-slot{display:grid;grid-template-columns:minmax(84px,1fr) minmax(72px,.85fr) minmax(78px,.85fr);gap:6px;align-items:center;padding:7px;border:1px solid rgba(84,76,58,.26);background:#fffae87a}.player-slot.is-disabled{opacity:.58}.slot-enabled{display:flex!important;flex-direction:row;align-items:center;gap:7px!important;color:var(--ink)!important}.slot-enabled input{width:16px;height:16px;margin:0}.setup-warning{margin:-2px 0 0;color:var(--red);font-size:12px;line-height:1.25}.terrain{width:13px;height:13px;border:1px solid rgba(41,39,32,.35)}.terrain.meadow{background:#d7d59b}.terrain.forest{background:#7fa16c}.terrain.hill{background:#bba36f}.terrain.water{background:#8db2bc}.panel{display:grid;grid-template-columns:1fr;align-items:start;gap:14px;min-width:0;padding:14px;border:1px solid var(--line);border-top:0;border-right:0;border-bottom:0;background:#efe8d2f0;box-shadow:0 16px 44px var(--shadow);overflow-y:auto;scrollbar-color:#7f755e #d7cba7;scrollbar-width:auto}.map-dock{position:relative;grid-column:2;grid-row:1;z-index:5;height:100%;max-height:none}.panel::-webkit-scrollbar{width:18px;height:18px}.panel::-webkit-scrollbar-track{background:#d7cba7;border:1px solid rgba(84,76,58,.26)}.panel::-webkit-scrollbar-thumb{border:4px solid #d7cba7;border-radius:999px;background:#7f755e}.panel::-webkit-scrollbar-thumb:hover{background:#5f5746}.title-block{display:grid;gap:4px}.eyebrow,.label{margin:0;color:var(--muted);font-size:12px;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin:0}h2{margin-bottom:8px;font-size:15px}.turn-actions{display:grid;grid-template-columns:auto auto auto;align-items:center;gap:8px}.connection-badge{display:inline-block;width:10px;height:10px;border:1px solid rgba(41,39,32,.38);border-radius:50%;background:var(--muted);box-shadow:0 0 0 2px #fff9e3c7}.connection-badge.is-connected{background:var(--green)}.connection-badge.is-working{background:#bf8a26}.connection-badge.is-offline{background:var(--red)}.connection-badge.is-idle{background:var(--muted)}.turn-pill{display:grid;place-items:center;min-height:38px}.turn-counter{position:relative;display:grid;place-items:center;width:32px;height:32px;border-radius:50%;color:var(--paper);font-weight:700;box-shadow:0 0 0 2px #29272047}.is-bot-turn .turn-counter:after{content:"";position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border:2px solid currentColor;border-radius:50%;opacity:.5;animation:bot-turn-pulse 1.15s ease-out infinite}@keyframes bot-turn-pulse{to{top:-12px;right:-12px;bottom:-12px;left:-12px;opacity:0}}button{min-height:38px;border:1px solid #6e644d;background:#f5ecd2;color:var(--ink);cursor:pointer}button:hover{background:#fff6d9}button:disabled{color:#2927207a;background:#d7cba76b;cursor:not-allowed}.primary{padding:8px 10px;background:var(--ink);color:var(--paper)}.resources{display:flex;flex-wrap:nowrap;justify-content:center;gap:8px;overflow-x:auto;padding-bottom:2px}.resources span{position:relative;display:grid;grid-template-columns:26px auto auto;grid-template-rows:auto auto;align-items:center;column-gap:7px;min-width:82px;padding:2px 10px;font-size:13px}.resources span+span:before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:1px;background:#544c3a57}.resources i{display:grid;place-items:center;width:22px;height:22px;font-style:normal;font-weight:700}.resources svg,.mini-resource svg{display:block;width:16px;height:16px}.resources b{font-size:17px;line-height:1}.resources em{grid-column:2;color:var(--muted);font-style:normal;font-size:10px;line-height:1}.resource-delta-badge{grid-column:3;grid-row:1 / span 2;align-self:center;min-width:24px;padding:0;border:0;background:transparent;color:var(--muted);font-size:11px;font-weight:700;line-height:1.2;text-align:center}.resource-delta-badge.is-positive{color:var(--green)}.resource-delta-badge.is-negative{color:var(--red)}.build-list{display:grid;gap:8px}.empty{color:var(--muted);font-size:14px;line-height:1.35}.build-button{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:10px;width:100%;padding:8px;text-align:left}.build-icon{position:relative;display:grid;place-items:center;width:38px;height:38px;border:2px solid currentColor;border-radius:50%;font-weight:700}.build-icon svg,.dialog-icon svg,.building-large-icon svg{display:block;width:20px;height:20px}.road-icon{border-radius:6px;color:var(--teal)}.danger-action .road-icon,.danger-action strong{color:var(--red)}.build-icon small{position:absolute;right:-5px;bottom:-4px;padding:0 3px;border:1px solid currentColor;background:var(--paper);font-size:9px;line-height:1.25}.build-button strong,.build-button small{display:block}.build-button small{margin-top:2px;color:var(--muted)}.worker-line{display:inline-flex!important;align-items:center;gap:4px}.badge-row{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:5px;min-width:112px}.upgrade-cost{justify-content:flex-start;min-width:0;margin-top:6px}.badge{display:inline-flex;align-items:center;gap:4px;min-height:28px;padding:4px 6px;border:1px solid rgba(41,39,32,.38);background:#fff9e3b8;color:var(--ink);font-weight:700}.badge svg{width:16px;height:16px}.badge em{color:var(--red);font-style:normal}.badge.is-missing{border-color:color-mix(in srgb,var(--red) 68%,#6e644d)}.worker-line svg{width:13px;height:13px}.tile-info{min-height:150px;color:var(--muted);font-size:14px}.tile-summary{display:none}.building-info{display:grid;gap:10px;font-size:14px}.building-card{display:grid;grid-template-columns:44px 1fr;align-items:center;gap:10px}.building-card p{margin-top:3px;color:var(--muted);line-height:1.3}.building-large-icon{display:grid;place-items:center;width:42px;height:42px;border:2px solid currentColor;border-radius:50%}dl{display:grid;gap:5px;margin:0 0 8px}dl div{display:flex;justify-content:space-between;gap:12px}dt{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}dd{margin:0;color:var(--ink);text-align:right}.message{color:var(--muted);font-size:13px;line-height:1.35}.seed-row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:auto}input,select{min-width:0;padding:8px;border:1px solid var(--line);background:#fff6d9;color:var(--ink)}.seed-row button{padding:8px 10px}.build-dialog{position:fixed;z-index:40;left:50%;top:56%;transform:translate(-50%,-50%);width:min(460px,calc(100vw - 32px));max-height:min(640px,calc(100dvh - 32px));margin:0;overflow:auto;border:1px solid var(--line);background:var(--paper);color:var(--ink);box-shadow:0 24px 80px #29272057}.build-dialog::backdrop{background:#29272075}.build-dialog form,.dialog-head,.dialog-actions{display:grid;gap:14px}.dialog-head{grid-template-columns:48px 1fr;align-items:center}.dialog-icon{display:grid;place-items:center;width:46px;height:46px;border:2px solid currentColor;border-radius:50%;font-weight:700}.resource-delta{margin-top:14px}.build-risk{display:grid;gap:5px;margin-top:12px;padding:10px;border:1px solid color-mix(in srgb,var(--red) 55%,var(--line));background:#a348361f}.build-risk strong{color:var(--red)}.build-risk p{color:var(--ink);font-size:14px;line-height:1.35}.dialog-actions{grid-template-columns:1fr 1fr}.market-trade{display:grid;gap:8px;padding-top:8px;border-top:1px solid rgba(84,76,58,.24)}.upgrade-box{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;border:1px solid rgba(84,76,58,.28);background:#fff9e36b}.upgrade-box strong,.upgrade-box small{display:block}.upgrade-box small{margin-top:3px;color:var(--muted);line-height:1.3}.upgrade-benefits{margin-top:6px}.upgrade-benefits ul{display:grid;gap:2px;margin:3px 0 0;padding-left:16px;color:var(--muted);line-height:1.3}.trade-row{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr) auto;align-items:center;gap:8px}@media(max-width:980px){.shell{height:100vh;height:100dvh;min-height:0}.game-area{grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr) minmax(148px,28dvh);min-height:0}.top-strip{grid-template-columns:auto auto minmax(0,1fr) auto}.board-wrap{min-height:0;box-shadow:none}.panel{grid-template-columns:1fr;border-top:1px solid var(--line);border-left:0}.map-dock{grid-column:1;grid-row:2;height:auto;max-height:none;padding-bottom:max(14px,env(safe-area-inset-bottom))}.tile-summary{display:grid;gap:6px}.hex-popup{display:none}}@media(max-width:700px){.start-shell{align-items:start;padding-top:max(18px,env(safe-area-inset-top))}.top-strip{grid-template-columns:auto minmax(0,1fr) auto;gap:8px;padding:6px 8px;padding-top:max(6px,env(safe-area-inset-top))}.main-menu{grid-column:1;grid-row:1}.map-mode-switch{grid-column:2;grid-row:1;justify-self:start;max-width:100%}.map-mode-switch button{grid-template-columns:14px auto;gap:4px;min-height:34px;padding:3px 5px}.map-mode-switch svg{width:14px;height:14px}.map-mode-switch small{max-width:54px;overflow:hidden;font-size:10px;text-overflow:ellipsis}.menu-popover{position:fixed;left:8px;top:calc(52px + env(safe-area-inset-top));width:min(300px,calc(100vw - 16px));max-height:calc(100dvh - 70px);overflow:auto}.resources{grid-column:1 / -1;grid-row:2;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));justify-content:flex-start;gap:0;overflow:hidden;padding:2px 0 0}.resources span{grid-template-columns:18px minmax(0,1fr) auto;min-width:0;min-height:35px;padding:4px 5px;border:0;background:transparent;font-size:11px}.resources span+span:before{display:block;top:4px;bottom:4px}.resources span:nth-child(4n+1):before{display:none}.resources b{font-size:16px}.resources em{grid-column:1 / -1;display:block;overflow:hidden;font-size:9px;text-overflow:ellipsis;white-space:nowrap}.resources i{width:18px;height:18px}.resources svg{width:14px;height:14px}.resource-delta-badge{grid-column:3;grid-row:1;min-width:0;padding:0;font-size:10px}.turn-actions{grid-column:3;grid-row:1;display:flex;align-items:center;justify-content:end;gap:6px;justify-self:end;min-width:0;white-space:nowrap}.turn-pill,.main-menu summary{flex:0 0 auto;min-height:44px;height:44px}.language-toggle button{min-height:34px;padding-inline:8px}.primary{flex:0 1 auto;min-width:0;padding-inline:8px}.map-dock{min-height:0}.trade-row{grid-template-columns:1fr}.map-key{left:8px;top:8px;gap:5px;max-width:calc(100vw - 32px);margin:8px 0 -48px 8px;padding:6px;font-size:12px}.panel{gap:10px;padding:10px}.panel dl div{gap:8px}.panel dd{overflow-wrap:anywhere}.build-button{grid-template-columns:40px minmax(0,1fr)}.build-button .badge-row{grid-column:1 / -1;justify-content:flex-start;min-width:0}.badge{min-height:32px;padding:5px 7px}.build-dialog{z-index:60;left:50%;top:auto;bottom:max(12px,env(safe-area-inset-bottom));transform:translate(-50%);width:calc(100vw - 20px);max-height:min(76dvh,620px)}}
