:root{--gold: #ffcf4d;--gold-deep: #f5a623;--gold-dim: #a96d12;--cream: #fffaf0;--cream-dim: #6f5d3f;--ink: #2c2541;--panel: rgba(255, 255, 255, .46);--panel-solid: rgba(255, 255, 255, .72);--panel-edge: rgba(255, 255, 255, .62);--panel-edge-strong: rgba(255, 255, 255, .82);--shadow: rgba(101, 124, 170, .24);--sky-top: #8be7ff;--sky-mid: #c9f4ff;--meadow: #85d957;--meadow-deep: #45b457;--water: #41c9f3;--clay: #e87842;--stone: #b9c6d6;--gem-rose: #ff4f9a;--gem-sky: #28bce8;--leaf: #20af62;--danger: #c93f52;--bg-1: #8be7ff;--bg-2: #fff0a8;--accent: #20af62;--font-display: "Cinzel", "Times New Roman", serif;--font-body: "Nunito", system-ui, sans-serif;--r-sm: 10px;--r-md: 16px;--r-lg: 24px;--r-pill: 999px;--glyph: clamp(22px, 6.2vmin, 46px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{font-family:var(--font-body);color:var(--ink);background:var(--sky-top);overflow:hidden;overscroll-behavior:none;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:var(--font-body);cursor:pointer;border:none;background:none;color:inherit}h1,h2,h3{font-family:var(--font-display);margin:0;letter-spacing:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}:focus-visible{outline:3px solid #1767d8;outline-offset:3px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes tile-drop{0%{transform:translateY(-120%) scale(.85);opacity:0}60%{transform:translateY(8%) scale(1.04);opacity:1}80%{transform:translateY(-3%) scale(.98)}to{transform:translateY(0) scale(1);opacity:1}}@keyframes tile-pop{0%{transform:scale(1)}35%{transform:scale(1.22) rotate(-3deg);filter:brightness(1.7)}to{transform:scale(0) rotate(8deg);opacity:0;filter:brightness(2.4)}}@keyframes spark{0%{transform:scale(.2);opacity:.9}to{transform:scale(2.4);opacity:0}}@keyframes float-up{0%{transform:translate(-50%) scale(.7);opacity:0}20%{opacity:1;transform:translate(-50%,-10px) scale(1.1)}to{transform:translate(-50%,-64px) scale(1);opacity:0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #ffd76e00}50%{box-shadow:0 0 22px 4px #ffd76e80}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes flash-glow{0%{opacity:0}18%{opacity:1}to{opacity:0}}@keyframes ray-spin{to{transform:rotate(360deg)}}@keyframes pop-in{0%{transform:scale(.85);opacity:0}60%{transform:scale(1.03);opacity:1}to{transform:scale(1);opacity:1}}@keyframes toast-in{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes banner-in{0%{transform:translate(-50%,-50%) scale(.4) rotate(-6deg);opacity:0}60%{transform:translate(-50%,-50%) scale(1.08) rotate(2deg);opacity:1}to{transform:translate(-50%,-50%) scale(1) rotate(0);opacity:1}}@keyframes banner-out{to{opacity:0;transform:translate(-50%,-50%) scale(.9)}}@keyframes shimmer{0%{background-position:-150% 0}to{background-position:250% 0}}@keyframes spin-ring{to{transform:rotate(360deg)}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes confetti-fall{0%{transform:translateY(-10vh) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}@keyframes count-pop{0%{transform:scale(1)}40%{transform:scale(1.35);color:#fff}to{transform:scale(1)}}@keyframes build-pop{0%{opacity:0;translate:0 18px}to{opacity:1;translate:0 0}}@keyframes windmill{to{transform:rotate(360deg)}}@keyframes coin-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes sparkle-rise{0%{transform:translateY(8px) scale(.7);opacity:0}35%{opacity:1}to{transform:translateY(-18px) scale(1.1);opacity:0}}@keyframes castle-settle{0%{transform:translateY(18px) rotate(-5deg) skew(-1.5deg) scale(.94);opacity:0;filter:drop-shadow(0 18px 18px rgba(60,104,76,.12)) saturate(.88)}60%{transform:translateY(-4px) rotate(-5deg) skew(-1.5deg) scale(1.02);opacity:1}to{transform:translateY(0) rotate(0) skew(0) scale(.7);opacity:1}}@keyframes build-smoke{0%{opacity:0;scale:.55;translate:0 14px}20%{opacity:.82}to{opacity:0;scale:1.8;translate:0 -34px}}.app{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg-1) 0%,var(--sky-mid) 42%,var(--bg-2) 100%);transition:background 1.2s ease;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);overflow:hidden}.app:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(2px 2px at 18% 20%,rgba(255,255,255,.86),transparent),radial-gradient(2px 2px at 74% 17%,rgba(255,255,255,.68),transparent),radial-gradient(1.5px 1.5px at 43% 64%,rgba(255,255,255,.72),transparent),radial-gradient(2px 2px at 86% 54%,rgba(255,255,255,.56),transparent);opacity:.78;pointer-events:none;display:none}.app:after{content:"";position:absolute;inset:auto -8% -12% -8%;height:42%;background:radial-gradient(80% 75% at 50% 100%,rgba(67,174,87,.46),transparent 72%),linear-gradient(180deg,transparent,rgba(255,255,255,.25));pointer-events:none;z-index:0;display:none}.stage{position:relative;flex:1;min-height:0;display:flex;gap:14px;padding:10px 12px 14px;z-index:3}.stage__board{flex:1 1 auto;min-width:0;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;transition:transform .48s cubic-bezier(.22,1,.36,1),opacity .32s ease}.stage__kingdom{display:flex;flex-direction:column;min-height:0;transition:transform .48s cubic-bezier(.22,1,.36,1),opacity .32s ease}.castle-view-toggle{position:fixed;left:50%;bottom:calc(18px + env(safe-area-inset-bottom));z-index:55;transform:translate(-50%);min-height:48px;padding:0 22px;border-radius:var(--r-pill);font-family:var(--font-display);font-weight:800;font-size:15px;color:#3a2400;background:linear-gradient(180deg,#fff4a9,var(--gold-deep));border:1px solid rgba(255,255,255,.72);box-shadow:0 6px #b97813,0 16px 32px #b0781338;-webkit-backdrop-filter:blur(16px) saturate(1.2);backdrop-filter:blur(16px) saturate(1.2);transition:transform .12s ease,box-shadow .12s ease,background .2s ease}.castle-view-toggle:active{transform:translate(-50%) translateY(4px);box-shadow:0 2px #b97813,0 8px 18px #b0781333}.castle-view-toggle[data-active=true]{background:linear-gradient(180deg,#c8f7ff,var(--gem-sky));box-shadow:0 6px #1d6a8a,0 16px 32px #199ac238}.app[data-castle-view=true] .stage__board{transform:translate(-115%) scale(.96);opacity:0;pointer-events:none}.app[data-castle-view=true] .stage__kingdom{transform:translate(115%) scale(.96);opacity:0;pointer-events:none}.app[data-castle-view=true] .topbar,.app[data-castle-view=true] .resource-bar,.app[data-castle-view=true] .energy{opacity:.2;transition:opacity .28s ease}.app[data-orient=portrait] .stage{flex-direction:column}.app[data-orient=portrait] .stage__kingdom{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;transform:translateY(100%);transition:transform .42s cubic-bezier(.22,1,.36,1);padding:10px 12px}.app[data-orient=portrait] .stage__kingdom[data-open=true]{transform:translateY(0)}.app[data-orient=portrait][data-castle-view=true] .stage__board,.app[data-orient=portrait][data-castle-view=true] .stage__kingdom{transform:translateY(110%) scale(.96)}.app[data-orient=landscape] .stage{flex-direction:row;align-items:stretch}.app[data-orient=landscape] .stage__kingdom{flex:0 0 clamp(280px,32vw,420px);max-width:420px}.kingdom-toggle{display:none}.app[data-orient=portrait] .kingdom-toggle{display:inline-flex}.kingdom-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;pointer-events:none}.kingdom-bg-art{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(../castle/BG.png);background-size:cover;background-position:center center;background-repeat:no-repeat;transform:scale(1.01)}.kingdom-bg-art:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 24%),radial-gradient(60% 45% at 50% 58%,rgba(255,255,255,.16),transparent 72%)}.kingdom-scene{position:absolute;left:50%;bottom:clamp(58px,9vh,96px);width:min(1080px,108vw);height:min(620px,66vh);transform:translate(-50%);transition:bottom .48s ease,height .48s ease,width .48s ease}.app[data-castle-view=true] .kingdom-scene{bottom:clamp(70px,10vh,112px);width:min(1220px,112vw);height:min(780px,82vh)}.scene-piece{position:absolute;transform-origin:50% 100%;transition:transform .55s ease,opacity .55s ease,filter .55s ease;animation:build-pop .52s ease both}.scene-piece[data-tier="0"]{filter:saturate(.74) brightness(.92)}.scene-piece[data-tier="0"] .damage{opacity:1}.scene-piece:not([data-tier="0"]) .damage{opacity:0}.castle{left:var(--castle-left, 25%);bottom:var(--castle-bottom, 5%);width:var(--castle-size, min(650px, 68vw));height:var(--castle-size, min(650px, 68vw));translate:-50% 0;transform:scale(var(--castle-scale, 1));transform-origin:50% 100%;z-index:4}.castle__asset{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 24px 22px rgba(60,104,76,.24));-webkit-user-select:none;user-select:none;pointer-events:none;animation:castle-settle .58s cubic-bezier(.2,.9,.25,1.2) both}.castle[data-tier="1"]{--castle-left: 45%;--castle-bottom: -15%;--castle-size: min(450px, 50vw);--castle-scale: 1.9;--castle-view-size: min(520px, 64vw)}.castle[data-tier="2"]{--castle-left: 42%;--castle-bottom: -20%;--castle-size: min(520px, 57vw);--castle-scale: 1.8;--castle-view-size: min(610px, 72vw)}.castle[data-tier="3"]{--castle-left: 40%;--castle-bottom: -20%;--castle-size: min(590px, 64vw);--castle-scale: 1.7;--castle-view-size: min(700px, 80vw)}.castle[data-tier="4"]{--castle-left: 36%;--castle-bottom: -25%;--castle-size: min(670px, 70vw);--castle-scale: 1.5;--castle-view-size: min(780px, 88vw)}.castle[data-tier="5"]{--castle-left: 30%;--castle-bottom: -25%;--castle-size: min(760px, 78vw);--castle-scale: 1.3;--castle-view-size: min(880px, 96vw)}.app[data-castle-view=true] .castle{width:var(--castle-view-size, var(--castle-size));height:var(--castle-view-size, var(--castle-size))}.build-smoke{position:absolute;left:50%;top:48%;z-index:8;width:150px;height:82px;border-radius:50%;background:radial-gradient(circle at 20% 54%,rgba(255,255,255,.82) 0 32px,transparent 34px),radial-gradient(circle at 50% 42%,rgba(239,231,211,.86) 0 42px,transparent 44px),radial-gradient(circle at 80% 56%,rgba(255,255,255,.78) 0 30px,transparent 32px);opacity:0;filter:blur(.9px);pointer-events:none;animation:build-smoke 1.05s ease-out both}.build-smoke--one{transform:translate(-92%)}.build-smoke--two{transform:translate(-50%);animation-delay:.08s}.build-smoke--three{transform:translate(-8%);animation-delay:.16s}@media (max-width: 760px){.kingdom-scene{width:860px;height:500px;bottom:82px}.app[data-orient=portrait] .kingdom-scene{transform:translate(-50%) scale(.86)}.app[data-orient=portrait][data-castle-view=true] .kingdom-scene{bottom:96px;transform:translate(-50%) scale(.98)}.app[data-orient=portrait] .castle{width:var(--castle-size, min(650px, 98vw));height:var(--castle-size, min(650px, 98vw))}.app[data-orient=portrait][data-castle-view=true] .castle{width:var(--castle-view-size, var(--castle-size));height:var(--castle-view-size, var(--castle-size))}}.topbar{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px 6px}.brand{display:flex;flex-direction:column;line-height:1}.brand__name{font-family:var(--font-display);font-weight:900;font-size:clamp(18px,4.4vmin,28px);background:linear-gradient(180deg,#654510,#a45b00 48%,#e85d38);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 1px 0 rgba(255,255,255,.46)}.brand__biome{font-weight:800;font-size:11px;letter-spacing:0;text-transform:uppercase;color:var(--accent);margin-top:3px}.topbar__right{display:flex;align-items:center;gap:8px}.score-pill{display:flex;flex-direction:column;align-items:flex-end;padding:6px 14px;border-radius:var(--r-md);background:var(--panel);border:1px solid var(--panel-edge);box-shadow:0 10px 26px #5275a729;-webkit-backdrop-filter:blur(16px) saturate(1.24);backdrop-filter:blur(16px) saturate(1.24)}.score-pill__label{font-size:10px;font-weight:800;letter-spacing:0;text-transform:uppercase;color:var(--cream-dim)}.score-pill__value{font-family:var(--font-display);font-weight:700;font-size:clamp(16px,3.6vmin,22px);color:#7b4d05}.icon-btn{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:18px;background:var(--panel);border:1px solid var(--panel-edge);box-shadow:0 8px 20px #5275a729;-webkit-backdrop-filter:blur(14px) saturate(1.18);backdrop-filter:blur(14px) saturate(1.18);transition:transform .1s ease,background .2s ease,box-shadow .2s ease}.icon-btn:active{transform:scale(.92)}.icon-btn[data-active=true]{background:linear-gradient(180deg,#fff0a0,var(--gold-deep));color:#3a2400;border-color:transparent}.resource-bar{display:flex;flex-wrap:wrap;gap:6px;padding:6px 12px 0;justify-content:center;z-index:2}.app[data-orient=landscape] .resource-bar{justify-content:flex-start}.resource{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:var(--r-pill);background:var(--panel);border:1px solid var(--panel-edge);box-shadow:0 8px 20px #5275a724;-webkit-backdrop-filter:blur(14px) saturate(1.18);backdrop-filter:blur(14px) saturate(1.18);font-weight:800;font-size:clamp(12px,2.6vmin,15px)}.resource__glyph{font-size:1.05em}.resource__value{font-variant-numeric:tabular-nums;min-width:1.5em;text-align:right}.resource[data-bump=true] .resource__value{animation:count-pop .4s ease;color:#8b5200}.energy{display:flex;align-items:center;gap:8px;padding:4px 12px;position:relative;z-index:2}.energy__icon{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-size:16px;color:#7a3e00;background:#ffffffb3;border:1px solid rgba(255,255,255,.8);box-shadow:0 6px 16px #b078132e}.energy__track{position:relative;flex:1;height:12px;border-radius:var(--r-pill);background:#ffffff6b;border:1px solid var(--panel-edge);overflow:hidden;max-width:280px}.energy__fill{position:absolute;top:0;right:0;bottom:0;left:0;width:var(--fill, 100%);background:linear-gradient(90deg,#ffe066,#ff8f55);transition:width .4s ease;box-shadow:0 0 10px #ff9d4d99}.energy__text{font-weight:800;font-size:12px;font-variant-numeric:tabular-nums;color:var(--ink);min-width:56px;text-align:right;padding:3px 8px;border-radius:var(--r-pill);background:#ffffffb8;border:1px solid rgba(255,255,255,.78)}.energy__free{color:#075a79}.machine{width:100%;max-width:min(96vw,560px);max-width:min(96vw,560px,calc((100dvh - 300px) * 6 / 5));display:flex;flex-direction:column;align-items:center;gap:clamp(8px,1.6vh,16px)}.app[data-orient=landscape] .machine{max-width:min(58vw,520px);height:100%;min-height:0;justify-content:center}.app[data-orient=landscape] .board-frame{flex:0 1 auto;min-height:0;aspect-ratio:6 / 5;height:100%;width:auto;max-width:100%}.board-frame{position:relative;width:100%;padding:clamp(8px,1.6vmin,14px);border-radius:var(--r-lg);background:linear-gradient(160deg,#ffffff9e,#ffffff57),var(--panel);border:1.5px solid var(--panel-edge-strong);box-shadow:0 18px 40px #5275a733,inset 0 1px #ffffffe0;-webkit-backdrop-filter:blur(18px) saturate(1.28);backdrop-filter:blur(18px) saturate(1.28)}.board-frame:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:calc(var(--r-lg) - 6px);border:1px solid rgba(255,255,255,.55);pointer-events:none}.board{position:relative;display:grid;grid-template-columns:repeat(var(--cols, 6),1fr);grid-template-rows:repeat(var(--rows, 5),1fr);gap:clamp(3px,.8vmin,7px);aspect-ratio:var(--cols, 6) / var(--rows, 5);width:100%;border-radius:var(--r-md);background:linear-gradient(180deg,#ffffff9e,#c9f4ff6b),#ffffff7a;padding:clamp(4px,1vmin,9px);overflow:hidden}.cell{position:relative;border-radius:var(--r-sm);background:#ffffff6b;box-shadow:inset 0 0 0 1px #5e74951f,inset 0 -8px 18px #6bc0e61f;display:flex;align-items:center;justify-content:center}.tile{position:absolute;inset:clamp(2px,.5vmin,5px);display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);font-size:var(--glyph);line-height:1;background:radial-gradient(120% 120% at 30% 20%,rgba(255,255,255,.22),transparent 55%),var(--tile-bg, rgba(70, 50, 110, .5));box-shadow:inset 0 1px #ffffff40,inset 0 -3px 6px #5548312e,0 5px 10px #5275a733;animation:tile-drop .4s cubic-bezier(.2,.9,.3,1.3) both;will-change:transform;-webkit-user-select:none;user-select:none}.tile__glyph{filter:drop-shadow(0 2px 2px rgba(63,54,44,.22))}.tile[data-special=wild]{box-shadow:inset 0 1px #fff6,0 0 16px 2px var(--tile-glow, rgba(255, 233, 168, .8));animation:tile-drop .4s cubic-bezier(.2,.9,.3,1.3) both,pulse-glow 1.8s ease-in-out infinite .4s}.tile[data-special=scatter]{box-shadow:inset 0 1px #fff6,0 0 16px 2px var(--tile-glow, rgba(200, 162, 255, .8));animation:tile-drop .4s cubic-bezier(.2,.9,.3,1.3) both,bob 2.2s ease-in-out infinite .4s}.tile[data-clearing=true]{animation:tile-pop .36s ease-in forwards;z-index:5}.cell .spark{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:60%;height:60%;border-radius:50%;background:radial-gradient(circle,rgba(255,245,200,.9),transparent 60%);animation:spark .4s ease-out forwards;pointer-events:none;z-index:6}.float-score{position:absolute;left:50%;top:12%;font-family:var(--font-display);font-weight:700;font-size:clamp(20px,5vmin,34px);color:var(--gold);text-shadow:0 2px 0 rgba(255,255,255,.75),0 0 18px rgba(255,215,110,.7);animation:float-up 1s ease-out forwards;pointer-events:none;z-index:20}.multiplier{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;min-height:30px;flex:0 0 auto}.multiplier__chip{padding:4px 14px;border-radius:var(--r-pill);background:linear-gradient(180deg,#fff0a0,var(--gold-deep));color:#3a2400;font-size:clamp(15px,3.4vmin,22px);box-shadow:0 4px 12px #ffd76e66;animation:count-pop .3s ease}.multiplier__label{font-family:var(--font-body);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:11px;color:var(--cream-dim)}.spin-btn{position:relative;flex:0 0 auto;width:clamp(120px,30vmin,180px);height:clamp(52px,8vh,68px);border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:clamp(17px,3.6vmin,23px);letter-spacing:.04em;color:#3a2400;background:linear-gradient(180deg,#fff4a9,var(--gold-deep) 60%,#e9922e);box-shadow:0 8px #9c6b1e,0 14px 24px #b0781347,inset 0 2px #fff9;transition:transform .08s ease,box-shadow .08s ease;overflow:hidden}.spin-btn:active:not(:disabled){transform:translateY(5px);box-shadow:0 3px #9c6b1e,0 6px 12px #0006,inset 0 2px #fff9}.spin-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);background-size:200% 100%;animation:shimmer 3.4s linear infinite;pointer-events:none;z-index:0}.spin-btn:disabled{filter:grayscale(.4) brightness(.8);cursor:not-allowed}.spin-btn[data-spinning=true] .spin-btn__label{opacity:0}.spin-btn__label{position:relative;z-index:1;display:block}.spin-btn__ring{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:26px;height:26px;border-radius:50%;border:3px solid rgba(58,36,0,.3);border-top-color:#3a2400;animation:spin-ring .7s linear infinite;display:none}.spin-btn[data-spinning=true] .spin-btn__ring{display:block}.spin-btn__cost{display:block;font-family:var(--font-body);font-weight:800;font-size:11px;opacity:1;margin-top:-2px;color:#6b3c00;text-shadow:0 1px 0 rgba(255,255,255,.45)}.spin-btn[data-free=true]{background:linear-gradient(180deg,#c8f7ff,var(--gem-sky) 60%,#199ac2);box-shadow:0 8px #1d6a8a,0 14px 24px #199ac242,inset 0 2px #fff9;color:#062536}.win-banner{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);z-index:40;text-align:center;pointer-events:none;animation:banner-in .5s cubic-bezier(.2,.9,.3,1.4) both}.win-banner[data-out=true]{animation:banner-out .4s ease forwards}.win-banner__title{font-family:var(--font-display);font-weight:900;font-size:clamp(26px,8vmin,60px);color:var(--gold);text-shadow:0 3px 0 rgba(119,75,5,.26),0 0 30px rgba(255,215,110,.8);line-height:1}.win-banner__score{margin-top:6px;font-family:var(--font-display);font-weight:700;font-size:clamp(20px,5vmin,34px);color:var(--ink);text-shadow:0 2px 0 rgba(255,255,255,.72)}.win-banner__chain{margin-top:4px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;font-size:12px;color:var(--gem-rose)}.win-banner__energy{margin-top:4px;font-weight:900;letter-spacing:.06em;font-size:13px;color:#ffd76e;text-shadow:0 0 12px rgba(255,157,77,.7)}.confetti{position:absolute;top:0;width:9px;height:14px;border-radius:2px;animation:confetti-fall linear forwards;z-index:38;pointer-events:none}.kingdom{flex:1;min-height:0;display:flex;flex-direction:column;border-radius:var(--r-lg);background:linear-gradient(160deg,#ffffffb8,#ffffff61),var(--panel);border:1.5px solid var(--panel-edge-strong);box-shadow:0 18px 40px #5275a738,inset 0 1px #ffffffe6;-webkit-backdrop-filter:blur(22px) saturate(1.26);backdrop-filter:blur(22px) saturate(1.26);overflow:hidden}.kingdom__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid rgba(74,84,122,.12)}.kingdom__title{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:clamp(16px,3.4vmin,20px);color:#7b4d05}.kingdom__close{width:34px;height:34px;border-radius:50%;background:#ffffff7a;border:1px solid var(--panel-edge);font-size:18px}.kingdom__scroll{flex:1;min-height:0;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:var(--gold-dim) transparent}.kingdom__scroll::-webkit-scrollbar{width:6px}.kingdom__scroll::-webkit-scrollbar-thumb{background:#a96d129e;border-radius:3px}.biome{padding:12px 14px;border-radius:var(--r-md);background:#ffffff6b;border:1px solid var(--panel-edge)}.biome__row{display:flex;align-items:center;gap:10px}.biome__crest{font-size:26px}.biome__name{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--ink)}.biome__tag{font-size:12px;color:var(--cream-dim);font-style:italic}.biome__next{margin-top:10px;font-size:12px;font-weight:700;color:var(--cream-dim)}.biome__bar{margin-top:6px;height:8px;border-radius:var(--r-pill);background:#ffffff85;overflow:hidden}.biome__bar-fill{height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--accent),var(--gold));transition:width .5s ease}.building{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r-md);background:#ffffff6b;border:1px solid rgba(255,255,255,.62);box-shadow:0 8px 18px #5275a71a;transition:border-color .2s ease,background .2s ease,transform .2s ease}.building[data-affordable=true]{border-color:#ffcf4dc7;background:#ffffff94}.building[data-affordable=true]:hover{transform:translateY(-1px)}.building[data-max=true]{opacity:.75}.building__icon{width:46px;height:46px;flex:0 0 46px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:26px;background:radial-gradient(120% 120% at 30% 20%,rgba(255,255,255,.18),transparent 55%),#ffffff8f;box-shadow:inset 0 1px #fff3}.building__body{flex:1;min-width:0}.building__name{display:flex;align-items:baseline;gap:8px;font-weight:800;font-size:15px}.building__lvl{font-size:11px;font-weight:800;color:#8b5200;letter-spacing:0}.building__effect{font-size:12px;color:var(--accent);font-weight:700;margin-top:1px}.building__blurb{font-size:11px;color:var(--cream-dim);margin-top:2px}.building__cost{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.cost-chip{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:800;padding:2px 7px;border-radius:var(--r-pill);background:#ffffff8a;border:1px solid rgba(74,84,122,.1)}.cost-chip[data-short=true]{color:var(--danger)}.building__action{flex:0 0 auto}.build-btn{padding:9px 14px;border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:13px;color:#3a2400;background:linear-gradient(180deg,#fff0a0,var(--gold-deep));box-shadow:0 4px #b97813,0 8px 14px #b0781338;transition:transform .08s ease,box-shadow .08s ease,filter .2s ease;white-space:nowrap}.build-btn:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px #9c6b1e,0 3px 8px #0000004d}.build-btn:disabled{filter:grayscale(.6) brightness(.7);cursor:not-allowed}.build-btn[data-max=true]{background:#ffffff80;color:var(--cream-dim);box-shadow:none}.toast{position:fixed;left:50%;bottom:calc(18px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:60;padding:11px 18px;border-radius:var(--r-pill);font-weight:800;font-size:13px;background:#ffffffb8;border:1px solid var(--panel-edge);box-shadow:0 10px 30px var(--shadow);-webkit-backdrop-filter:blur(18px) saturate(1.25);backdrop-filter:blur(18px) saturate(1.25);animation:toast-in .35s cubic-bezier(.2,.9,.3,1.4) both;max-width:90vw;text-align:center}.toast[data-kind=gold]{border-color:var(--gold);color:#7a4d05}.toast[data-kind=warn]{border-color:var(--danger);color:var(--danger)}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#4388b838;-webkit-backdrop-filter:blur(10px) saturate(1.2);backdrop-filter:blur(10px) saturate(1.2);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade-in .2s ease both}.modal{width:min(440px,92vw);max-height:86vh;overflow-y:auto;border-radius:var(--r-lg);background:linear-gradient(145deg,#ffffffc7,#ffffff7a),#ffffff85;border:1.5px solid rgba(255,255,255,.82);box-shadow:0 24px 60px #5275a742,inset 0 1px #ffffffe0;padding:22px;color:var(--ink);-webkit-backdrop-filter:blur(22px) saturate(1.32);backdrop-filter:blur(22px) saturate(1.32);animation:pop-in .28s cubic-bezier(.2,.9,.3,1.4) both}.modal__title{font-family:var(--font-display);font-weight:700;font-size:22px;color:#7b4d05;margin-bottom:8px}.modal__row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(74,84,122,.12);font-weight:700}.modal__row span:last-child{color:#8b5200;font-variant-numeric:tabular-nums}.modal__actions{display:flex;gap:10px;margin-top:18px}.btn{flex:1;padding:12px;border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:15px;transition:transform .08s ease,filter .2s ease}.btn:active{transform:translateY(2px)}.btn--gold{color:#3a2400;background:linear-gradient(180deg,#ffe990,var(--gold-deep));box-shadow:0 5px #b97813,0 12px 22px #f5a62342}.btn--ghost{background:#ffffff61;border:1px solid rgba(255,255,255,.7);color:var(--ink);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn--danger{color:#fff;background:linear-gradient(180deg,#ff8a8a,#d94f4f);box-shadow:0 5px #962e2e}.scatter-rays{position:absolute;left:-60%;top:-60%;width:220%;height:220%;pointer-events:none;background:repeating-conic-gradient(from 0deg at 50% 50%,#ffe9a800,#ffe9a83d 3deg,#ffe9a800 7deg),radial-gradient(circle at 50% 50%,rgba(200,162,255,.4),transparent 58%);-webkit-mask-image:radial-gradient(circle at 50% 50%,transparent 21%,#000 38%,#000 46%,transparent 74%);mask-image:radial-gradient(circle at 50% 50%,transparent 21%,#000 38%,#000 46%,transparent 74%);transform-origin:50% 50%;animation:flash-glow 1.8s ease both,ray-spin 14s linear infinite}.kingdom-toggle{align-items:center;gap:8px;padding:12px 22px;border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:15px;color:#3a2400;background:linear-gradient(180deg,#fff3a8,var(--gold-deep));box-shadow:0 6px #b97813,0 12px 22px #b0781338;transition:transform .08s ease}.kingdom-toggle:active{transform:translateY(3px)}.kingdom-toggle__badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--r-pill);background:var(--gem-rose);color:#fff;font-size:11px;font-weight:900}.menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto;background:#67bfe933;-webkit-backdrop-filter:blur(10px) saturate(1.2);backdrop-filter:blur(10px) saturate(1.2);animation:fade-in .25s ease both}.menu__card{width:min(440px,94vw);margin:auto;padding:clamp(20px,4vmin,30px) clamp(18px,4vmin,26px);border-radius:var(--r-lg);background:linear-gradient(145deg,#ffffffd1,#ffffff80),#ffffff8c;border:1.5px solid rgba(255,255,255,.84);box-shadow:0 24px 60px #5275a747,inset 0 1px #ffffffe6;-webkit-backdrop-filter:blur(22px) saturate(1.32);backdrop-filter:blur(22px) saturate(1.32);text-align:center}.menu__crest{font-size:clamp(34px,9vmin,52px);line-height:1}.menu__title{font-family:var(--font-display);font-weight:900;font-size:clamp(28px,7vmin,44px);margin-top:6px;background:linear-gradient(180deg,#6c4a11,#b56d00 45%,#e86b3d);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:none}.menu__tagline{margin:4px 0 18px;color:var(--cream-dim);font-weight:700;font-size:13px}.menu__heading{font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:0;text-transform:uppercase;color:var(--accent);margin-bottom:12px}.menu__steps{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:10px;text-align:left}.menu__step{display:flex;align-items:flex-start;gap:11px}.menu__step-icon{flex:0 0 auto;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;border-radius:var(--r-sm);background:#ffffff75;border:1px solid var(--panel-edge)}.menu__step-body{display:flex;flex-direction:column;line-height:1.3}.menu__step-title{font-weight:800;font-size:14px;color:var(--ink)}.menu__step-text{font-size:12.5px;color:var(--cream-dim)}.menu__play{position:relative;width:100%;height:clamp(54px,9vh,64px);border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:clamp(19px,4vmin,24px);letter-spacing:.06em;color:#3a2400;background:linear-gradient(180deg,#ffe79a,var(--gold-deep) 60%,#d99a2b);box-shadow:0 8px #9c6b1e,0 14px 24px #00000073,inset 0 2px #fff9;transition:transform .08s ease,box-shadow .08s ease}.menu__play:active{transform:translateY(5px);box-shadow:0 3px #9c6b1e,0 6px 12px #0006,inset 0 2px #fff9}.menu__play-icon{margin-right:8px;font-size:.85em}.gameover__lead{margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--cream-dim)}.gameover__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:18px}.gameover__stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 6px;border-radius:var(--r-md);background:#ffffff61;border:1px solid var(--panel-edge)}.gameover__stat-value{font-family:var(--font-display);font-weight:700;font-size:clamp(16px,4.4vmin,22px);color:#8b5200;font-variant-numeric:tabular-nums}.gameover__stat-label{font-size:10px;font-weight:800;letter-spacing:0;text-transform:uppercase;color:var(--cream-dim);text-align:center}.gameover__continue{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;gap:1px;padding:13px;border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:19px;color:#062536;background:linear-gradient(180deg,#b6f0ff,var(--gem-sky) 60%,#2f9ec9);box-shadow:0 6px #1d6a8a,0 12px 22px #0006;transition:transform .08s ease,box-shadow .08s ease}.gameover__continue:active:not(:disabled){transform:translateY(4px);box-shadow:0 2px #1d6a8a,0 6px 12px #0006}.gameover__continue:disabled{filter:grayscale(.3) brightness(.9);cursor:progress}.gameover__continue-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:16px}.gameover__continue-sub{font-family:var(--font-body);font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.04em;opacity:.75}.lb__note{margin:4px 0 16px;font-size:13px;line-height:1.5;color:var(--cream-dim);text-align:center}.lb__note--warn{color:var(--ink);border:1px solid rgba(255,215,110,.25);background:#ffd76e14;border-radius:var(--r-md);padding:10px 12px}.lb__list{list-style:none;margin:0 0 8px;padding:0;display:flex;flex-direction:column;gap:6px;max-height:50vh;overflow-y:auto}.lb__row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-md);background:#ffffff6b;border:1px solid var(--panel-edge)}.lb__row[data-me=true]{border-color:var(--gold);background:#ffd76e1a}.lb__rank{min-width:26px;font-family:var(--font-display);font-weight:700;font-size:16px;color:#8b5200;text-align:center}.lb__avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;background:#ffffff94;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.lb__name{flex:1;min-width:0;font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb__score{font-family:var(--font-display);font-weight:700;color:#8b5200;font-variant-numeric:tabular-nums}
