:root{--surface: #f9f9f9;--surface-low: #f3f3f3;--surface-container: #eeeeee;--surface-high: #e2e2e2;--white: #ffffff;--ink: #2d2d2d;--ink-soft: #404846;--outline: #717976;--mint: #b4e3d5;--mint-strong: #3b665b;--lavender: #e4d7fd;--lavender-strong: #635979;--coral: #ffcec0;--coral-bright: #ffab91;--coral-strong: #8d4d38;--sky: #b3e5fc;--sky-strong: #2d7fa8;--error: #ba1a1a;--error-container: #ffdad6;--font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--shadow-offset: 4px 4px 0 var(--ink)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100vh}body{background:var(--surface);color:var(--ink);font-family:var(--font);font-size:16px;line-height:1.5}canvas{image-rendering:pixelated}h1,h2,h3{font-family:var(--font);font-weight:800;letter-spacing:-.02em;line-height:1.2}.pixel-font{font-weight:700}a{color:var(--mint-strong);text-decoration:none}.section-title,.bet-label,.option-label,.inventory-slot .label,.tag,.game-nav a{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.pixel-panel{background:var(--white);border:1px solid var(--ink);border-radius:0;padding:16px}.pixel-btn{font-family:var(--font);font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);background:var(--mint);border:2px solid var(--ink);border-radius:0;padding:12px 20px;cursor:pointer;box-shadow:var(--shadow-offset);transition:transform .06s,box-shadow .06s}.pixel-btn:hover:not(:disabled){transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.pixel-btn:active:not(:disabled){transform:translate(4px,4px);box-shadow:none}.pixel-btn:disabled{background:var(--surface-high);color:var(--outline);border-color:var(--outline);cursor:not-allowed;transform:none;box-shadow:4px 4px 0 var(--outline)}.pixel-btn--secondary{background:var(--white)}.pixel-btn--small{font-size:11px;padding:8px 12px}.pixel-btn--green{background:var(--mint)}.game-layout{min-height:100vh;display:flex;flex-direction:column}.game-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--ink)}.game-logo{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--ink);white-space:nowrap}.header-actions{display:flex;align-items:center;gap:6px;flex:0 0 auto;margin-left:auto}.header-actions .mail-btn{margin-right:0}.header-mail-btn,.header-action-btn{flex:0 0 auto}.hud-resources{display:flex;gap:8px;flex-wrap:wrap;flex:1;justify-content:center}.hud-chip{display:flex;align-items:center;gap:7px;background:var(--white);border:1px solid var(--ink);border-radius:0;padding:4px 10px 4px 6px;font-size:14px;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums;min-width:86px}.hud-chip canvas{display:block}.hud-level{gap:6px;padding:4px 8px}.hud-level-badge{font-weight:800;font-size:12px;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}.hud-xp-bar{width:56px;height:8px;border:1px solid var(--ink);background:var(--surface-low);overflow:hidden}.hud-xp-fill{height:100%;background:var(--lavender);border-right:1px solid var(--lavender-strong);transition:width .4s steps(8)}.game-nav{display:flex;gap:6px;flex-wrap:wrap}.game-nav a{color:var(--ink-soft);padding:8px 12px;border:1px solid transparent;border-radius:0}.game-nav a:hover{border-color:var(--ink)}.game-nav a.active{color:var(--ink);border-color:var(--ink);background:var(--mint)}.game-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px 20px 60px}.game-loading{text-align:center;padding:28px}.slot-page{display:grid;grid-template-columns:1fr 290px;gap:20px;align-items:start}.slot-page>*,.city-page>*,.gamehome-grid>*{min-width:0}.slot-stage{position:relative}.slot-title{display:flex;align-items:baseline;gap:12px;margin:0 0 12px}.slot-title h1{font-size:24px;margin:0;color:var(--ink)}.slot-title span{color:var(--ink-soft);font-size:14px}.slot-controls{display:flex;align-items:stretch;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:16px}.bet-stepper{display:flex;align-items:center;gap:8px;width:fit-content;margin-inline:auto;background:var(--white);border:1px solid var(--ink);border-radius:0;padding:6px 10px}.bet-stepper button{font-family:var(--font);font-size:16px;font-weight:700;width:34px;height:34px;border-radius:0;border:1px solid var(--ink);background:var(--surface-low);color:var(--ink);cursor:pointer}.bet-stepper button:hover:not(:disabled){background:var(--mint)}.bet-stepper button:disabled{opacity:.35;cursor:not-allowed}.bet-value{font-size:18px;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums;min-width:84px;text-align:center;color:var(--ink)}.bet-label{color:var(--ink-soft);text-align:center}.spin-button{font-size:18px;padding:14px 56px;flex:1 1 auto;max-width:360px;background:var(--coral)}.slot-side{display:flex;flex-direction:column;gap:16px}.paytable{font-size:14px}.paytable h3{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin:0 0 10px;color:var(--ink)}.paytable-row{display:flex;align-items:center;gap:8px;padding:4px 0;color:var(--ink-soft);border-bottom:1px solid var(--surface-high)}.paytable-row:last-child{border-bottom:none}.paytable-row b{color:var(--ink);font-variant-numeric:tabular-nums}.slot-error{color:var(--error);font-size:13px;font-weight:600;text-align:center;margin-top:8px;min-height:20px}.slot-options{display:flex;justify-content:center;gap:22px;flex-wrap:wrap;margin-top:12px}.option-group{display:flex;align-items:center;gap:6px}.option-label{color:var(--ink-soft);margin-right:2px}.option-chip{font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.05em;min-width:38px;padding:7px 9px;border-radius:0;border:1px solid var(--ink);background:var(--white);color:var(--ink-soft);cursor:pointer;transition:background .12s}.option-chip:hover:not(:disabled){background:var(--surface-container)}.option-chip.active{color:var(--ink);background:var(--sky)}.option-chip:disabled{opacity:.45;cursor:not-allowed}.city-page{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}.city-canvas-wrap{padding:8px}.city-side{display:flex;flex-direction:column;gap:16px}.city-stats{display:flex;gap:12px;flex-wrap:wrap;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink-soft)}.building-card{display:flex;gap:12px;align-items:flex-start}.building-card h3{margin:0 0 4px;font-size:16px;color:var(--ink)}.building-card p{margin:0 0 8px;font-size:14px;color:var(--ink-soft)}.cost-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:6px 0}.cost-item{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}.cost-item.insufficient{color:var(--error)}.build-list{display:flex;flex-direction:column;max-height:420px;overflow-y:auto}.build-item{display:flex;gap:10px;align-items:center;background:var(--white);border:none;border-bottom:1px solid var(--surface-high);border-left:4px solid transparent;border-radius:0;padding:10px 8px;cursor:pointer;transition:background .12s,border-color .12s}.build-item:hover:not(.disabled){background:var(--surface-low);border-left-color:var(--mint-strong)}.build-item.disabled{opacity:.45;cursor:not-allowed}.build-item .name{font-size:14px;font-weight:700}.placement-hint{font-size:13px;font-weight:700;color:var(--mint-strong);text-align:center;padding:8px;background:var(--mint);border:1px solid var(--ink)}.mission-chain{margin-bottom:26px}.mission-chain>h2{font-size:20px;color:var(--ink);margin:0 0 4px}.mission-chain>p{color:var(--ink-soft);margin:0 0 12px;font-size:14px}.mission-card{display:flex;align-items:center;gap:14px;margin-bottom:10px}.mission-card.locked{opacity:.45}.mission-card .info{flex:1}.mission-card h3{font-size:15px;margin:0 0 5px}.mission-card p{margin:0 0 8px;font-size:14px;color:var(--ink-soft)}.progress-bar{height:16px;border:1px solid var(--ink);border-radius:0;background:var(--surface-high);overflow:hidden;position:relative}.progress-bar>div{height:100%;background:var(--mint);transition:width .5s ease-out}.progress-bar span{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--ink)}.reward-line{display:flex;gap:10px;align-items:center;font-size:12px;font-weight:700;letter-spacing:.05em;color:var(--coral-strong)}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.inventory-slot{text-align:center;padding:18px 12px}.inventory-slot>img,.inventory-slot>canvas{display:block;margin-inline:auto}.inventory-slot .amount{font-size:22px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin:10px 0 4px}.inventory-slot .label{color:var(--ink-soft)}.inventory-slot.empty{opacity:.4;border-style:dashed}.inventory-slot .pixel-btn{margin-top:10px}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.shop-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.shop-card h3{margin:0;font-size:16px}.shop-card p{margin:0;font-size:12.5px;flex:1}.shop-card .meta{display:flex;gap:8px;flex-wrap:wrap}.active-boosts{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.boost-chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:6px 10px}.challenge-card.claimed{opacity:.55}.challenge-card h3 .tag{margin-left:6px;vertical-align:middle}.account-menu{position:relative}.account-btn{background:var(--sky);border:1px solid var(--ink);padding:6px 10px;cursor:pointer;font-size:15px;line-height:1}.account-btn:hover{background:var(--coral)}.account-dropdown{position:absolute;right:0;left:auto;top:calc(100% + 8px);z-index:60;display:flex;flex-direction:column;gap:4px;min-width:190px;max-width:calc(100vw - 24px);padding:10px}.account-dropdown .account-name{font-family:var(--font-pixel);font-size:10px;padding:4px 6px 8px;border-bottom:1px solid var(--ink);margin-bottom:4px}.account-dropdown button{background:none;border:none;text-align:left;padding:7px 6px;cursor:pointer;font-size:13px;color:var(--ink)}.account-dropdown button:hover{background:var(--sky)}.account-btn{display:flex;align-items:center;justify-content:center}.account-btn canvas{display:block}.account-dropdown .account-name{display:flex;align-items:center;gap:6px}.mail-btn{position:relative;margin-right:6px}.mail-badge{position:absolute;top:-7px;right:-7px;min-width:16px;height:16px;padding:0 3px;display:flex;align-items:center;justify-content:center;background:var(--coral-bright);border:1px solid var(--ink);font-size:10px;font-weight:700;line-height:1}.mail-box{text-align:left;max-width:480px}.mail-box h2{text-align:center}.mail-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;max-height:55vh;overflow-y:auto}.mail-item{border:1px solid var(--ink);background:var(--white)}.mail-item-head{width:100%;display:flex;align-items:center;gap:8px;padding:9px 10px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--ink);text-align:left}.mail-item-head:hover{background:var(--sky)}.mail-item-title{flex:1}.mail-item--unread .mail-item-title{font-weight:700}.mail-dot{width:8px;height:8px;flex-shrink:0;background:var(--coral-bright);border:1px solid var(--ink)}.mail-item-date{font-size:11px;color:var(--outline)}.mail-item-body{padding:0 10px 10px;border-top:1px solid var(--surface-high);font-size:13px}.mail-item-body p{margin:8px 0 10px}.mail-reward{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.mail-reward-item{display:inline-flex;align-items:center;gap:4px;font-weight:700}.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:18px}.profile-header .section-title{margin:0 0 10px}.profile-avatar-frame{padding:8px;line-height:0;background:var(--white)}.avatar-editor{max-width:620px}.avatar-editor-body{display:flex;gap:18px;align-items:flex-start;justify-content:center;flex-wrap:wrap}.avatar-editor-grid{display:grid;grid-template-columns:repeat(16,19px);grid-auto-rows:19px;width:fit-content;border:2px solid var(--ink);touch-action:none;cursor:crosshair;-webkit-user-select:none;user-select:none;background:repeating-conic-gradient(#ececec 0% 25%,var(--white) 0% 50%) 0 0 / 12px 12px}.avatar-cell{box-shadow:inset 0 0 0 .5px #1a1c2c1f}.avatar-editor-side{display:flex;flex-direction:column;gap:14px;align-items:center}.avatar-palette{display:grid;grid-template-columns:repeat(6,26px);gap:6px}.avatar-swatch{width:26px;height:26px;border:1px solid var(--ink);border-radius:0;padding:0;cursor:pointer;font-size:12px;line-height:1;color:var(--ink)}.avatar-swatch.selected{outline:2px solid var(--ink);outline-offset:1px;box-shadow:2px 2px 0 var(--ink)}.avatar-swatch--eraser{background:var(--white)}.avatar-preview-row{display:flex;align-items:flex-end;gap:10px}.avatar-preview-row canvas{border:1px solid var(--ink);background:var(--white)}.avatar-tools{display:flex;flex-direction:column;gap:8px}.avatar-editor-error{color:var(--error);font-size:13px;margin:12px 0 0}.avatar-editor-actions{display:flex;justify-content:center;gap:10px;margin-top:18px}.coupon-modal{max-width:360px;text-align:left}.coupon-modal label{display:block;margin-bottom:8px;font-size:12px;font-weight:700;text-transform:uppercase;color:var(--ink-soft)}.coupon-modal input{width:100%;border:2px solid var(--ink);background:var(--white);padding:10px 12px;font-family:var(--font);font-size:16px;color:var(--ink);box-shadow:inset 2px 2px #1a1c2c1f}.coupon-modal input:focus{outline:2px solid var(--sky-strong);outline-offset:2px}.coupon-error{color:var(--error);font-size:13px;margin:10px 0 0}.coupon-actions{display:flex;justify-content:center;gap:10px;margin-top:18px;flex-wrap:wrap}.coupon-success{text-align:center}.coupon-success-kicker{margin:0 0 8px;color:var(--mint-strong);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.coupon-success h2{margin-bottom:12px}.coupon-success-amount{display:inline-flex;align-items:center;justify-content:center;min-width:160px;margin:0 auto 14px;padding:10px 16px;background:var(--surface-low);border:1px solid var(--ink);box-shadow:4px 4px 0 var(--ink);color:var(--ink);font-size:24px;font-weight:800;line-height:1.2}.coupon-success .muted{margin:0 0 18px;font-size:14px}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.achievement-card{display:flex;align-items:flex-start;gap:12px;opacity:.65}.achievement-card.unlocked{opacity:1;box-shadow:var(--shadow-offset)}.achievement-card h3{margin:0 0 4px;font-size:14px}.achievement-card p{margin:0 0 6px;font-size:12px}.achievement-card .info{flex:1}.gamehome-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}.slot-card-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.slot-card{position:relative;display:flex;align-items:flex-start;gap:12px;color:var(--ink);box-shadow:var(--shadow-offset);transition:transform .1s,box-shadow .1s}.slot-card:hover:not(.locked){transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.slot-card h3{margin:0 0 6px;font-size:17px;color:var(--ink)}.slot-card-icon{width:48px;height:48px;flex:0 0 48px;display:grid;place-items:center;background:var(--surface-low);border:1px solid var(--ink)}.slot-card-icon>img,.slot-card-icon>canvas{display:block;margin:auto}.slot-card-info{min-width:0;flex:1}.slot-card .meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.tag{font-size:10px;padding:4px 8px;border-radius:0;background:var(--sky);border:1px solid var(--ink);color:var(--ink)}.tag.gold{background:var(--coral)}.slot-card.locked{box-shadow:none;opacity:.6}.locked-banner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#f9f9f9bf;border-radius:0;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);text-align:center}.toast-stack{position:fixed;right:16px;bottom:16px;z-index:90;display:flex;flex-direction:column;gap:10px;max-width:320px}.toast{padding:12px 14px;animation:toast-in .25s ease-out;border-left:4px solid var(--coral-bright);box-shadow:var(--shadow-offset)}.toast.mission{border-left-color:var(--mint-strong)}.toast.tutorial{border-left-color:var(--sky-strong)}.toast h4{margin:0 0 4px;font-size:14px;font-weight:700}.toast p{margin:0;font-size:13px;color:var(--ink-soft)}@keyframes toast-in{0%{transform:translate(40px);opacity:0}to{transform:none;opacity:1}}.tutorial-card{position:fixed;left:16px;bottom:16px;z-index:80;max-width:330px;border:1px solid var(--ink);border-left:4px solid var(--sky-strong);box-shadow:var(--shadow-offset);animation:toast-in .3s ease-out}.tutorial-card h4{margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--sky-strong)}.tutorial-card p{margin:0 0 10px;font-size:14px}.tutorial-highlight{animation:tutorial-pulse 1.1s infinite;position:relative;z-index:45}@keyframes tutorial-pulse{0%,to{outline:2px solid rgba(45,127,168,0);outline-offset:2px}50%{outline:2px solid rgba(45,127,168,.95);outline-offset:5px}}.bonus-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#2d2d2d33;animation:fade-in .25s}@keyframes fade-in{0%{opacity:0}}.bonus-box{text-align:center;padding:26px;max-width:560px;width:calc(100vw - 32px);box-shadow:8px 8px 0 var(--ink)}.bonus-box h2{font-size:20px;color:var(--ink);margin:0 0 18px}.levelup-box{position:relative;display:flex;flex-direction:column;align-items:center;max-width:380px;padding:30px 24px 28px;overflow:hidden;animation:levelup-pop .45s cubic-bezier(.34,1.56,.64,1) both}@keyframes levelup-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.levelup-kicker{margin:0 0 18px;font-size:13px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);animation:levelup-rise .4s ease-out .1s both}.levelup-kicker,.levelup-stage,.levelup-badge,.levelup-reward,.levelup-hint,.levelup-box .pixel-btn{position:relative;z-index:1}.levelup-stage{position:relative;display:grid;place-items:center;width:190px;height:146px;margin:0 0 8px;isolation:isolate}.levelup-firework{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;z-index:0;pointer-events:none;overflow:visible}.levelup-firework span{--angle: 0deg;--distance: 78px;--delay: 0s;--spark-color: var(--mint);--spark-width: 7px;--spark-height: 7px;--spark-offset-x: -3.5px;--spark-offset-y: -3.5px;position:absolute;left:50%;top:50%;width:var(--spark-width);height:var(--spark-height);margin:var(--spark-offset-y) 0 0 var(--spark-offset-x);background:var(--spark-color);box-shadow:0 0 0 1px var(--ink);opacity:0;transform:rotate(var(--angle)) translate(18px) scale(.3);animation:levelup-firework-burst 2.1s ease-out var(--delay) both}@keyframes levelup-firework-burst{0%,10%{opacity:0;transform:rotate(var(--angle)) translate(18px) scale(.25)}22%{opacity:1;transform:rotate(var(--angle)) translate(42px) scale(1.15)}58%{opacity:.9;transform:rotate(var(--angle)) translate(var(--distance)) scale(1)}to{opacity:0;transform:rotate(var(--angle)) translate(calc(var(--distance) + 14px)) scale(.35)}}.levelup-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:118px;height:118px;margin:0;background:var(--coral-bright);border:2px solid var(--ink);box-shadow:var(--shadow-offset);animation:levelup-badge-pop .55s cubic-bezier(.34,1.8,.64,1) .15s both}@keyframes levelup-badge-pop{0%{transform:scale(0) rotate(-10deg)}70%{transform:scale(1.14) rotate(3deg)}to{transform:scale(1) rotate(0)}}.levelup-badge-label{font-size:12px;font-weight:800;letter-spacing:.12em;color:var(--coral-strong)}.levelup-badge-number{font-size:48px;font-weight:800;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}.levelup-reward{display:flex;align-items:center;justify-content:center;gap:8px;width:fit-content;min-width:128px;margin:0 0 18px;padding:8px 14px;background:var(--surface-low);border:1px solid var(--ink);box-shadow:4px 4px 0 var(--ink);font-size:24px;font-weight:800;font-variant-numeric:tabular-nums;animation:levelup-rise .4s ease-out .55s both}.levelup-hint{max-width:240px;margin:0 0 18px;font-size:15px;line-height:1.35;animation:levelup-rise .4s ease-out .9s both}.levelup-box .pixel-btn{min-width:168px;animation:levelup-rise .4s ease-out .9s both}@keyframes levelup-rise{0%{opacity:0;transform:translateY(10px)}}.levelup-confetti{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.levelup-confetti span{position:absolute;top:0;animation-iteration-count:infinite;animation-timing-function:linear}@keyframes levelup-confetti-a{0%{transform:translate3d(0,-6vh,0) rotate(0)}to{transform:translate3d(5vw,106vh,0) rotate(540deg)}}@keyframes levelup-confetti-b{0%{transform:translate3d(0,-6vh,0) rotate(0)}to{transform:translate3d(-5vw,106vh,0) rotate(-540deg)}}@media (prefers-reduced-motion: reduce){.levelup-box,.levelup-kicker,.levelup-firework span,.levelup-badge,.levelup-reward,.levelup-hint,.levelup-box .pixel-btn{animation:none}.levelup-confetti{display:none}}.wheel-wrap{position:relative;width:min(320px,78vw);margin:0 auto 18px}.wheel-pointer{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:22px solid var(--ink);z-index:2}.wheel-canvas{width:100%;border-radius:50%;border:3px solid var(--ink);box-shadow:8px 8px 0 var(--surface-high)}.chest-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}.chest-option{width:120px;padding:16px 10px;cursor:pointer;border:2px solid var(--ink);border-radius:0;background:var(--white);box-shadow:var(--shadow-offset);transition:transform .1s,box-shadow .1s;font-family:var(--font);font-size:12px;font-weight:700;color:var(--ink)}.chest-option:hover:not(:disabled){transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.chest-option.revealed{cursor:default}.chest-option.chosen{background:var(--lavender);animation:chest-pop .4s ease-out}@keyframes chest-pop{0%{transform:scale(.8)}60%{transform:scale(1.12)}to{transform:scale(1)}}.bonus-result{font-size:18px;font-weight:800;letter-spacing:-.01em;font-variant-numeric:tabular-nums;color:var(--mint-strong);margin:12px 0;min-height:24px;animation:chest-pop .4s ease-out}.login-days{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:14px 0 4px}.login-day{width:66px;padding:8px 4px;border:2px solid var(--ink);background:var(--white);font-size:11px;font-weight:700;color:var(--ink)}.login-day-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:4px}.login-day-reward{display:flex;align-items:center;justify-content:center;gap:4px;font-variant-numeric:tabular-nums}.login-day.done{opacity:.4}.login-day.today{background:var(--mint);box-shadow:var(--shadow-offset);transform:translate(-2px,-2px)}.multiplier-flash{font-size:48px;font-weight:800;letter-spacing:-.02em;color:var(--coral-strong);animation:chest-pop .5s ease-out;margin:20px 0}.info-btn{width:24px;height:24px;flex-shrink:0;border-radius:0;border:1px solid var(--ink);background:var(--white);color:var(--ink-soft);font-family:var(--font);font-size:13px;font-weight:700;line-height:1;cursor:pointer;transition:background .12s}.info-btn:hover{background:var(--sky);color:var(--ink)}.help-modal{max-width:460px;width:calc(100vw - 32px);max-height:88vh;overflow-y:auto;text-align:left;box-shadow:8px 8px 0 var(--ink)}.help-modal h2{display:flex;align-items:center;gap:10px;font-size:18px;color:var(--ink);margin:0 0 8px}.help-modal>p{color:var(--ink-soft);font-size:14px;margin:0 0 14px}.help-level{border:1px solid var(--surface-high);border-left:4px solid transparent;border-radius:0;padding:9px 11px;margin-bottom:8px}.help-level.current{border-color:var(--ink);border-left:4px solid var(--mint-strong);background:var(--surface-low)}.help-level .level-title{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);margin-bottom:6px;display:flex;justify-content:space-between}.help-level .effects{font-size:14px;color:var(--mint-strong)}.help-level .prereq{font-size:13px;color:var(--ink-soft)}.home{min-height:100vh;display:flex;flex-direction:column}.home-hero{text-align:center;padding:90px 20px 60px}.home-hero h1{font-size:clamp(32px,6vw,48px);font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0 0 18px}.home-hero p{font-size:17px;color:var(--ink-soft);max-width:640px;margin:0 auto 30px}.home-cta{display:inline-flex;align-items:center;justify-content:center;width:auto;max-width:calc(100vw - 40px);white-space:nowrap;font-size:16px;padding:14px 28px;background:var(--coral)}.home-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(230px,100%),1fr));gap:16px;width:100%;max-width:1080px;margin:0 auto;padding:20px}.feature-card{text-align:center;padding:26px 18px;box-shadow:var(--shadow-offset)}.feature-card h3{font-size:16px;color:var(--ink);margin:14px 0 8px}.feature-card p{font-size:14px;color:var(--ink-soft);margin:0}.home-footer{text-align:center;color:var(--ink-soft);font-size:13px;padding:40px 0 24px;border-top:1px solid var(--surface-high);margin-top:40px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-box{width:380px;max-width:100%;padding:28px;box-shadow:8px 8px 0 var(--ink)}.auth-box h1{font-size:24px;color:var(--ink);text-align:center;margin:0 0 20px}.auth-tabs{display:flex;gap:8px;margin-bottom:18px}.auth-tabs button{flex:1;font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:10px;background:var(--white);color:var(--ink-soft);border:1px solid var(--ink);border-radius:0;cursor:pointer}.auth-tabs button.active{color:var(--ink);background:var(--mint)}.auth-box label{display:block;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);margin:12px 0 6px}.auth-box input{width:100%;padding:12px;font-family:var(--font);font-size:15px;background:var(--white);color:var(--ink);border:1px solid var(--ink);border-radius:0;outline:none}.auth-box input:focus{background:#b3e5fc1a;border-width:2px;padding:11px}.section-title{color:var(--ink);margin:0 0 14px}.muted{color:var(--ink-soft)}.error-text{color:var(--error);font-size:13px}.phaser-host canvas{animation:fade-in .35s ease-out}.phaser-host--scroll,.phaser-host--scroll canvas{touch-action:pan-y}.phaser-host--scroll canvas{pointer-events:none}@media (max-width: 980px){.slot-page,.city-page,.gamehome-grid{grid-template-columns:1fr}}@media (max-width: 900px){.game-logo{order:1}.header-actions{order:3;margin-left:auto}.game-nav{order:4;flex-basis:100%;justify-content:flex-start;flex-wrap:nowrap;min-width:0;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;touch-action:pan-x}.game-nav::-webkit-scrollbar{display:none}.game-nav a{flex:0 0 auto}.hud-resources{order:5;flex-basis:100%;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.hud-resources::-webkit-scrollbar{display:none}.hud-chip{flex-shrink:0}}@media (max-width: 640px){.game-header{gap:8px;padding:8px 12px}.game-logo{font-size:15px}.hud-chip{font-size:12px;min-width:64px;padding:3px 7px 3px 4px}.game-nav a{font-size:10px;padding:6px 8px}.slot-controls{position:fixed;left:10px;right:10px;bottom:10px;z-index:35;background:var(--surface);border:1px solid var(--ink);border-radius:0;padding:10px;box-shadow:var(--shadow-offset)}.spin-button{order:3;flex:1 1 100%;max-width:none}.slot-controls>div:first-child{flex:1 1 auto;min-width:0}.bet-stepper{width:auto;justify-content:space-between}.bet-label{white-space:normal}.game-content{padding:12px 10px calc(130px + env(safe-area-inset-bottom))}body:has(.slot-controls) .game-content{padding-bottom:calc(13rem + env(safe-area-inset-bottom))}body:has(.slot-controls) .toast-stack,body:has(.slot-controls) .tutorial-card{bottom:240px}.bonus-box{max-height:92vh;overflow-y:auto;padding:18px 14px}.levelup-box{padding:26px 18px 24px}.levelup-kicker{font-size:12px;letter-spacing:.12em}.levelup-badge{width:108px;height:108px}.levelup-reward{margin-bottom:16px;font-size:22px}.tutorial-card{max-width:calc(100vw - 32px)}.home-hero{padding-inline:14px}.home-cta{max-width:calc(100vw - 28px);font-size:13px;padding:12px 16px}}.guild-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px;min-width:0}.guild-toolbar .pixel-btn:first-of-type{margin-left:auto}.guild-search{display:flex;gap:8px;margin:12px 0}.guild-search input,.guild-create input,.guild-create textarea{padding:10px;font-family:var(--font);font-size:14px;background:var(--white);color:var(--ink);border:1px solid var(--ink);border-radius:0;outline:none}.guild-search input{flex:1;min-width:0;max-width:320px}.guild-create{padding:16px;margin:12px 0}.guild-create label{display:block;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);margin:12px 0 6px}.guild-create input:not([type=radio]),.guild-create textarea{width:100%;resize:vertical}.guild-emblems{display:flex;gap:6px;flex-wrap:wrap}.guild-emblem{padding:6px;background:var(--white);border:1px solid var(--ink);cursor:pointer}.guild-emblem.selected{background:var(--mint);border-width:2px;padding:5px}.guild-policy{display:flex;flex-direction:column;gap:6px}.guild-policy label{display:flex;align-items:center;gap:8px;margin:0;font-size:13px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--ink)}.guild-policy input[type=radio]{width:auto;flex:0 0 auto;margin:0}.guild-create-actions{display:flex;gap:8px;margin-top:14px}.guild-row{display:flex;align-items:center;gap:12px;min-width:0}.guild-row--mine{outline:2px solid var(--ink)}.guild-rank{min-width:34px;font-weight:700;text-align:center}.guild-rank.top{font-size:20px}.guild-pager{display:flex;align-items:center;gap:12px;justify-content:center;margin-top:14px}.guild-header{display:flex;align-items:center;gap:14px;padding:16px;margin-bottom:12px;min-width:0}.guild-header .info{flex:1;min-width:0}.guild-header h2{margin:0 0 4px}.guild-header p{margin:2px 0}.guild-header-actions{display:flex;flex-direction:column;gap:6px}.guild-tabs{display:flex;gap:0;margin-bottom:12px;max-width:100%}.guild-tabs button{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:10px 14px;background:var(--white);color:var(--ink-soft);border:1px solid var(--ink);border-radius:0;cursor:pointer}.guild-tabs button.active{color:var(--ink);background:var(--mint)}.guild-member-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.guild-page .guild-row h3{display:flex;align-items:center;gap:6px;flex-wrap:wrap}@media (max-width: 640px){.guild-toolbar,.guild-search,.guild-create-actions,.guild-pager,.guild-header,.guild-row,.guild-page .mission-card{align-items:stretch}.guild-toolbar,.guild-search,.guild-create-actions,.guild-pager,.guild-header,.guild-row{flex-direction:column}.guild-toolbar .pixel-btn:first-of-type{margin-left:0}.guild-toolbar .pixel-btn,.guild-search input,.guild-search .pixel-btn,.guild-create-actions .pixel-btn,.guild-pager .pixel-btn,.guild-header-actions .pixel-btn,.guild-row>.pixel-btn{width:100%}.guild-header-actions,.guild-member-actions{width:100%;justify-content:stretch}.guild-member-actions .pixel-btn{flex:1 1 auto;min-width:0}.guild-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr))}.guild-tabs button{min-width:0;padding:9px 6px;font-size:10px;white-space:normal;overflow-wrap:anywhere}.guild-header h2,.guild-page .mission-card h3{overflow-wrap:anywhere}}.game-nav .mail-badge{position:static;margin-left:6px}.chat-drawer{position:fixed;top:0;right:0;bottom:0;z-index:70;width:min(360px,100vw);display:flex;flex-direction:column;padding:0;border:none;border-left:2px solid var(--ink);box-shadow:-6px 0 #2d2d2d1f;animation:chat-slide-in .2s ease-out}@keyframes chat-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--ink)}.chat-header h3{flex:1;margin:0;font-size:14px;letter-spacing:.08em;text-transform:uppercase}.chat-close,.chat-back{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--ink);border-radius:0;font-size:13px;cursor:pointer}.chat-close:hover,.chat-back:hover{background:var(--coral)}.chat-tabs{margin:0;padding:10px 12px 0}.chat-tabs button{position:relative;flex:1}.chat-tabs .mail-badge{position:static;display:inline-flex;margin-left:6px}.chat-tabs .mail-dot{display:inline-block;margin-left:6px}.chat-messages{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:10px 12px}.chat-older{align-self:center;flex-shrink:0}.chat-empty{margin-top:18px;text-align:center;font-size:12px}.chat-msg{max-width:92%;align-self:flex-start;padding:6px 8px;background:var(--surface-low);border:1px solid var(--ink);font-size:13px}.chat-msg--mine{align-self:flex-end;background:var(--mint)}.chat-msg-meta{display:flex;align-items:baseline;gap:6px;font-size:10px}.chat-msg-name{font-weight:700;font-size:11px}.chat-msg-name--link{padding:0;background:none;border:none;color:var(--sky-strong);font:inherit;font-weight:700;font-size:11px;cursor:pointer}.chat-msg-name--link:hover{text-decoration:underline}.chat-msg-time{margin-left:auto;color:var(--outline)}.chat-msg-text{margin:3px 0 0;white-space:pre-wrap;word-break:break-word}.chat-locked{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 16px;text-align:center;font-size:13px}.chat-locked p{margin:0}.chat-dm-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--ink);font-size:13px}.chat-conversations{flex:1;min-height:0;display:flex;flex-direction:column;gap:8px;padding:10px 12px}.chat-search,.chat-input-row input{padding:8px;background:var(--white);border:1px solid var(--ink);border-radius:0;font:inherit;font-size:13px}.chat-conv-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.chat-conv-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px;background:var(--white);border:1px solid var(--ink);border-radius:0;font:inherit;text-align:left;cursor:pointer}.chat-conv-row:hover{background:var(--surface-low)}.chat-conv-main{display:flex;flex-direction:column;gap:2px;min-width:0;font-size:13px}.chat-conv-preview{max-width:220px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:11px;color:var(--outline)}.chat-conv-side{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;font-size:10px;color:var(--outline)}.chat-conv-side .mail-badge{position:static}.chat-input-row{display:flex;gap:6px;padding:10px 12px;border-top:1px solid var(--ink)}.chat-input-row input{flex:1;min-width:0}.dragon-hud-icon{display:block}.dragon-hud-icon--bounce{animation:dragon-bob 1.4s ease-in-out infinite}.dragon-box{position:relative;max-width:440px}.dragon-subtitle{margin:-10px 0 6px}.dragon-stage{position:relative;display:flex;align-items:center;justify-content:center;min-height:132px;padding:6px 0}.dragon-figure{animation:dragon-bob 2.4s ease-in-out infinite}.dragon-figure canvas{display:block}.dragon-mood-sleepy .dragon-figure{animation:dragon-doze 4s ease-in-out infinite;filter:saturate(.65)}.dragon-mood-grumpy .dragon-figure{animation-duration:3.4s;filter:saturate(.85)}.dragon-react-pet .dragon-figure{animation:dragon-wiggle .5s ease-in-out 2}.dragon-react-play .dragon-figure{animation:dragon-hop .55s ease-in-out 2}.dragon-react-feed .dragon-figure{animation:dragon-chomp .5s ease-in-out 2}.dragon-emote{position:absolute;top:6px;right:calc(50% - 88px);animation:dragon-emote-float 2.6s ease-in-out infinite}.dragon-hearts span{position:absolute;top:30%;animation:dragon-heart-rise 1s ease-out forwards}.dragon-away{display:flex;flex-direction:column;align-items:center;gap:8px}.dragon-away p{margin:0}.dragon-mood-line{margin:0 0 12px;font-size:14px}.dragon-progress{margin:0 auto 12px;max-width:300px}.dragon-progress-bar{height:10px;border:1px solid var(--ink);background:#fff}.dragon-progress-fill{height:100%;background:var(--mint);transition:width .5s ease-out}.dragon-progress-label{margin:4px 0 0;font-size:12px}.dragon-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:12px}.dragon-feed-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.dragon-feed-option{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px;padding:8px 6px;border:1px solid var(--ink);background:#fff;font:inherit;font-size:13px;cursor:pointer;box-shadow:2px 2px 0 var(--ink)}.dragon-feed-option:not(:disabled):hover{background:var(--mint)}.dragon-feed-option:disabled{opacity:.45;cursor:default;box-shadow:none}.dragon-feed-note{grid-column:1 / -1;margin:0;font-size:12px}.dragon-name-form{display:flex;gap:8px;justify-content:center;margin-bottom:12px}.dragon-name-input{border:1px solid var(--ink);padding:8px 10px;font:inherit;font-size:14px;min-width:0;width:180px}.dragon-pop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;align-items:center;justify-content:center;background:#ffffffa6}.dragon-pop-panel{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 26px;animation:dragon-pop-in .35s cubic-bezier(.2,1.5,.4,1) both}.dragon-pop-panel--evolve{padding:24px 32px}.dragon-pop-title{margin:0;font-weight:700}.dragon-pop-amount{margin:0;display:flex;align-items:center;gap:6px;color:var(--coral-strong);font-weight:700}.dragon-figure--pop{animation:dragon-hop .7s ease-in-out infinite}@keyframes dragon-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes dragon-doze{0%,to{transform:scaleY(1)}50%{transform:scaleY(.94) translateY(3px)}}@keyframes dragon-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-6deg)}75%{transform:rotate(6deg)}}@keyframes dragon-hop{0%,to{transform:translateY(0)}40%{transform:translateY(-12px) rotate(-3deg)}70%{transform:translateY(0) scaleY(.94)}}@keyframes dragon-chomp{0%,to{transform:scaleY(1)}50%{transform:scaleY(.9) translateY(4px)}}@keyframes dragon-emote-float{0%,to{transform:translateY(0);opacity:.9}50%{transform:translateY(-6px);opacity:1}}@keyframes dragon-heart-rise{0%{transform:translateY(0) scale(.7);opacity:1}to{transform:translateY(-46px) scale(1.15);opacity:0}}@keyframes dragon-pop-in{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
