:root{--color-plain:#a7f3d0;--color-mountain:#065f46;--color-water:#3b82f6;--color-ghost:#80808080;--color-start:#ef4444;--color-end:#10b981;--color-bg:#1e293b;--color-text:#f8fafc;--color-border:#334155;--color-road:#475569;--app-height:100vh;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--color-text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle,#0f172a 0%,#020617 100%);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.5}@supports (height:100dvh){:root{--app-height:100dvh}}html{width:100%;min-height:var(--app-height);height:100%}body{width:100%;min-height:var(--app-height);height:var(--app-height);-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;margin:0;display:block;overflow:hidden}#root{width:100%;min-height:var(--app-height);text-align:center;height:100%;margin:0;padding:0}.no-animations *,.no-animations :before,.no-animations :after{transition:none!important;animation:none!important}.card-item{cursor:pointer;background:linear-gradient(145deg,#2a3b52,#1e293b);border:2px solid #0000;border-radius:12px;flex-direction:column;width:140px;height:200px;padding:12px;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;overflow:visible;box-shadow:0 4px 6px -1px #0003,0 2px 4px -1px #0000001a}.card-item.is-stacked:before,.card-item.is-stacked:after{content:"";border-radius:inherit;pointer-events:none;z-index:-1;background:linear-gradient(145deg,#334155f2,#0f172aeb);border:2px solid #94a3b81f;position:absolute;inset:0}.card-item.is-stacked:before{opacity:.72;transform:translate(7px,7px)scale(.985)}.card-item.is-stacked:after{opacity:.38;transform:translate(14px,14px)scale(.97)}.card-stack-count{color:#f8fafc;text-align:center;background:#0f172aeb;border:1px solid #94a3b84d;border-radius:999px;min-width:30px;padding:4px 8px;font-size:.75rem;font-weight:800;line-height:1;position:absolute;top:8px;left:8px;box-shadow:0 8px 18px #00000040}.card-item:hover{z-index:10;transform:translateY(-16px)scale(1.05);box-shadow:0 10px 15px -3px #0000004d}.card-item.selected{z-index:20;border-color:#fbbf24;transform:translateY(-24px)scale(1.1);box-shadow:0 0 20px #fbbf2466}.card-cost{color:#fbbf24;background:#00000080;border-radius:12px;align-items:center;gap:4px;padding:4px 8px;font-size:.875rem;font-weight:700;transition:all .3s;display:flex;position:absolute;top:8px;right:8px}.cost-penalty{animation:1s infinite alternate pulse-danger;color:#fff!important;background-color:#ef4444!important}@keyframes pulse-danger{0%{transform:scale(1);box-shadow:0 0 #ef444466}70%{transform:scale(1.05);box-shadow:0 0 0 15px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.card-name{text-shadow:1px 1px 2px #00000080;margin:20px 0 4px;font-size:1.125rem}.card-type-label{color:#fff9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.65rem}.card-desc{color:#fffc;background:#0003;border-radius:6px;flex:1;padding:8px;font-size:.75rem;line-height:1.4}.card-road{border-top:4px solid var(--color-plain)}.card-bridge{border-top:4px solid var(--color-water)}.card-tunnel{border-top:4px solid var(--color-mountain)}.card-facility{border-top:4px solid #f59e0b}.card-demolish{border-top:4px solid #ef4444}.card-special{border-top:4px solid #a855f7}.card-mud{background:linear-gradient(145deg,#7a5530,#4a3420);border-top:4px solid #8b5e34}.card-charges-container{width:100%;margin-top:10px}.card-charges-bar{background:#0006;border:1px solid #ffffff1a;border-radius:10px;height:18px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0000004d}.card-charges-fill{background:linear-gradient(90deg,#10b981,#34d399);border-radius:10px;height:100%;transition:width .3s}.card-charges-text{color:#fff;text-shadow:0 1px 2px #000c;pointer-events:none;white-space:nowrap;font-size:.7rem;font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@media (width<=900px),(height<=520px){.card-item{border-radius:6px;width:74px;height:112px;padding:6px}.card-name{margin:8px 0 2px;font-size:.7rem}.card-type-label{margin-bottom:2px;font-size:.45rem}.card-desc{padding:3px;font-size:.5rem;line-height:1.1}.card-cost{padding:1px 4px;font-size:.6rem;top:3px;right:3px}.card-stack-count{min-width:22px;padding:2px 5px;font-size:.55rem;top:4px;left:4px}.card-item.is-stacked:before{transform:translate(4px,4px)scale(.985)}.card-item.is-stacked:after{transform:translate(8px,8px)scale(.97)}.card-charges-bar{height:10px}.card-charges-text{font-size:.5rem}.card-item:hover{transform:translate(8px)scale(1.02)}.card-item.selected{transform:translate(14px)scale(1.05)}}.card-item.is-ashing{pointer-events:none!important;z-index:1000!important;box-shadow:none!important;background:0 0!important;border-color:#0000!important;transition:none!important;animation:1.3s cubic-bezier(.5,0,.5,1) forwards card-shake-framework!important}.card-item.is-ashing>:not(.ash-particles-container){animation:.8s forwards content-dissolve}@keyframes content-dissolve{0%{filter:sepia()hue-rotate(-30deg)saturate(5);opacity:1}30%{filter:sepia()hue-rotate(-50deg)saturate(8)brightness(.5);opacity:.8}to{filter:sepia()hue-rotate(-50deg)saturate(10)brightness(0);opacity:0;transform:scale(.5)}}@keyframes card-shake-framework{0%,to{transform:translate(0)}10%,30%{transform:translate(-4px,2px)rotate(-2deg)}20%,40%{transform:translate(4px,-2px)rotate(2deg)}50%{transform:translate(-2px,-3px)rotate(0)}}.ash-particles-container{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.ash-frag{opacity:0;background:#1e293b;border-radius:2px;animation:1.3s cubic-bezier(.2,.8,.2,1) forwards frag-fly;position:absolute;box-shadow:0 0 5px #ef4444}.frag-1{width:40px;height:30px;animation-delay:.1s;top:10%;left:10%}.frag-2{width:50px;height:40px;animation-delay:.2s;top:20%;left:40%}.frag-3{width:30px;height:50px;animation-delay:.15s;top:50%;left:20%}.frag-4{width:60px;height:25px;animation-delay:50ms;top:70%;left:30%}.frag-5{width:35px;height:35px;animation-delay:.25s;top:40%;left:60%}.frag-6{width:25px;height:20px;animation-delay:.3s;top:30%;left:20%}@keyframes frag-fly{0%{opacity:1;background:#2a3b52;transform:translate(0)scale(1)rotate(0)}30%{background:#ef4444}to{opacity:0;transform:translate(var(--tx,50px), var(--ty,-150px)) scale(.2) rotate(var(--rot,180deg));background:#000}}.frag-1{--tx:-60px;--ty:-180px;--rot:-120deg}.frag-2{--tx:80px;--ty:-150px;--rot:200deg}.frag-3{--tx:-40px;--ty:-200px;--rot:90deg}.frag-4{--tx:100px;--ty:-120px;--rot:-80deg}.frag-5{--tx:20px;--ty:-250px;--rot:300deg}.frag-6{--tx:-80px;--ty:-100px;--rot:150deg}.ash-spark{background:#fbbf24;border-radius:50%;width:6px;height:6px;animation:1.3s ease-out forwards spark-fly;position:absolute}@keyframes spark-fly{0%{opacity:1;transform:translate(0)scale(1);box-shadow:0 0 15px 2px #ef4444}to{opacity:0;transform:translate(var(--tx,0), var(--ty,-200px)) scale(.2);box-shadow:0 0 5px #fbbf24}}.spark-1{--tx:-50px;--ty:-220px;animation-delay:.1s;top:50%;left:50%}.spark-2{--tx:80px;--ty:-180px;animation-delay:.2s;top:30%;left:70%}.spark-3{--tx:20px;--ty:-260px;animation-delay:50ms;top:80%;left:30%}.card-area{z-index:100;pointer-events:none;background:linear-gradient(#0000 0%,#0f172ab3 30%,#0f172af2 100%);justify-content:center;align-items:flex-end;height:220px;padding:0 40px 20px;display:flex;position:fixed;bottom:0;left:0;right:0}.card-area>*{pointer-events:auto}.hand-container{z-index:1;justify-content:center;align-items:flex-end;min-width:0;margin-bottom:10px;display:flex}.hand-container .card-item{margin-left:-40px;animation:.4s cubic-bezier(.34,1.56,.64,1) backwards card-draw-in}.hand-container .card-item.suppress-entry-animation{animation:none!important}.hand-container .card-item:first-child{margin-left:0}.hand-container.is-discarding-all .card-item{animation:.4s ease-in forwards card-discard-all!important}.hand-container .card-item.is-exiting{z-index:100;pointer-events:none;white-space:nowrap;overflow:hidden;animation:.3s ease-in forwards card-discard-all,.3s ease-in forwards card-exit-shrink!important}@keyframes card-draw-in{0%{opacity:0;transform:translate(-400px,150px)rotate(-45deg)scale(.3)}to{opacity:1;transform:translate(0)rotate(0)scale(1)}}@keyframes card-discard-all{to{opacity:0;transform:translate(400px,150px)rotate(45deg)scale(.3)}}@keyframes card-exit-shrink{to{opacity:0;width:0;margin-left:0;padding-left:0;padding-right:0}}.action-piles{z-index:10;flex-direction:column;align-items:flex-end;gap:12px;display:flex;position:absolute;bottom:30px;right:40px}.pile-controls{align-items:flex-end;gap:12px;display:flex;position:relative}.piles-info{z-index:10;color:#94a3b8;border:1px solid var(--color-border);background:#1e293be6;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;width:80px;height:100px;padding:0;transition:all .2s;display:flex;box-shadow:0 4px 12px #00000080}.pile-trigger{cursor:pointer}.pile-trigger:hover,.pile-trigger.is-active{color:#e2e8f0;border-color:#60a5fab3;transform:translateY(-2px);box-shadow:0 8px 20px #3b82f638}.pile-count{color:var(--color-text);margin:4px 0;font-size:1.5rem;font-weight:700}.pile-label{font-size:.7rem}.end-turn-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:172px;height:60px;padding:0 24px;font-size:1rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 14px #3b82f663}.end-turn-btn:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.end-turn-btn:active{transform:translateY(0)}.end-turn-btn:disabled{cursor:not-allowed;opacity:.65;transform:none;box-shadow:0 4px 14px #1e40af2e}.pile-viewer-popover{z-index:101;width:200px;max-height:min(240px, calc(var(--app-height) - 260px));color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto;background:#1e293bf2;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;animation:.18s ease-out forwards popupslide;display:flex;position:absolute;bottom:calc(100% + 12px);right:0;box-shadow:0 10px 25px #00000080}@keyframes popupslide{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pile-viewer-header{background:#ffffff0d;border-bottom:1px solid #ffffff1a;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.pile-viewer-header h3{color:#f8fafc;margin:0;font-size:.95rem;font-weight:600}.pile-viewer-content{max-height:min(190px, calc(var(--app-height) - 320px));scrollbar-width:none;-ms-overflow-style:none;padding:12px 16px;overflow-y:auto}.pile-viewer-content::-webkit-scrollbar{display:none}.pile-item{color:#cbd5e1;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:8px 0;font-size:.9rem;display:flex}.pile-item:last-child{border-bottom:none}.pile-count-badge{border-radius:10px;padding:2px 8px;font-size:.8rem;font-weight:700}.pile-empty{color:#64748b;text-align:center;padding:16px 0;font-size:.9rem}@media (width<=900px),(height<=520px){.card-area{--card-area-controls-width:144px;background:0 0;justify-content:flex-start;align-items:stretch;height:auto;padding:0;inset:84px 0 0}.hand-container{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:flex-start;width:82px;margin:0;padding:8px 0;position:fixed;top:94px;bottom:12px;left:10px}.hand-container .card-item{margin-top:-82px;margin-left:0}.hand-container .card-item:first-child{margin-top:0}.action-piles{width:var(--card-area-controls-width);align-items:stretch;gap:8px;position:fixed;bottom:10px;right:10px}.pile-controls{justify-content:flex-end;gap:6px}.piles-info{border-radius:8px;width:46px;height:64px}.piles-info svg{width:16px!important;height:16px!important}.pile-count{margin:2px 0;font-size:.9rem}.pile-label{font-size:.5rem}.end-turn-btn{border-radius:8px;width:100%;height:40px;padding:0 10px;font-size:.75rem}.end-turn-btn svg{width:16px!important;height:16px!important}.pile-viewer-popover{width:min(152px,100vw - 24px);max-height:min(170px, calc(var(--app-height) - 220px))}.pile-viewer-header{padding:8px 10px}.pile-viewer-header h3{font-size:.8rem}.pile-viewer-content{max-height:min(128px, calc(var(--app-height) - 270px));padding:8px 10px}.pile-item{padding:6px 0;font-size:.72rem}.pile-count-badge{padding:2px 6px;font-size:.68rem}}@media (width<=520px){.card-area{--card-area-controls-width:132px}.hand-container{width:74px;left:8px}.hand-container .card-item{margin-top:-78px}.pile-viewer-popover{width:min(136px,100vw - 24px)}}.card-shop-container{z-index:1000;align-items:flex-start;transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:100px;left:0}.card-shop-container.is-closed{transform:translate(-220px)}.card-shop-container.is-open{transform:translate(16px)}.card-shop{-webkit-backdrop-filter:blur(16px);width:180px;max-height:calc(var(--app-height) - 340px);background:#0f172ad9;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;gap:12px;padding:16px;display:flex;box-shadow:0 10px 30px #00000080}.shop-trigger{-webkit-backdrop-filter:blur(12px);cursor:pointer;color:#fff;background:#0f172acc;border:1px solid #ffffff1a;border-radius:0 12px 12px 0;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;transition:all .2s;display:flex;position:absolute;top:20px;left:100%;box-shadow:4px 0 15px #0000004d}.shop-trigger:hover{background:#1e293be6;padding-right:12px}.trigger-text{writing-mode:vertical-lr;letter-spacing:.25em;color:#fff;font-size:.8rem;font-weight:800}.trigger-icon{animation:2s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.shop-header{color:#fff;border-bottom:1px solid #ffffff26;align-items:center;gap:8px;padding-bottom:8px;font-size:.95rem;font-weight:800;display:flex}.shop-items{scrollbar-width:none;-ms-overflow-style:none;flex-direction:column;gap:10px;display:flex;overflow-y:auto}.shop-items::-webkit-scrollbar{display:none}.shop-balance{background:#ffffff0a;border:1px solid #ffffff14;border-radius:14px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.shop-balance-label{color:#94a3b8;letter-spacing:.04em;font-size:.76rem;font-weight:700}.shop-money-badge{color:#fbbf24;background:#f59e0b1f;border:1px solid #f59e0b4d;border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:5px 10px;font-weight:800;line-height:1;display:inline-flex}.shop-money-badge-compact{padding:4px 8px;font-size:.76rem}.shop-money-icon{flex-shrink:0}.shop-money-value{min-width:1.5ch}.shop-item{background:#ffffff08;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;gap:8px;padding:10px;transition:all .2s;display:flex}.shop-item:hover:not(.locked){background:#ffffff14;border-color:#ffffff4d;transform:scale(1.02)}.shop-item.is-active{background:#22c55e1f;border-color:#22c55e8c;box-shadow:0 0 0 1px #22c55e33}.item-info{align-items:center;gap:10px;display:flex}.item-details{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.item-icon{color:#fff;background:#0f172a99;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.item-name{color:#f8fafc;font-size:.85rem;font-weight:600}.buy-button{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;width:100%;padding:6px 0;font-size:.75rem;font-weight:600;transition:all .2s}.buy-button:hover:not(:disabled){background:#2563eb}.buy-button.is-active{background:#16a34a}.buy-button.is-active:hover:not(:disabled){background:#15803d}.buy-button:disabled{color:#64748b;cursor:not-allowed;background:#334155}.shop-footer{color:#475569;text-align:center;margin-top:4px;font-size:.6rem}@media (width<=900px),(height<=520px){.card-shop-container{pointer-events:none;top:0;left:auto;right:0}.card-shop-container.is-closed,.card-shop-container.is-open{transform:none}.card-shop{width:138px;max-height:calc(var(--app-height) - 204px);pointer-events:auto;opacity:0;border-radius:14px;gap:6px;padding:6px;transition:opacity .22s,transform .22s;position:fixed;top:50%;right:72px;transform:translateY(-50%)translate(18px)}.card-shop-container.is-open .card-shop{opacity:1;transform:translateY(-50%)translate(0)}.card-shop-container.is-closed .card-shop{pointer-events:none}.shop-trigger{pointer-events:auto;background:#0f172a99;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;width:52px;height:52px;padding:0;position:fixed;top:50%;left:auto;right:10px;transform:translateY(-50%);box-shadow:0 10px 24px #00000047}.shop-trigger:hover{background:#1e293be6;padding-right:0}.trigger-text{display:none}.trigger-icon{width:18px;height:18px;animation:none}.shop-trigger svg:last-child{display:none}.shop-balance{border-radius:9px;gap:6px;padding:6px 8px}.shop-balance-label{letter-spacing:.02em;font-size:.62rem}.shop-money-badge{gap:3px;padding:3px 6px;font-size:.66rem}.shop-items{gap:4px}.shop-item{border-radius:9px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px;padding:6px;display:grid}.item-info{gap:6px;min-width:0}.item-icon{border-radius:6px;width:22px;height:22px}.item-details{gap:4px;min-width:0}.item-name{text-overflow:ellipsis;white-space:nowrap;font-size:.66rem;line-height:1.15;overflow:hidden}.shop-money-badge-compact{gap:3px;padding:2px 6px;font-size:.62rem}.buy-button{border-radius:7px;width:auto;min-width:44px;padding:4px 6px;font-size:.62rem;line-height:1.1}.shop-footer{display:none}}@media (width<=520px){.card-shop{width:128px;right:64px}.shop-trigger{width:48px;height:48px;right:8px}.buy-button{min-width:40px;padding:4px 5px;font-size:.58rem}}.disaster-progress-wrapper{flex-direction:column;gap:4px;width:90%;margin:4px auto 12px;padding:4px 0 12px;animation:.5s ease-out slide-down;display:flex}.disaster-bar-row{background:#ffffff1a;border:1px solid #ffffff0d;border-radius:4px;height:6px;display:flex;position:relative;overflow:hidden}.bar-half{flex:1;height:100%;position:relative}.bar-half:first-child{border-right:1px solid #fff3}.bar-fill{height:100%;transition:width .3s,left .3s;position:absolute;top:0}.no-transition .bar-fill{transition:none!important}.blue-fill{z-index:1;background:linear-gradient(90deg,#3b82f6,#60a5fa)}.red-fill{z-index:2;background:linear-gradient(90deg,#ef4444,#f87171);box-shadow:0 0 10px #ef444480}.disaster-marker{z-index:10;background-color:#fbbf24;width:2px;height:100%;position:absolute;top:0;box-shadow:0 0 4px #fbbf24}.disaster-ticks{justify-content:space-between;width:100%;padding:0 2px;display:flex}.disaster-ticks span{color:#94a3b8;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:600}@keyframes slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.disaster-progress-wrapper{width:calc(100% - 40px);padding-bottom:8px}}.game-hud-container{z-index:1000;flex-direction:column;align-items:center;gap:12px;width:fit-content;max-width:calc(100vw - 16px);display:flex;position:fixed;top:20px;left:50%;transform:translate(-50%)}.game-hud{-webkit-backdrop-filter:blur(12px);background:#0f172a99;border:1px solid #ffffff1a;border-radius:100px;flex-wrap:nowrap;justify-content:center;align-items:center;gap:clamp(12px,2vw,20px);width:fit-content;max-width:100%;padding:10px clamp(14px,2.4vw,24px);display:flex;box-shadow:0 10px 25px -5px #0000004d}.hud-info-section{flex-wrap:nowrap;flex:0 auto;align-items:center;gap:clamp(12px,2vw,20px);min-width:0;display:flex}.hud-info-item{flex:none;align-items:center;gap:clamp(4px,.8vw,8px);display:flex;position:relative}.hud-info-item:not(:last-child):after{content:"";background:#ffffff1a;width:1px;height:20px;position:absolute;right:-10px}.hud-icon{color:#94a3b8;flex-shrink:0}.hud-content{flex-wrap:nowrap;align-items:baseline;gap:6px;min-width:0;display:flex}.hud-label{color:#64748b;white-space:nowrap;word-break:keep-all;writing-mode:horizontal-tb;font-size:.8rem;font-weight:600}.hud-value{color:#f8fafc;white-space:nowrap;word-break:keep-all;min-width:20px;font-size:1.1rem;font-weight:700}.hud-actions-section{border-left:1px solid #ffffff1a;flex:none;align-items:center;gap:clamp(8px,1.2vw,12px);margin-left:0;padding-left:clamp(10px,2vw,20px);display:flex}.new-game-btn{color:#94a3b8;white-space:nowrap;word-break:keep-all;writing-mode:horizontal-tb;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;justify-content:center;align-items:center;padding:6px 16px;font-size:.85rem;font-weight:700;line-height:1.2;transition:all .2s;display:inline-flex}.new-game-btn:hover{color:#f87171;background:#ef444433;border-color:#ef444480;transform:translateY(-1px)}.settings-btn{color:#94a3b8;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.settings-btn:hover{color:#fff;background:#ffffff1a;transform:rotate(30deg)}.hud-value.warn,.hud-icon.warn{color:#facc15}.hud-value.danger,.hud-icon.danger{color:#f87171}@media (width<=760px),(height<=520px){.game-hud-container{align-items:center;width:fit-content;max-width:calc(100vw - 8px);top:8px;left:50%;right:auto;transform:translate(-50%)}.game-hud{border-radius:24px;flex-wrap:nowrap;justify-content:center;gap:10px;width:fit-content;max-width:100%;padding:8px 12px}.hud-info-section{flex-wrap:nowrap;flex:0 auto;justify-content:flex-start;gap:8px 10px;min-width:0}.hud-info-item{gap:4px}.hud-label,.hud-info-item:not(:last-child):after{display:none}.hud-value{min-width:0;font-size:1rem;line-height:1}.hud-actions-section{align-self:center;gap:6px;margin-left:0;padding-left:8px}.new-game-btn{padding:6px 10px;font-size:.78rem}}@media (width<=460px){.game-hud{flex-direction:column;align-items:stretch;gap:10px;padding:8px 10px}.hud-info-section{justify-content:space-between}.hud-actions-section{border-top:1px solid #ffffff1a;border-left:none;justify-content:flex-end;margin-left:0;padding-top:8px;padding-left:0}.new-game-btn{flex:1}}.leaderboard-side-panel{-webkit-backdrop-filter:blur(8px);z-index:500;-webkit-user-select:none;user-select:none;pointer-events:auto;background:#0f172a66;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;width:180px;padding:12px;transition:transform .3s;display:flex;position:fixed;top:20px;right:20px;box-shadow:0 8px 32px #0003}@media (width<=1200px){.leaderboard-side-panel{opacity:.5}.leaderboard-side-panel:hover{opacity:1}}@media (width<=900px){.leaderboard-side-panel{display:none}}.side-panel-header{border-bottom:1px solid #ffffff0d;align-items:center;gap:6px;margin-bottom:10px;padding-bottom:8px;display:flex;position:relative}.trophy-icon{color:#facc15}.panel-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;flex:1;font-size:.75rem;font-weight:700}.refresh-action{color:#64748b;cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;transition:color .2s;display:flex}.refresh-action:hover{color:#fff}.side-panel-content{flex-direction:column;display:flex}.mini-ranking-list{flex-direction:column;gap:8px;display:flex}.ranking-item{align-items:center;gap:8px;font-size:.85rem;display:flex}.rank-num{color:#64748b;background:#ffffff0d;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;display:flex}.rank-1{color:#facc15;background:#facc1533}.rank-2{color:#e2e8f0;background:#e2e8f026}.rank-3{color:#fb923c;background:#fb923c26}.rank-name{color:#cbd5e1;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.rank-score{color:#3b82f6;font-weight:700}.no-data-hint{color:#475569;text-align:center;padding:10px 0;font-size:.7rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.map-tile{-webkit-user-select:none;user-select:none;cursor:pointer;border-radius:8px;width:100%;height:100%;transition:all .2s;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #0000001a}.map-tile:hover{z-index:10;transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.terrain-plain{background-color:var(--color-plain)}.terrain-mountain{background-color:var(--color-mountain)}.terrain-water{background-color:var(--color-water)}.terrain-void{background-color:#0f172a;background-image:radial-gradient(#1e293b 10%,#0000 10%),radial-gradient(#1e293b 10%,#0000 10%);background-position:0 0,10px 10px;background-size:20px 20px;box-shadow:inset 0 0 10px #000}.is-ghost-point{background-color:var(--color-ghost);z-index:5;border:3px solid #ffffff4d;border-radius:50%;width:24px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.point-indicator{z-index:5;border-radius:50%;width:24px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px #00000080}.is-start{background-color:var(--color-start);border:3px solid #fff;animation:2s infinite start-target-ping}.is-end{background-color:var(--color-end);border:3px solid #fff;animation:2s infinite end-target-ping}@keyframes start-target-ping{0%{box-shadow:0 0 #ef444499}70%{box-shadow:0 0 0 20px #ef444400}to{box-shadow:0 0 #ef444400}}@keyframes end-target-ping{0%{box-shadow:0 0 #22c55e99}70%{box-shadow:0 0 0 20px #22c55e00}to{box-shadow:0 0 #22c55e00}}.tile-svg{pointer-events:none;z-index:2;width:100%;height:100%;position:absolute;inset:0}.connection-line{stroke:var(--color-road);stroke-width:16px;stroke-linecap:round;stroke-linejoin:round;fill:none}.facility-roundabout{border:8px solid var(--color-road);background-color:var(--color-plain);z-index:3;border-radius:50%;width:28px;height:28px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.facility-overpass{background-color:var(--color-road);z-index:4;width:40px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:2px 2px 4px #0006}.facility-overpass:after{content:"";background-color:var(--color-road);width:12px;height:40px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:2px 2px 4px #0006}.facility-firestation{z-index:10;filter:drop-shadow(0 0 10px #3b82f6);justify-content:center;align-items:center;font-size:36px;animation:.8s infinite alternate fire-flicker;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.is-fire{filter:drop-shadow(0 0 10px #f97316);z-index:10;background-color:#ef44444d;border:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:28px;animation:.8s infinite alternate fire-flicker;display:flex}@keyframes fire-flicker{0%{opacity:.9;transform:translate(-50%,-50%)scale(1)}to{opacity:1;transform:translate(-50%,-55%)scale(1.1)}}.edge-node{z-index:20;background-color:#fbbf2466;border:2px solid #fbbf24cc;border-radius:50%;width:20px;height:20px;transition:all .2s;position:absolute}.edge-node:hover{background-color:#fbbf24;transform:scale(1.3)}.edge-top{top:-10px;left:50%;transform:translate(-50%)}.edge-bottom{bottom:-10px;left:50%;transform:translate(-50%)}.edge-left{top:50%;left:-10px;transform:translateY(-50%)}.edge-right{top:50%;right:-10px;transform:translateY(-50%)}.edge-top:hover,.edge-bottom:hover{transform:translate(-50%)scale(1.3)}.edge-left:hover,.edge-right:hover{transform:translateY(-50%)scale(1.3)}.pending-indicator{color:#1e293b;pointer-events:none;z-index:500;background:#fbbf24;border-radius:20px;padding:8px 16px;font-weight:700;animation:1.5s infinite pulse;position:fixed;bottom:240px;left:50%;transform:translate(-50%);box-shadow:0 4px 6px #0003}@keyframes pulse{0%{opacity:.8;transform:translate(-50%)scale(1)}50%{opacity:1;transform:translate(-50%)scale(1.05)}to{opacity:.8;transform:translate(-50%)scale(1)}}.error-indicator{color:#fff;pointer-events:none;z-index:500;background:#ef4444;border-radius:20px;padding:8px 16px;font-weight:700;animation:.4s ease-in-out shake;position:fixed;bottom:240px;left:50%;transform:translate(-50%);box-shadow:0 4px 6px #0003}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (width<=900px),(height<=520px){.edge-node{background-color:#0000;border:none;width:34px;height:34px}.edge-node:after{content:"";box-sizing:border-box;pointer-events:none;background-color:#fbbf2466;border:2px solid #fbbf24cc;border-radius:50%;width:30px;height:30px;transition:background-color .2s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.edge-top{top:-17px;left:50%;transform:translate(-50%)}.edge-bottom{bottom:-17px;left:50%;transform:translate(-50%)}.edge-left{top:50%;left:-17px;transform:translateY(-50%)}.edge-right{top:50%;right:-17px;transform:translateY(-50%)}.edge-node:hover:after,.edge-node:active:after{background-color:#fbbf24}.edge-top:hover,.edge-top:active,.edge-bottom:hover,.edge-bottom:active{transform:translate(-50%)scale(1.18)}.edge-left:hover,.edge-left:active,.edge-right:hover,.edge-right:active{transform:translateY(-50%)scale(1.18)}.pending-indicator,.error-indicator{max-width:calc(100vw - 32px);padding:8px 12px;font-size:.82rem;bottom:158px;left:50%}}:root{--tile-size:64px}.map-container{width:100%;min-height:var(--app-height);height:var(--app-height);background-color:var(--color-bg);scrollbar-width:none;-ms-overflow-style:none;display:flex;position:relative;overflow:auto}.map-container::-webkit-scrollbar{display:none}.map-grid{transform-origin:50%;border-radius:8px;gap:2px;margin:auto;padding:300px;transition:transform .3s;display:grid}.nav-arrow{-webkit-backdrop-filter:blur(8px);color:#fff9;cursor:pointer;z-index:900;background:#ffffff1a;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:all .3s;animation:.4s ease-out forwards arrow-fade-in;display:flex;position:fixed;top:50%;transform:translateY(-50%);box-shadow:0 4px 16px #0003}.nav-arrow:hover{color:#fff;background:#fff3;transform:translateY(-50%)scale(1.1)}.nav-arrow-left{left:20px}.nav-arrow-right{right:20px}@keyframes arrow-fade-in{0%{opacity:0;transform:translateY(-50%)scale(.8)}to{opacity:1;transform:translateY(-50%)scale(1)}}@media (width<=900px),(height<=520px){:root{--tile-size:clamp(48px, 12vw, 56px)}.map-container{box-sizing:border-box;padding-top:84px;padding-bottom:148px}.map-grid{padding:140px 96px}.nav-arrow{border:none;width:36px;height:36px}.nav-arrow svg{width:20px!important;height:20px!important}.nav-arrow-left{left:6px}.nav-arrow-right{right:6px}}@media (width<=520px){.map-grid{padding:120px 72px}}.meteor-strike-overlay{z-index:2400;pointer-events:none;--meteor-strike-duration:1.4s;position:fixed;inset:0;overflow:hidden}.meteor-strike-backdrop{animation:meteor-backdrop-fade var(--meteor-strike-duration) ease-out forwards;background:radial-gradient(circle at 52% 62%,#38bdf814 0%,#38bdf800 18%),radial-gradient(circle at 54% 66%,#f9731629 0%,#f9731600 26%),linear-gradient(#0206171f 0%,#02061794 100%);position:absolute;inset:0}.meteor-trail-layer{filter:drop-shadow(0 0 10px #fde04738);width:100%;height:100%;position:absolute;inset:0;overflow:visible}.meteor-tail-line{fill:none;stroke:#fde68a;stroke-linecap:round;stroke-linejoin:round;stroke-width:var(--tail-width,2px);opacity:0;stroke-dasharray:18 82;stroke-dashoffset:100px;animation:meteor-tail-line var(--tail-duration,.82s) ease-out forwards;animation-delay:var(--tail-delay,0s)}.meteor-tail-dot{fill:#f8fafc;opacity:0;transform-box:fill-box;transform-origin:50%;filter:drop-shadow(0 0 8px #ffffff73);animation:meteor-tail-dot var(--tail-dot-duration,.52s) ease-out forwards;animation-delay:var(--tail-dot-delay,0s)}.meteor-body{opacity:0;width:0;height:0;animation:meteor-flight var(--meteor-strike-duration) cubic-bezier(.18, .8, .28, 1) forwards;position:absolute;top:0;left:0}.meteor-polyhedron{width:104px;height:104px;transform-style:preserve-3d;animation:meteor-spin var(--meteor-strike-duration) linear forwards;filter:drop-shadow(0 0 18px #f973166b)drop-shadow(0 0 36px #38bdf82e);position:relative;transform:translate(-50%,-50%)rotateX(58deg)rotateY(-26deg)}.meteor-face{clip-path:polygon(50% 0%,86% 18%,100% 52%,78% 88%,36% 100%,0% 62%,14% 18%);border:1px solid #ffffff29;position:absolute;inset:0}.meteor-face-main{background:linear-gradient(145deg,#fde68a 0%,#f59e0b 34%,#ea580c 62%,#7c2d12 100%);transform:translateZ(22px)}.meteor-face-left{background:linear-gradient(160deg,#facc15f2 0%,#c2410ceb 100%);transform:rotateY(72deg)translateZ(18px)translate(-12px)scale(.94)}.meteor-face-right{background:linear-gradient(170deg,#fbbf24f2 0%,#7c2d12eb 100%);transform:rotateY(-68deg)translateZ(18px)translate(12px)scale(.9)}.meteor-face-top{background:linear-gradient(#ffffff6b 0%,#fbbf24e0 34%,#9a3412eb 100%);transform:rotateX(72deg)translateZ(20px)translateY(-10px)scale(.84)}.meteor-core-face{clip-path:polygon(50% 0%,90% 34%,72% 100%,20% 90%,0% 38%);mix-blend-mode:screen;filter:blur(.6px);background:linear-gradient(145deg,#ffffffeb 0%,#7dd3fcbf 34%,#f9731633 100%);inset:22%;transform:translateZ(34px)}.meteor-crater-target{opacity:0;animation:crater-emerge var(--meteor-strike-duration) ease-out forwards;position:absolute;transform:translate(-50%,-50%)}.meteor-crater-shadow,.meteor-crater-ring,.meteor-crater-core{border-radius:50%;position:absolute;inset:0}.meteor-crater-shadow{filter:blur(16px);background:radial-gradient(#0f172aeb 0%,#0f172a1a 68%,#0000 100%);transform:scale(1.24)}.meteor-crater-ring{animation:crater-ring-pulse var(--meteor-strike-duration) ease-out forwards;background:radial-gradient(#38bdf80d 0%,#0f172a00 72%);border:2px solid #fbbf2485;inset:8% 6%;box-shadow:0 0 26px #f9731638,inset 0 0 18px #38bdf81f}.meteor-crater-core{background:radial-gradient(at 36% 34%,#ffffff29 0%,#4755691f 28%,#020617f5 100%);inset:24% 17%;box-shadow:inset 0 10px 20px #0f172a99}.meteor-crater-dot{opacity:0;background:#fbbf24db;border-radius:50%;animation:.42s ease-out forwards crater-dot-pulse;position:absolute;transform:translate(-50%,-50%)scale(.2);box-shadow:0 0 10px #f9731673}.meteor-impact-burst{width:0;height:0;position:absolute;top:0;left:0;transform:translate(-50%,-50%)}.meteor-impact-flash,.meteor-impact-ring{opacity:0;position:absolute;top:0;left:0;transform:translate(-50%,-50%)}.meteor-impact-flash{width:138px;height:138px;animation:meteor-impact-flash var(--meteor-strike-duration) linear forwards;background:radial-gradient(circle,#ffffffeb 0%,#fde047d6 18%,#f9731647 42%,#0000 72%);border-radius:50%}.meteor-impact-ring{width:162px;height:88px;animation:meteor-impact-ring var(--meteor-strike-duration) ease-out forwards;border:2px solid #38bdf87a;border-radius:50%;box-shadow:0 0 18px #38bdf847,inset 0 0 18px #fbbf2433}.meteor-impact-dot{opacity:0;animation:meteor-impact-dot var(--impact-duration,.42s) ease-out forwards;animation-delay:var(--impact-delay,0s);background:radial-gradient(circle,#fffffff5 0%,#fde047d6 48%,#f97316a3 100%);border-radius:50%;position:absolute;top:0;left:0;transform:translate(-50%,-50%)scale(.22);box-shadow:0 0 12px #f973167a}@keyframes meteor-backdrop-fade{0%{opacity:0}15%{opacity:1}86%{opacity:1}to{opacity:0}}@keyframes meteor-tail-line{0%{opacity:0;stroke-dashoffset:118px}18%{opacity:var(--tail-opacity,.88)}78%{opacity:.38}to{opacity:0;stroke-dashoffset:0}}@keyframes meteor-tail-dot{0%{opacity:0;transform:scale(.25)}22%{opacity:.95}to{opacity:0;transform:scale(.65)}}@keyframes meteor-flight{0%{opacity:0;transform:translate(var(--meteor-start-x), var(--meteor-start-y)) scale(.42) rotate(-28deg)}14%{opacity:1}78%{opacity:1}to{opacity:0;transform:translate(var(--meteor-target-x), var(--meteor-target-y)) scale(1.08) rotate(30deg)}}@keyframes meteor-spin{0%{transform:translate(-50%,-50%)rotateX(58deg)rotateY(-26deg)rotate(0)}to{transform:translate(-50%,-50%)rotateX(78deg)rotateY(24deg)rotate(220deg)}}@keyframes crater-emerge{0%{opacity:.15;transform:translate(-50%,-50%)scale(.82)}45%{opacity:.32}76%{opacity:.88;transform:translate(-50%,-50%)scale(1)}to{opacity:.96;transform:translate(-50%,-50%)scale(1)}}@keyframes crater-ring-pulse{0%{opacity:.25;transform:scale(.88)}72%{opacity:.8;transform:scale(1)}to{opacity:.95;transform:scale(1.06)}}@keyframes crater-dot-pulse{0%{opacity:0;transform:translate(-50%,-50%)scale(.18)}36%{opacity:.88}to{opacity:.25;transform:translate(-50%,-50%)scale(1)}}@keyframes meteor-impact-flash{0%,72%{opacity:0;transform:translate(-50%,-50%)scale(.18)}80%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(2.3)}}@keyframes meteor-impact-ring{0%,74%{opacity:0;transform:translate(-50%,-50%)scale(.35)}82%{opacity:.85;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(1.8)}}@keyframes meteor-impact-dot{0%{opacity:0;transform:translate(-50%,-50%)scale(.2)}22%{opacity:1}to{opacity:0;transform:translate(calc(-50% + var(--impact-x)), calc(-50% + var(--impact-y))) scale(1)}}@media (width<=900px),(height<=520px){.meteor-polyhedron{width:82px;height:82px}.meteor-impact-flash{width:108px;height:108px}.meteor-impact-ring{width:126px;height:72px}}.narrative-overlay{z-index:2000;opacity:0;visibility:hidden;pointer-events:none;background-color:#000;justify-content:center;align-items:center;transition:opacity .5s,visibility .5s;display:flex;position:fixed;inset:0}.narrative-overlay.is-visible{opacity:1;visibility:visible;pointer-events:auto}.narrative-content{text-align:center;padding:20px}.narrative-text{color:#fff;letter-spacing:.5rem;opacity:0;text-shadow:0 0 20px #ffffff80;margin:0;font-size:3rem;font-weight:300;transition:opacity .5s .2s,transform .5s .2s;transform:translateY(10px)}.narrative-overlay.is-visible .narrative-text{opacity:1;transform:translateY(0)}@media (width<=768px){.narrative-text{letter-spacing:.3rem;font-size:1.8rem}}.game-main{width:100%;min-height:var(--app-height);height:100%;position:relative;overflow:hidden}.game-over-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:9999;background:#0f172ae6;justify-content:center;align-items:center;animation:.5s ease-out fade-in;display:flex;position:fixed;inset:0}.game-over-modal{text-align:center;background:#1e293bf2;border:1px solid #ef44444d;border-radius:20px;width:90%;max-width:400px;padding:40px;animation:.4s cubic-bezier(.16,1,.3,1) slide-up;transform:translateY(0);box-shadow:0 0 50px #ef444433}.game-over-icon{color:#ef4444;background:#ef44441a;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 24px;animation:2s infinite pulse-danger;display:flex}.game-over-modal h2{color:#f8fafc;letter-spacing:2px;margin-bottom:12px;font-size:2.5rem}.game-over-modal p{color:#94a3b8;margin-bottom:24px;line-height:1.6}.cheat-warning{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-bottom:24px;padding:12px;font-size:.9rem;font-weight:600;animation:.5s ease-in-out shake;display:flex}.score-submission{flex-direction:column;gap:12px;margin-bottom:32px;display:flex}.score-submission input{color:#fff;background:#0f172a80;border:1px solid #ffffff1a;border-radius:12px;outline:none;padding:12px 16px;font-size:1rem;transition:border-color .2s}.score-submission input:focus{background:#0f172acc;border-color:#3b82f6}.submit-score-btn{color:#60a5fa;cursor:pointer;background:#3b82f626;border:1px solid #3b82f64d;border-radius:12px;justify-content:center;align-items:center;padding:12px;font-weight:700;transition:all .2s;display:flex}.submit-score-btn:hover:not(:disabled){color:#fff;background:#3b82f6}.submit-score-btn:disabled{opacity:.5;cursor:not-allowed}.submission-success{background:#10b9811a;border:1px solid #10b98133;border-radius:12px;margin-bottom:32px;padding:16px}.view-rank-btn{color:#10b981;cursor:pointer;background:0 0;border:none;margin-top:8px;font-weight:600;text-decoration:underline}.spinning{animation:1s linear infinite spin}.restart-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ef4444 0%,#b91c1c 100%);border:none;border-radius:12px;width:100%;padding:14px 32px;font-size:1.125rem;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #ef44444d}.restart-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.restart-btn:active{transform:translateY(0)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
