:root{--col-bg:#0a0a0a;--col-surface:#111;--col-surface-deep:#0d0d0d;--col-border:#333;--col-border-dim:#222;--col-text:#d4d4d8;--col-text-muted:#71717a;--col-text-dim:#52525b;--col-text-faint:#3f3f46;--col-tile-empty:var(--col-border);--col-white:#fff;--palette-1:#3fc697;--palette-2:#3fb1c6;--palette-3:#3f6ec6;--palette-4:#c63f6e;--palette-5:#c6973f;--palette-1-hi:oklch(from var(--palette-1) calc(l * 1.2) calc(c * .8) h);--palette-1-mid:oklch(from var(--palette-1) calc(l * .75) c h);--palette-1-dim:oklch(from var(--palette-1) calc(l * .52) c h);--palette-1-bg:oklch(from var(--palette-1) calc(l * .38) calc(c * .5) h);--palette-3-hi:oklch(from var(--palette-3) calc(l * 1.2) calc(c * .8) h);--palette-3-mid:oklch(from var(--palette-3) calc(l * .75) c h);--palette-3-dim:oklch(from var(--palette-3) calc(l * .5) c h);--palette-3-muted:oklch(from var(--palette-3) calc(l * .45) calc(c * .25) h);--palette-4-hi:oklch(from var(--palette-4) calc(l * 1.15) calc(c * .8) h);--palette-4-dim:oklch(from var(--palette-4) calc(l * .55) c h);--palette-5-mid:oklch(from var(--palette-5) calc(l * .75) c h);--palette-5-dim:oklch(from var(--palette-5) calc(l * .52) c h);--col-player:var(--palette-1);--col-peer:var(--palette-2);--col-accent:var(--palette-3);--col-accent-hi:var(--palette-3-mid);--col-enemy:var(--palette-4);--col-resource:var(--palette-5);--col-gold:var(--palette-5);--col-settlement:var(--palette-5);--col-accent-glow:#3f6ec680;--col-enemy-glow:#c63f6eb3;--col-settlement-glow-lo:#c6973f59;--col-settlement-glow-hi:#c6973fd9;--col-green:#6f6;--col-red:#f66;--col-orange:#fa0;--col-amber:#f90;--col-fire:#f60;--col-combat:#f33;--col-building:#a1a1aa;--col-danger-text:#f96;--col-danger-border:#644;--col-spawn-reason:#a44;--col-unit-1:var(--palette-1-mid);--col-unit-2:var(--palette-1);--col-unit-3:var(--palette-1-hi);--col-unit-4:oklch(from var(--palette-1) calc(l * 1.3) calc(c * .6) h);--col-grass:var(--palette-1-mid);--col-tree:var(--palette-1-dim);--col-sapling:oklch(from var(--palette-1) calc(l * .62) c h);--col-water:var(--palette-3-dim);--col-mud:oklch(38% .06 60);--col-farm:var(--palette-5-dim);--col-road:var(--col-text-muted);--col-btn-bg:#141420;--col-progress-green:#1a4a2a;--col-progress-red:#4a1a1a;--col-btn-border:#446;--col-btn-hover:#1e2a38;--col-btn-danger-hover:#2a1a1a;--col-btn-ranged-border:#466;--col-btn-ranged-hover:#1a2a2a;--col-channeling-border:#2a6a3a;--col-tile-hover:#1a1a1a;--col-tile-selected-bg:oklch(from var(--palette-1) calc(l * .28) calc(c * .45) h);--col-buildable:var(--col-grass);--col-buildable-hover:oklch(from var(--palette-1) calc(l * .22) calc(c * .35) h);--col-farm-buildable:var(--col-farm);--col-farm-hover:oklch(from var(--palette-5) calc(l * .22) calc(c * .35) h);--col-spawn-hover-bg:#151515;--col-radius-bg:oklch(from var(--palette-1) calc(l * .38) c h / .18);--col-unit-1-bg:oklch(from var(--palette-1) calc(l * .38) c h / .28);--col-unit-2-bg:oklch(from var(--palette-1) calc(l * .38) c h / .5);--col-unit-3-bg:oklch(from var(--palette-1) calc(l * .38) c h / .68);--col-unit-4-bg:oklch(from var(--palette-1) calc(l * .38) c h / .85);--col-farm-zone-bg:oklch(from var(--palette-5) calc(l * .35) c h / .15);--col-telegraph-bg:#c8960059;--col-telegraph-border:#ffc80099;--col-hit-bg:#dc32328c;--col-hit-border:#ff5050e6;--col-dpad-bg:#05050fd9;--col-overlay-bg:#0a0a0af7}[data-theme=ocean]{--palette-1:#3fc697;--palette-2:#3fb1c6;--palette-3:#3f6ec6;--palette-4:#c63f6e;--palette-5:#c6973f;--col-accent-glow:#3f6ec680;--col-enemy-glow:#c63f6eb3;--col-settlement-glow-lo:#c6973f59;--col-settlement-glow-hi:#c6973fd9}[data-theme=desert]{--palette-1:#d8622c;--palette-2:#d8b92c;--palette-3:#a2d82c;--palette-4:#2ca2d8;--palette-5:#622cd8;--col-accent-glow:#a2d82c80;--col-enemy-glow:#2ca2d8b3;--col-settlement-glow-lo:#622cd859;--col-settlement-glow-hi:#622cd8d9}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--col-bg);color:var(--col-text);padding:8px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:20px}@media (width>=640px){body{padding:16px}}#root{text-align:left;width:100%;max-width:100%;min-height:100dvh;display:block}.ascii-game{flex-direction:column;gap:.75rem;margin:0 auto;display:flex}body{height:100dvh;overflow:hidden}#root{min-height:unset;height:100%}.ascii-game{height:100%}.ascii-game__body{flex:1;min-height:0}.ascii-game__map{flex-direction:column;flex:1;justify-content:flex-end;min-height:0;padding:0}.ascii-map-wrap{flex:1;justify-content:center;align-items:flex-end;width:100%;min-height:0;display:flex;container-type:size}.ascii-map-wrap .ascii-map__row{height:4.7619cqmin}.ascii-map-wrap .ascii-tile{width:4.7619cqmin;height:4.7619cqmin;font-size:4.28571cqmin}.ascii-game__top{border:1px solid var(--col-border);background:var(--col-surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:6px 8px;display:flex}.ascii-game__body{flex-direction:column;align-items:stretch;gap:.75rem;display:flex}.ascii-game__map{border:1px solid var(--col-border);background:var(--col-surface);justify-content:center;min-width:0;padding:6px 8px;display:flex;overflow:hidden}.ascii-game__side{flex-direction:column;gap:.5rem;display:flex}.resource-bar{color:var(--col-accent);flex-wrap:wrap;gap:1rem;display:flex}.protection-status{font-size:18px}.protection-status--foundingProtected{color:var(--col-accent-hi)}.protection-status--foundingReady{color:var(--col-gold)}.protection-status--combatActive{color:var(--col-red)}.ascii-map{-webkit-user-select:none;user-select:none;font-size:13px;line-height:0}.ascii-map__row{height:14px;display:flex}.ascii-tile{cursor:default;width:14px;height:14px;color:var(--col-tile-empty);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;line-height:1;display:inline-flex}@media (width<=899px){.ascii-game__map{border-left:none;border-right:none;margin:0 -8px}}.ascii-tile.tile--clickable{cursor:pointer}.ascii-tile.tile--clickable:hover{background:var(--col-tile-hover)}.ascii-tile.tile--selected{background:var(--col-tile-selected-bg);color:var(--col-white)}.tile--unit{color:var(--col-accent)}.tile--player{color:var(--col-player)}.tile--peer{color:var(--col-peer)}.tile--worker{color:var(--col-accent)}.tile--guard{color:var(--col-accent-hi)}.tile--enemy{color:var(--col-enemy)}.tile--raider{color:var(--col-enemy);text-shadow:0 0 5px var(--col-enemy-glow)}.ascii-tile.tile--on-mud{animation:.18s ease-out forwards mudSink}@keyframes mudSink{0%{transform:translateY(0)}to{transform:translateY(3px)}}.tile--building{color:var(--col-building)}.tile--core{color:var(--col-settlement);animation:2.2s ease-in-out infinite corePulse}.tile--depot,.tile--worker-hut,.tile--barracks{color:var(--col-building)}.tile--watchtower{color:var(--col-accent-hi);text-shadow:0 0 4px var(--col-accent-glow)}.tile--lumber-camp,.tile--farm,.tile--wall{color:var(--col-building)}.tile--gate{color:var(--col-accent)}.tile--resource{color:var(--col-resource)}.tile--tree{color:var(--col-tree)}.tile--log{position:relative;color:#0000!important}.tile--log:before{content:"t";color:var(--col-resource);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(90deg)}.tile--chopping{transform-origin:bottom;animation:.3s ease-in-out infinite treeChop}@keyframes treeChop{0%{transform:rotate(0)}20%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}80%{transform:rotate(-4deg)}to{transform:rotate(0)}}.tile--log.tile--harvesting:before{animation:.4s ease-in-out infinite treeHarvest}@keyframes treeHarvest{0%,to{transform:translate(-50%,-50%)rotate(90deg)}30%{transform:translate(-50%,-50%)rotate(83deg)}70%{transform:translate(-50%,-50%)rotate(97deg)}}.tile--constructing{animation:.45s cubic-bezier(.2,.8,.3,1) forwards buildingRise,.8s ease-in-out .45s infinite buildingBlink}@keyframes buildingRise{0%{clip-path:inset(0 0 100%);opacity:.6}to{clip-path:inset(0);opacity:1}}@keyframes buildingBlink{0%,to{opacity:1}50%{opacity:.2}}.tile--unknown{color:#0000;pointer-events:none}.tile--explored{pointer-events:none;opacity:.45;position:relative}.tile--explored:after{content:"?";color:oklch(55% .04 220);opacity:0;justify-content:center;align-items:center;animation:3s step-end infinite exploredToggle;display:flex;position:absolute;inset:0}@keyframes exploredToggle{50%{opacity:1}}.tile--terrain{color:var(--col-text-faint)}.tile--grass{color:var(--col-grass)}.tile--mud{color:var(--col-mud)}.tile--water{color:var(--col-water)}.tile--sapling{color:#0000;position:relative}.tile--sapling:after{content:"t";color:var(--col-sapling);justify-content:center;align-items:center;font-size:.6em;display:flex;position:absolute;inset:0}.tile--road{color:var(--col-road)}.tile--settlement{color:var(--col-settlement)}.tile--combat{color:var(--col-combat);font-weight:700}.tile--route-danger{color:var(--col-amber)}.tile--projectile{color:var(--col-white);font-weight:700}.tile--in-radius{background:var(--col-radius-bg)}.tile--farm-zone{background:var(--col-farm-zone-bg)}.tile--buildable{color:var(--col-buildable)}.tile--buildable:hover{background:var(--col-buildable-hover)}.tile--farm-buildable{color:var(--col-farm-buildable)}.tile--farm-buildable:hover{background:var(--col-farm-hover)}.tile--has-unit{background:var(--col-unit-1-bg);color:var(--col-unit-1)!important}.tile--crowded{background:var(--col-unit-2-bg);color:var(--col-unit-2)!important}.tile--unit-packed{background:var(--col-unit-3-bg);color:var(--col-unit-3)!important}.tile--unit-full{background:var(--col-unit-4-bg);color:var(--col-unit-4)!important}@keyframes corePulse{0%,to{text-shadow:0 0 4px var(--col-settlement-glow-lo)}50%{text-shadow:0 0 12px var(--col-settlement-glow-hi)}}.tile--hit{animation:.18s ease-out hitFlash}@keyframes hitFlash{0%{color:#fff;text-shadow:0 0 12px #fff;transform:scale(1.4)}to{transform:scale(1)}}.screen-wrap{position:relative}.corner-tile-info{z-index:20;opacity:.08;pointer-events:auto;max-width:160px;max-height:50dvh;line-height:1.4;transition:opacity .2s;position:absolute;bottom:8px;left:8px;overflow-y:auto}.corner-tile-info:hover{opacity:.72}.corner-tile-info--active{opacity:.65}.corner-tile-info--active:hover{opacity:.9}.corner-tile-info__label{color:var(--col-accent-hi);font-size:11px}.corner-tile-info__desc{color:var(--col-text-dim);margin-bottom:4px;font-size:10px}.corner-tile-info__btns{flex-wrap:wrap;gap:3px;margin-top:4px;display:flex}.corner-tile-info__btn{padding:2px 5px;font-size:10px}.corner-toasts{z-index:20;pointer-events:none;flex-direction:column;align-items:flex-end;gap:4px;max-width:220px;display:flex;position:absolute;top:8px;right:8px}.corner-toast{background:#00000080;padding:2px 7px;font-size:11px;animation:.25s ease-out forwards toastIn}.corner-toast--out{animation:.45s ease-in forwards toastOut}.corner-toast--info{color:var(--col-text-muted)}.corner-toast--success{color:var(--col-green)}.corner-toast--warning{color:var(--col-orange)}.corner-toast--danger{color:var(--col-red)}@keyframes toastIn{0%{opacity:0;transform:translate(8px)}to{opacity:.82;transform:translate(0)}}@keyframes toastOut{0%{opacity:.82}to{opacity:0}}.screen-wrap--shake{animation:.16s linear screenShake}@keyframes screenShake{0%{transform:translate(0)}20%{transform:translate(-2px,1px)}40%{transform:translate(2px,-1px)}60%{transform:translate(-1px,2px)}80%{transform:translate(1px,-1px)}to{transform:translate(0)}}.screen-flash{pointer-events:none;animation:.2s ease-out forwards screenFlash;position:absolute;inset:0}@keyframes screenFlash{0%{opacity:1}to{opacity:0}}.tile--telegraph{outline:1px solid var(--col-telegraph-border);background:var(--col-telegraph-bg)!important}.tile--active-hit{outline:1px solid var(--col-hit-border);background:var(--col-hit-bg)!important}.tile--projectile{font-weight:700}.tile--proj-arrow{color:var(--col-resource)}.tile--proj-bolt{color:var(--col-accent-hi);text-shadow:0 0 4px var(--col-accent-glow)}.tile--proj-fire{color:var(--col-fire);text-shadow:0 0 6px var(--col-amber)}.ascii-panel{border:1px solid var(--col-border);background:var(--col-surface);font-size:19px}.ascii-panel__title{border-bottom:1px solid var(--col-border);color:var(--col-accent);letter-spacing:.05em;padding:4px 8px;font-size:17px}.ascii-panel__body{flex-direction:column;gap:2px;padding:6px 8px;display:flex}.action-buttons{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.action-button{background:var(--col-btn-bg);border:1px solid var(--col-btn-border);color:var(--col-accent);cursor:pointer;padding:3px 8px;font-family:inherit;font-size:18px}@media (pointer:coarse){.action-button{min-height:44px;padding:8px 12px;font-size:20px}}.action-button:hover:not(:disabled){background:var(--col-btn-hover)}.action-button:disabled{opacity:.4;cursor:not-allowed}.action-button--danger{border-color:var(--col-danger-border);color:var(--col-danger-text)}.action-button--danger:hover:not(:disabled){background:var(--col-btn-danger-hover)}.action-button--channeling{opacity:1;cursor:default;border-color:var(--col-channeling-border);color:var(--col-green)}.build-mode-toggle{opacity:.6;margin-left:auto;padding:2px 8px;font-size:11px}.build-mode-toggle--active{opacity:1;border-color:var(--col-accent);color:var(--col-accent)}.tile-alerts-row{align-items:flex-start;gap:.5rem;display:flex}.tile-alerts-row__tile,.tile-alerts-row__alerts{flex:1;min-width:0}.alert-log__body{max-height:180px;overflow-y:auto}.alert{justify-content:space-between;align-items:baseline;gap:8px;padding:2px 0;font-size:18px;display:flex}.alert--info{color:var(--col-text-muted)}.alert--success{color:var(--col-green)}.alert--warning{color:var(--col-orange)}.alert--danger{color:var(--col-red)}.alert-action{color:var(--col-text-dim);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-family:inherit;font-size:17px}.alert-action:hover{color:var(--col-accent)}.founding-checklist .ascii-panel__body{font-size:18px}.checklist-item--complete{color:var(--col-green)}.checklist-item--pending{color:var(--col-text-dim)}.connecting{color:var(--col-text-muted);padding:2rem}.world-screen{flex-direction:column;gap:0;max-width:900px;margin:0 auto;display:flex}.world-screen__header{border:1px solid var(--col-border);background:var(--col-surface);color:var(--col-accent);border-bottom:none;flex-wrap:wrap;justify-content:space-between;padding:4px 8px;font-size:19px;display:flex}.world-screen__title{color:var(--col-accent-hi);letter-spacing:.05em}.world-screen__info{color:var(--col-text-muted)}.world-screen__viewport{border:1px solid var(--col-border);background:var(--col-surface-deep);color:var(--col-text-muted);letter-spacing:0;padding:6px 8px;font-size:17px;line-height:1.3;overflow:hidden}.world-screen__footer{border:1px solid var(--col-border);background:var(--col-surface);color:var(--col-text-faint);border-top:none;padding:4px 8px;font-size:17px}.spawn-selection{flex-direction:column;gap:0;max-width:900px;height:100dvh;margin:0 auto;display:flex;overflow-y:auto}.spawn-selection__header{border:1px solid var(--col-border);background:var(--col-surface);z-index:1;border-bottom:none;flex-wrap:wrap;justify-content:space-between;gap:4px;padding:4px 8px;font-size:15px;display:flex;position:sticky;top:0}.spawn-selection__title{color:var(--col-accent-hi);letter-spacing:.05em}.spawn-selection__hint{color:var(--col-text-muted)}.spawn-selection__hint--touch{display:none}@media (pointer:coarse){.spawn-selection__hint--pointer{display:none}.spawn-selection__hint--touch{display:block}}.spawn-selection__grid{border:1px solid var(--col-border);background:var(--col-surface-deep);grid-template-columns:1fr;display:grid}@media (width>=600px){.spawn-selection__grid{grid-template-columns:repeat(3,1fr)}}.spawn-option{background:var(--col-surface-deep);border:1px solid var(--col-border-dim);cursor:pointer;color:var(--col-accent);text-align:left;flex-direction:column;gap:4px;padding:8px;font-family:inherit;display:flex}.spawn-option:hover:not(:disabled){background:var(--col-spawn-hover-bg);border-color:var(--col-accent-hi)}.spawn-option:disabled{cursor:not-allowed;opacity:.4}.spawn-option__label{font-size:18px}@media (pointer:coarse){.spawn-option{gap:8px;padding:12px 10px}.spawn-option__label{font-size:20px}}.spawn-option--valid .spawn-option__label{color:var(--col-accent-hi)}.spawn-option--invalid .spawn-option__label{color:var(--col-text-dim)}.spawn-option__preview{width:100%;margin:0;line-height:0;container-type:inline-size}.spawn-option__preview .ascii-map__row{height:4cqw}.spawn-option__preview .ascii-tile{flex-shrink:0;width:4cqw;height:4cqw;font-size:3.6cqw}.spawn-option__reason{color:var(--col-spawn-reason);font-size:16px}.dpad{display:none}@media (pointer:coarse){.dpad__move{flex-direction:column;align-items:center;gap:2px;display:flex}.dpad__row{justify-content:center;gap:2px;display:flex}.dpad__center{width:44px;height:44px}.dpad__btn{background:var(--col-btn-bg);border:1px solid var(--col-btn-border);width:44px;height:44px;color:var(--col-accent);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;justify-content:center;align-items:center;font-family:inherit;font-size:18px;display:flex}.dpad__btn:active{background:var(--col-btn-hover)}.dpad__actions{flex-direction:column;gap:4px;display:flex}.dpad__action-row{gap:4px;display:flex}.dpad__btn--attack{border-color:var(--col-danger-border);color:var(--col-danger-text)}.dpad__btn--attack:active{background:var(--col-btn-danger-hover)}.dpad__btn--ranged{border-color:var(--col-btn-ranged-border);color:var(--col-accent-hi)}.dpad__btn--ranged:active{background:var(--col-btn-ranged-hover)}}@media (width<=1023px) and (pointer:coarse){.dpad{background:var(--col-dpad-bg);flex-shrink:0;justify-content:center;align-items:flex-start;gap:24px;width:100%;padding:10px 12px;display:flex;position:static}}.panel-toggle{display:none}@media (width<=1023px){.panel-toggle{z-index:100;background:var(--col-btn-bg);border:1px solid var(--col-btn-border);width:44px;height:44px;color:var(--col-accent);cursor:pointer;touch-action:manipulation;justify-content:center;align-items:center;font-family:inherit;font-size:20px;display:flex;position:fixed;bottom:16px;right:16px}.ascii-game__side{z-index:50;background:var(--col-overlay-bg);flex-direction:column;gap:.5rem;padding:16px 16px 80px;display:none;position:fixed;inset:0;overflow-y:auto}.ascii-game__side--open{display:flex}}@media (width>=1280px){.tile-alerts-row{flex-direction:column}}@media (width>=1024px){.ascii-game__side{flex-direction:column;gap:.5rem;display:flex}}@media (width>=1280px){.ascii-game__body{grid-template-rows:1fr;grid-template-columns:minmax(0,1fr) 280px;display:grid}.ascii-game__side{max-height:100%;overflow-y:auto}}.vlab{background:var(--col-bg);height:100dvh;color:var(--col-text);flex-direction:column;font-family:Courier New,Courier,monospace;font-size:14px;display:flex;overflow-y:auto}.vlab-header{border-bottom:1px solid var(--col-border-dim);z-index:10;background:var(--col-bg);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 16px;display:flex;position:sticky;top:0}.vlab-title{color:var(--col-accent);letter-spacing:.1em;text-transform:uppercase;margin-right:4px;font-size:15px;font-weight:700}.vlab-nav{flex-wrap:wrap;flex:1;gap:4px;display:flex}.vlab-nav-btn{border:1px solid var(--col-border-dim);color:var(--col-text-muted);cursor:pointer;background:0 0;border-radius:3px;padding:5px 14px;font-family:inherit;font-size:13px;transition:color .1s,border-color .1s,background .1s}.vlab-nav-btn:hover{color:var(--col-text);border-color:var(--col-border)}.vlab-nav-btn--active{color:var(--col-accent);border-color:var(--col-accent);background:#6688cc1a}.vlab-back{color:var(--col-text-muted);white-space:nowrap;margin-left:auto;font-size:13px;text-decoration:none}.vlab-back:hover{color:var(--col-text)}.vlab-page{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex}.vlab-page--cols{flex-direction:column;gap:16px}@media (width>=700px){.vlab-page--cols{flex-direction:row;align-items:flex-start;gap:16px}}.vlab-page-toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.vlab-page-title{text-transform:uppercase;letter-spacing:.12em;color:var(--col-accent);white-space:nowrap;font-size:13px;font-weight:700}.vlab-block{border:1px solid var(--col-border-dim);background:var(--col-surface);border-radius:5px;flex-direction:column;gap:0;padding:14px 16px;display:flex}.vlab-block--grow{flex:1}.vlab-block__title{text-transform:uppercase;letter-spacing:.12em;color:var(--col-accent);margin-bottom:12px;font-size:12px;font-weight:700}.vlab-block__label{color:var(--col-text-muted);margin-bottom:5px;font-size:12px}.vlab-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.vlab-label{color:var(--col-text-muted);min-width:140px;font-size:13px}.vlab-select{background:var(--col-surface-deep);color:var(--col-text);border:1px solid var(--col-border);border-radius:4px;padding:4px 10px;font-family:inherit;font-size:13px}.vlab-slider{accent-color:var(--col-accent);flex:1;width:160px;min-width:80px;max-width:240px}.vlab-frames{gap:6px;display:flex}.vlab-frame{border:1px solid var(--col-border-dim);background:var(--col-surface-deep);width:32px;height:32px;color:var(--col-text-muted);border-radius:3px;justify-content:center;align-items:center;font-size:20px;transition:color .1s,border-color .1s;display:inline-flex}.vlab-frame--active{color:var(--col-text);border-color:var(--col-accent)}.vlab-preview-large{border:1px solid var(--col-border);background:var(--col-surface-deep);border-radius:4px;justify-content:center;align-items:center;width:60px;height:60px;font-size:42px;display:inline-flex}.vlab-btn{background:var(--col-surface-deep);color:var(--col-text-muted);border:1px solid var(--col-border-dim);cursor:pointer;border-radius:3px;padding:5px 12px;font-family:inherit;font-size:13px;transition:color .1s,border-color .1s}.vlab-btn:hover{color:var(--col-text);border-color:var(--col-accent)}.vlab-btn--red{color:var(--col-red);border-color:#553}.vlab-btn--white{color:#ccc;border-color:#444}.vlab-hint{color:var(--col-text-faint);margin:0;font-size:12px}.vlab-filter-tabs{flex-wrap:wrap;gap:4px;display:flex}.vlab-tab{border:1px solid var(--col-border-dim);color:var(--col-text-muted);cursor:pointer;background:0 0;border-radius:3px;padding:4px 11px;font-family:inherit;font-size:12px;transition:color .1s,border-color .1s,background .1s}.vlab-tab:hover{color:var(--col-text);border-color:var(--col-border)}.vlab-tab--active{color:var(--col-accent);border-color:var(--col-accent);background:#6688cc14}.vlab-pill{text-transform:uppercase;letter-spacing:.08em;border:1px solid;border-radius:3px;padding:2px 7px;font-size:11px;font-weight:700;display:inline-block}.vlab-pill--unit{color:#7aabff;background:#7aabff0f;border-color:#3a5a88}.vlab-pill--building{color:#f0c060;background:#f0c0600f;border-color:#806020}.vlab-pill--resource{color:#70c870;background:#70c8700f;border-color:#305030}.vlab-pill--terrain{color:#909090;background:#9090900f;border-color:#404040}.vlab-card-grid{grid-template-columns:1fr;gap:8px;display:grid}@media (width>=420px){.vlab-card-grid{grid-template-columns:1fr 1fr}}@media (width>=680px){.vlab-card-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=960px){.vlab-card-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=1280px){.vlab-card-grid{grid-template-columns:repeat(5,1fr)}}.vlab-card{border:1px solid var(--col-border-dim);background:var(--col-surface);border-radius:4px;flex-direction:column;gap:7px;padding:10px 12px;display:flex}.vlab-card__header{align-items:center;gap:10px;display:flex}.vlab-card__glyph{background:var(--col-surface-deep);border:1px solid var(--col-border-dim);border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;display:flex}.vlab-card__meta{flex-direction:column;gap:4px;min-width:0;display:flex}.vlab-card__name{color:var(--col-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;line-height:1;overflow:hidden}.vlab-card__desc{color:var(--col-text-muted);margin:0;font-size:11px;line-height:1.45}.vlab-stats{border-collapse:collapse;width:100%;font-size:11px}.vlab-stats__row+.vlab-stats__row td{border-top:1px solid var(--col-border-dim)}.vlab-stats__label{color:var(--col-text-dim);white-space:nowrap;vertical-align:top;text-align:center;width:42%;padding:3px 6px 3px 0}.vlab-stats__value{color:var(--col-text);vertical-align:top;word-break:break-word;text-align:center;padding:3px 0}.vlab-proj-tabs{flex-wrap:wrap;gap:4px;margin-bottom:12px;display:flex}.vlab-proj-stats{flex-wrap:wrap;gap:12px;margin-bottom:12px;font-size:13px;display:flex}.vlab-proj-stat{align-items:baseline;gap:5px;display:flex}.vlab-proj-stat-k{color:var(--col-text-dim);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.vlab-proj-track{background:var(--col-surface-deep);border:1px solid var(--col-border-dim);border-radius:3px;padding:8px 10px;display:flex;overflow-x:auto}.vlab-proj-cell{flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:17px;transition:color 60ms;display:inline-flex}.vlab-proj-cell--head{color:var(--col-text)}.vlab-proj-cell--trail{color:var(--col-text-dim)}.vlab-proj-cell--future{color:var(--col-text-faint)}.vlab-proj-frames-wrap{border:1px solid var(--col-border-dim);background:var(--col-surface-deep);border-radius:3px;overflow-x:auto}.vlab-proj-frames{flex-direction:column;min-width:max-content;padding:4px 0;display:flex}.vlab-proj-frame-row{align-items:center;padding:1px 0;display:flex}.vlab-proj-frame-row:hover{background:#ffffff05}.vlab-proj-frame-label{color:var(--col-text-dim);white-space:nowrap;flex-shrink:0;min-width:64px;padding:0 10px;font-size:11px}.vlab-proj-frame-cells{display:flex}.vlab-preview-map{background:var(--col-surface-deep);border:1px solid var(--col-border-dim);border-radius:5px;flex-wrap:wrap;align-items:flex-start;gap:14px;margin-top:10px;padding:14px;display:flex;position:relative}.vlab-preview-item{flex-direction:column;align-items:center;gap:4px;display:flex}.vlab-preview-label{color:var(--col-text-muted);text-align:center;max-width:60px;font-size:11px;line-height:1.2}.screen-flash{pointer-events:none;border-radius:inherit;animation:.25s ease-out forwards flashFade;position:absolute;inset:0}.screen-flash--red{background:#ff323259}.screen-flash--white{background:#ffffff8c}@keyframes flashFade{0%{opacity:1}to{opacity:0}}@media (width<=480px){.vlab{font-size:13px}.vlab-label{min-width:0}.vlab-slider{width:100%;max-width:100%}.vlab-row{flex-direction:column;align-items:flex-start}.vlab-page{gap:12px;padding:12px}.vlab-block{padding:12px 13px}}.vlab-theme-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.vlab-theme-card{all:unset;cursor:pointer;background:var(--col-surface);border:2px solid var(--col-border-dim);border-radius:8px;flex-direction:column;gap:12px;padding:16px;transition:border-color .15s,box-shadow .15s;display:flex}.vlab-theme-card:hover{border-color:var(--col-border)}.vlab-theme-card--active{border-color:var(--col-accent);box-shadow:0 0 12px var(--col-accent-glow)}.vlab-theme-card__header{align-items:center;gap:8px;display:flex}.vlab-theme-card__name{color:var(--col-text);font-size:15px;font-weight:700}.vlab-theme-badge{text-transform:uppercase;letter-spacing:.08em;background:var(--col-accent);color:var(--col-bg);border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.vlab-theme-swatches{gap:6px;display:flex}.vlab-swatch-col{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.vlab-swatch{border:1px solid #ffffff14;border-radius:4px;width:100%;height:28px}.vlab-swatch-label{color:var(--col-text-dim);text-align:center;white-space:nowrap;font-size:9px}.vlab-swatch-hex{color:var(--col-text-faint);text-align:center;font-family:monospace;font-size:9px}.vlab-theme-preview{border-top:1px solid var(--col-border-dim);justify-content:center;align-items:center;gap:10px;padding:8px 0 2px;display:flex}.vlab-shade-group{margin-bottom:16px}.vlab-shade-group__title{color:var(--col-text);margin-bottom:6px;font-size:12px;font-weight:600}.vlab-shade-row{flex-wrap:wrap;gap:6px;display:flex}.vlab-shade-cell{flex-direction:column;flex:1;align-items:center;gap:3px;min-width:68px;display:flex}.vlab-shade-swatch{border:1px solid #ffffff14;border-radius:4px;width:100%;height:22px}.vlab-shade-name{color:var(--col-text-dim);text-align:center;white-space:nowrap;font-family:monospace;font-size:9px}.vlab-shade-uses{color:var(--col-text-faint);text-align:center;font-size:9px;line-height:1.3}
