:root{--text: #5c5348;--text-h: #1c1814;--text-muted: #7a7268;--bg: #f2ebe0;--bg-elevated: #faf6ef;--border: #d4cbc0;--code-bg: #e8dfd2;--panel-inset: rgba(28, 24, 20, .04);--accent: #a33228;--accent-hover: #8a2a22;--accent-bg: rgba(163, 50, 40, .12);--accent-border: rgba(163, 50, 40, .45);--safe: #1d6b4a;--social-bg: rgba(232, 223, 210, .65);--shadow: rgba(28, 24, 20, .08) 0 12px 28px -8px, rgba(28, 24, 20, .06) 0 4px 12px -4px;--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .45);--res-wood: #8b5a1a;--res-wood-bg: rgba(139, 90, 26, .12);--res-stone: #5c6670;--res-stone-bg: rgba(92, 102, 112, .12);--res-iron: #3d4a5c;--res-iron-bg: rgba(61, 74, 92, .14);--res-food: #2f6b4a;--res-food-bg: rgba(47, 107, 74, .12);--res-gold: #b8860b;--res-gold-bg: rgba(184, 134, 11, .14);--res-defense: #4a5a8a;--res-defense-bg: rgba(74, 90, 138, .12);--res-default: var(--text-h);--res-default-bg: rgba(28, 24, 20, .06);--sans: "DM Sans", system-ui, "Segoe UI", sans-serif;--heading: "Cinzel", "Palatino Linotype", Palatino, serif;--mono: ui-monospace, Consolas, monospace;font:17px/150% var(--sans);letter-spacing:.02em;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 1024px){:root{font-size:16px}}html{height:100%}body{margin:0;min-height:100%;min-height:100svh;display:flex;flex-direction:column;background:radial-gradient(ellipse 100% 70% at 50% -15%,rgba(163,50,40,.09),transparent 55%),repeating-linear-gradient(-12deg,transparent,transparent 11px,rgba(92,83,72,.03) 11px,rgba(92,83,72,.03) 12px),var(--bg)}@media (prefers-color-scheme: dark){:root{--text: #b8b0a5;--text-h: #f0ebe4;--text-muted: #8a8278;--bg: #121816;--bg-elevated: #171d1a;--border: #2a3330;--code-bg: #1a2220;--panel-inset: rgba(0, 0, 0, .25);--accent: #e07060;--accent-hover: #e8887a;--accent-bg: rgba(224, 112, 96, .15);--accent-border: rgba(224, 112, 96, .45);--safe: #5cb88a;--social-bg: rgba(26, 34, 32, .65);--shadow: rgba(0, 0, 0, .45) 0 16px 40px -12px, rgba(0, 0, 0, .3) 0 6px 16px -6px;--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .06);--res-wood: #d4a574;--res-wood-bg: rgba(212, 165, 116, .14);--res-stone: #9ca8b0;--res-stone-bg: rgba(156, 168, 176, .12);--res-iron: #a8b4c4;--res-iron-bg: rgba(168, 180, 196, .12);--res-food: #6bcf9a;--res-food-bg: rgba(107, 207, 154, .12);--res-gold: #e8c547;--res-gold-bg: rgba(232, 197, 71, .14);--res-defense: #8a9fd4;--res-defense-bg: rgba(138, 159, 212, .12);--res-default: var(--text-h);--res-default-bg: rgba(255, 255, 255, .05)}body{background:radial-gradient(ellipse 100% 60% at 50% -10%,rgba(224,112,96,.12),transparent 50%),repeating-linear-gradient(-12deg,transparent,transparent 11px,rgba(255,255,255,.02) 11px,rgba(255,255,255,.02) 12px),var(--bg)}#social .button-icon{filter:invert(1) brightness(2)}}#root{flex:1;display:flex;flex-direction:column;width:100%;max-width:100%;min-height:0;margin:0;text-align:center;box-sizing:border-box;background:var(--bg-elevated)}h1,h2{font-family:var(--heading);font-weight:600;color:var(--text-h);letter-spacing:.06em}h1{font-size:40px;letter-spacing:.08em;margin:28px 0}@media (max-width: 1024px){h1{font-size:28px;margin:20px 0}}h2{font-size:18px;line-height:130%;letter-spacing:.1em;text-transform:uppercase;margin:0 0 10px}@media (max-width: 1024px){h2{font-size:16px}}p{margin:0}code,.counter{font-family:var(--mono);display:inline-flex;border-radius:4px;color:var(--text-h)}code{font-size:15px;line-height:135%;padding:4px 8px;background:var(--code-bg)}.auth-layout{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:0;padding:24px;box-sizing:border-box}.ws-connection-banner{align-self:stretch;margin:-8px -8px 16px;padding:12px 16px;border-radius:6px 14px;font-size:14px;line-height:1.45;text-align:center;color:#92400e;background:#f59e0b2e;border:1px solid rgba(217,119,6,.45)}.ws-connection-banner__code{font-family:ui-monospace,monospace;font-size:.88em}.game-screen>.ws-connection-banner{margin:0;border-radius:0;border-left:none;border-right:none;border-top:none;border-bottom:1px solid rgba(217,119,6,.35)}@media (prefers-color-scheme: dark){.ws-connection-banner{color:#fde68a;background:#b4530938;border-color:#fbbf2459}.game-screen>.ws-connection-banner{border-bottom-color:#fbbf2447}}.auth-card{width:100%;max-width:400px;padding:36px 32px;border-radius:6px 18px;background:linear-gradient(165deg,var(--code-bg) 0%,color-mix(in srgb,var(--code-bg) 92%,var(--text-h)) 100%);border:1px solid var(--border);box-shadow:var(--shadow-inset),var(--shadow)}.auth-card--logged-in{text-align:center}.auth-form h2,.auth-card h2{margin:0 0 24px;font-size:22px;font-family:var(--heading);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-h)}.auth-error{margin:0 0 16px;padding:12px 14px;border-radius:6px;border-left:3px solid #b91c1c;background:#dc26261a;color:#991b1b;font-size:14px;text-align:left}@media (prefers-color-scheme: dark){.auth-error{color:#fecaca;border-left-color:#f87171}}.auth-field{margin-bottom:16px}.auth-field label{display:block;margin-bottom:6px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.auth-field input{width:100%;padding:11px 14px;font-size:16px;border:1px solid var(--border);border-radius:6px 12px;background:var(--bg);color:var(--text-h);box-sizing:border-box;box-shadow:inset 0 2px 4px var(--panel-inset)}.auth-field input:focus{outline:2px solid var(--accent);outline-offset:2px}.auth-field input:disabled{opacity:.7;cursor:not-allowed}.auth-submit{width:100%;margin-top:8px;padding:13px 18px;font-size:15px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 92%,#fff) 0%,var(--accent) 100%);border:1px solid color-mix(in srgb,var(--accent) 70%,#000);border-radius:6px 14px;cursor:pointer;box-shadow:var(--shadow-inset),0 2px 8px #a3322840;transition:filter .2s,transform .15s}.auth-submit:hover:not(:disabled){filter:brightness(1.05)}.auth-submit:active:not(:disabled){transform:translateY(1px)}.auth-submit:disabled{opacity:.55;cursor:not-allowed}.auth-submit--secondary,.auth-logout{background:transparent;color:var(--text-h);border:1px solid var(--border);box-shadow:none;margin-top:20px}.game-content .auth-logout{display:block;width:auto;max-width:220px;margin-left:auto;margin-right:auto}.auth-submit--secondary:hover:not(:disabled),.auth-logout:hover:not(:disabled){filter:none;background:var(--accent-bg);border-color:var(--accent-border)}.auth-link{margin:20px 0 0;font-size:14px;color:var(--text)}.auth-link-btn{padding:0;font-size:inherit;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.auth-link-btn:hover{opacity:.85}.auth-welcome{margin:0;font-size:15px;color:var(--text-muted)}.auth-welcome strong{color:var(--text-h);font-weight:600}.auth-status{margin:0;text-align:center;color:var(--text)}.game-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1001;max-width:min(420px,calc(100% - 32px));padding:12px 18px;border-radius:6px 14px;font-size:14px;font-weight:600;letter-spacing:.04em;color:var(--text-h);background:linear-gradient(165deg,var(--bg-elevated) 0%,var(--code-bg) 100%);border:1px solid var(--accent-border);box-shadow:var(--shadow);animation:game-toast-in .25s ease-out}@keyframes game-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.game-screen{flex:1;display:flex;flex-direction:column;min-height:0;width:100%;text-align:left}.game-footer{flex-shrink:0;padding:8px 16px 14px;text-align:center}.game-footer__link{font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--text-muted);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--text-muted) 35%,transparent)}.game-footer__link:hover{color:var(--text);border-bottom-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.resource-bar{flex-shrink:0;padding:14px 20px 16px;background:linear-gradient(180deg,color-mix(in srgb,var(--code-bg) 88%,var(--accent)) 0%,var(--code-bg) 100%);border-bottom:1px solid var(--border);box-shadow:inset 0 -1px #fff3}@media (prefers-color-scheme: dark){.resource-bar{box-shadow:inset 0 -1px #ffffff0a}}.resource-bar__row{display:flex;flex-wrap:wrap;align-items:center;gap:12px 16px}.resource-bar__items{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:stretch;justify-content:flex-start;flex:1 1 0;min-width:0}.resource-bar__profile{display:inline-flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto;padding:8px 12px 8px 14px;border-radius:4px 12px;border:1px solid var(--border);background:var(--bg-elevated);font:inherit;color:var(--text-h);cursor:pointer;box-shadow:var(--shadow-inset);transition:border-color .12s ease,transform .12s ease}.resource-bar__profile:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.resource-bar__profile:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.resource-bar__profile-icon{flex-shrink:0;color:var(--text-muted)}.resource-bar__profile-name{max-width:min(160px,28vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;letter-spacing:.04em}.resource-bar__item{display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:120px;padding:8px 12px 8px 14px;border-radius:4px 12px;border:1px solid var(--border);border-left-width:4px;border-left-color:var(--item-accent, var(--res-default));background:var(--item-bg, var(--res-default-bg));box-shadow:inset 0 1px #ffffff59}@media (prefers-color-scheme: dark){.resource-bar__item{box-shadow:inset 0 1px #ffffff0a}}.resource-bar__item--wood{--item-accent: var(--res-wood);--item-bg: var(--res-wood-bg)}.resource-bar__item--stone{--item-accent: var(--res-stone);--item-bg: var(--res-stone-bg)}.resource-bar__item--iron{--item-accent: var(--res-iron);--item-bg: var(--res-iron-bg)}.resource-bar__item--food{--item-accent: var(--res-food);--item-bg: var(--res-food-bg)}.resource-bar__item--gold{--item-accent: var(--res-gold);--item-bg: var(--res-gold-bg)}.resource-bar__item--clickable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.resource-bar__item--clickable:hover{transform:translateY(-1px);box-shadow:var(--shadow-inset),var(--shadow)}.resource-bar__item--clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.resource-bar__item--defense{--item-accent: var(--res-defense);--item-bg: var(--res-defense-bg)}.resource-bar__name{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}.resource-bar__amount-wrap{position:relative;display:inline-flex;align-items:baseline;gap:6px}.resource-bar__amount{font-weight:700;font-family:var(--mono);font-size:15px;color:var(--text-h);font-variant-numeric:tabular-nums}.resource-bar__amount--full{color:#b91c1c}@media (prefers-color-scheme: dark){.resource-bar__amount--full{color:#f87171}}.resource-bar__delta{font-size:12px;font-weight:700;font-family:var(--mono);animation:resource-delta-pump 1.2s ease-out forwards}.resource-bar__delta--gain{color:var(--safe)}.resource-bar__delta--loss{color:#b91c1c}@media (prefers-color-scheme: dark){.resource-bar__delta--loss{color:#f87171}}@keyframes resource-delta-pump{0%{opacity:1;transform:scale(1)}25%{opacity:1;transform:scale(1.25)}50%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1.15)}}.resource-bar__loading{font-size:13px;font-style:italic;color:var(--text-muted)}.game-main{flex:1;display:flex;align-items:stretch;justify-content:center;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:28px 20px 40px;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(163,50,40,.06),transparent 60%),var(--bg-elevated)}.game-main__stack{width:100%;max-width:100%;display:flex;flex-direction:column;align-items:stretch}.game-content{text-align:center;width:100%;max-width:560px;margin-left:auto;margin-right:auto}.buildings-section--my-buildings{width:100%;max-width:none;margin-left:0;margin-right:0;align-self:stretch;box-sizing:border-box}.buildings-section--my-buildings__inner{width:100%;max-width:none}.buildings-section{margin:20px 0;padding:18px 20px;border-radius:6px 16px;background:var(--code-bg);border:1px solid var(--border);text-align:left;box-shadow:var(--shadow-inset),0 1px #ffffff40}@media (prefers-color-scheme: dark){.buildings-section{box-shadow:var(--shadow-inset),0 1px #ffffff08}}.buildings-section--queue{position:relative;border-left:4px solid var(--accent);overflow:hidden}.buildings-section--queue:after{content:"";position:absolute;left:0;bottom:0;height:3px;width:100%;background:linear-gradient(90deg,transparent,var(--accent),color-mix(in srgb,var(--accent) 40%,transparent),var(--accent),transparent);background-size:200% 100%;animation:construction-shimmer 2s ease-in-out infinite;opacity:.85}@keyframes construction-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.buildings-section__title{margin:0 0 14px;font-family:var(--heading);font-size:15px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-h)}.buildings-section__queue{margin:0;font-size:15px;color:var(--text);font-variant-numeric:tabular-nums}.buildings-section__queue strong{color:var(--text-h)}.buildings-section__empty{margin:0;font-size:14px;color:var(--text-muted)}.buildings-list{margin:0;padding:0;list-style:none}.buildings-cards{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.buildings-cards__cell{aspect-ratio:1 / 1;min-width:0;margin:0;padding:0}.buildings-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;height:100%;padding:10px 8px;border-radius:8px 14px;box-sizing:border-box;background:var(--bg-elevated);border:1px solid var(--border);box-shadow:var(--shadow-inset),0 2px 8px #1c18140f;text-align:center;font:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.buildings-card:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.buildings-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-color-scheme: dark){.buildings-card{box-shadow:var(--shadow-inset),0 2px 10px #0003}}.buildings-card__body{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:0;max-width:100%}.buildings-card__title{display:block;margin:0;font-family:var(--heading);font-size:clamp(12px,2.8vw,15px);font-weight:700;letter-spacing:.04em;color:var(--text-h);line-height:1.25;overflow-wrap:anywhere}.buildings-card__level{display:block;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.buildings-card__status{display:block;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-style:italic}.buildings-card--unbuilt{background:color-mix(in srgb,var(--code-bg) 55%,var(--bg-elevated));border-style:dashed}.buildings-card--unbuilt:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.buildings-section__error{margin:0 0 14px;text-align:left}.buildings-card__production{display:block;margin-top:2px;max-width:100%;font-size:10px;line-height:1.3;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--safe)}.building-modal__title{margin-bottom:4px}.building-modal__level{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--text-muted)}.building-modal__unbuilt-label{font-style:italic}.building-modal__production{margin:0 0 14px;font-size:14px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--safe)}.building-modal__requirements,.building-modal__costs,.building-modal__hint{margin:0 0 12px}.buildings-list__item{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 0;font-size:14px;color:var(--text);border-bottom:1px solid var(--border)}.buildings-list__production{display:block;margin-top:4px;font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--safe)}.buildings-list__item:last-child{border-bottom:none}.buildings-list__item--buildable{display:flex;justify-content:space-between;align-items:center;gap:16px}.buildings-list__costs{display:block;margin-top:6px;font-size:12px;color:var(--text-muted);line-height:1.45}.buildings-list__cost--insufficient{color:#b91c1c;font-weight:600}@media (prefers-color-scheme: dark){.buildings-list__cost--insufficient{color:#f87171}}.buildings-list__build-btn{flex-shrink:0;width:auto;min-width:100px;margin-top:0;padding:9px 16px;font-size:12px}.resource-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#1c181473;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.resource-modal{position:relative;width:100%;max-width:420px;padding:28px 26px 24px;border-radius:4px 16px;background:linear-gradient(165deg,var(--code-bg) 0%,color-mix(in srgb,var(--code-bg) 92%,var(--text-h)) 100%);border:1px solid var(--border);box-shadow:var(--shadow-inset),var(--shadow)}.resource-modal__close{position:absolute;top:16px;right:16px;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;margin:0;border:none;border-radius:8px;color:var(--text-muted);background:transparent;cursor:pointer;transition:color .15s ease,background .15s ease}.resource-modal__close:hover{color:var(--text-h);background:color-mix(in srgb,var(--text-h) 8%,transparent)}.resource-modal__close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.resource-modal__title{margin:0 0 12px;padding-right:44px;font-size:20px;font-family:var(--heading);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-h)}.resource-modal__hint{margin:0 0 16px;font-size:14px;line-height:1.5;color:var(--text-muted)}.resource-modal__meta{margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--text-muted)}.resource-modal__error{margin-bottom:12px}.resource-modal__max{display:inline-block;margin:0 0 16px;padding:0;font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.resource-modal__max:hover:not(:disabled){color:var(--accent-hover)}.resource-modal__max:disabled{opacity:.5;cursor:not-allowed}.account-modal{max-width:440px}.account-modal__title{margin-bottom:6px}.account-modal__tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:16px}.account-modal__tab{min-width:0;padding:10px 8px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);background:color-mix(in srgb,var(--bg) 50%,transparent);border:1px solid var(--border);border-radius:4px 10px;cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.account-modal__tab:hover{color:var(--text-h);border-color:color-mix(in srgb,var(--accent) 25%,var(--border))}.account-modal__tab--active{color:var(--text-h);border-color:var(--accent-border);background:var(--accent-bg)}.account-modal__panel{text-align:left}.account-modal__panel--transactions{min-height:120px}.account-modal__msg{margin-bottom:12px}.account-modal__success{margin:0 0 12px;padding:10px 12px;border-radius:6px;font-size:14px;color:var(--safe);background:color-mix(in srgb,var(--safe) 12%,transparent);border:1px solid color-mix(in srgb,var(--safe) 35%,transparent)}.account-modal__tx-hint{margin-bottom:12px}.account-modal__tx-status,.account-modal__empty{margin:0;font-size:14px;color:var(--text-muted)}.account-modal__tx-list{margin:0;padding:0;list-style:none;max-height:min(280px,40vh);overflow-y:auto}.account-modal__tx-row{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px 12px;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px}.account-modal__tx-row:last-child{border-bottom:none}.account-modal__tx-amount{font-weight:600;color:var(--res-gold);font-variant-numeric:tabular-nums}.account-modal__tx-date{font-size:12px;color:var(--text-muted)}.account-modal__panel--account{text-align:left}.account-modal__account-logout{width:100%;margin-top:4px}.account-modal__danger{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.account-modal__danger-title{margin:0 0 6px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-h)}.account-modal__danger-text{margin:0 0 12px;font-size:13px;line-height:1.45;color:var(--text-muted)}.account-modal__delete-btn{margin-top:8px;background:transparent!important;color:#b91c1c!important;border:1px solid #b91c1c!important;box-shadow:none!important}.account-modal__delete-btn:hover:not(:disabled){filter:none!important;background:#b91c1c1a!important}@media (prefers-color-scheme: dark){.account-modal__delete-btn{color:#f87171!important;border-color:#f87171!important}.account-modal__delete-btn:hover:not(:disabled){background:#f871711f!important}}.resource-modal__actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}.resource-modal__actions .auth-submit{margin-top:0}.buildings-section__queue-actions{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:10px}.buildings-section__instant-btn{width:auto;min-width:100px;margin-top:0;padding:9px 16px;font-size:12px}
