:root{--bg: #6bb6ff;--bg-deep: #3b7dd8;--grass: #5dbb45;--grass-dark: #348c33;--dirt: #8b5a2b;--dirt-dark: #5a3519;--stone: #7f8c8d;--stone-dark: #4b5563;--wood: #a86b32;--wood-dark: #6f3f18;--gold: #facc15;--diamond: #22d3ee;--red: #ef4444;--energy: #84cc16;--text: #1f2937;--text-light: #f8fafc;--panel: #f4e7c5;--panel-dark: #c8a96a;--border-dark: #2f2118;--muted: #6b7280;--muted-strong: #9ca3af;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--primary: #3b82f6;--primary-strong: #2563eb;--accent: #3b82f6;color:var(--text);background:var(--bg);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#6bb6ff,#3b7dd8 60%,#5dbb45 90%,#8b5a2b)}button{font:inherit}button,a{-webkit-tap-highlight-color:transparent}.block-app{position:relative;max-width:480px;min-height:100vh;margin:0 auto;overflow:hidden;background:linear-gradient(180deg,#6bb6ff,#5ba3e8 40%,#5dbb45 85%,#8b5a2b);box-shadow:0 0 0 4px var(--border-dark),0 12px 40px #0000004d}.block-app:after{content:"";position:fixed;bottom:0;left:0;right:0;height:12px;background:repeating-linear-gradient(90deg,var(--grass) 0px,var(--grass) 12px,var(--grass-dark) 12px,var(--grass-dark) 24px);z-index:0;pointer-events:none}.app-shell{position:relative;max-width:480px;min-height:100vh;margin:0 auto;overflow:hidden;background:linear-gradient(180deg,#6bb6ff,#5ba3e8 40%,#5dbb45 85%,#8b5a2b);box-shadow:0 0 0 4px var(--border-dark),0 12px 40px #0000004d}.app-content{position:relative;z-index:1;min-height:100vh;padding-bottom:calc(96px + env(safe-area-inset-bottom))}.page{width:100%;padding:calc(18px + env(safe-area-inset-top)) 16px 24px}.page-header{margin-bottom:16px}.page-header h1,.profile-hero h1{margin:0;color:var(--text);font-size:28px;font-weight:900;letter-spacing:-.5px;line-height:1.1;text-shadow:1px 1px 0 rgba(255,255,255,.3)}.page-header p,.profile-hero p{margin:8px 0 0;color:var(--muted);line-height:1.45;font-weight:600}.eyebrow,.metric-label,.street-card-kicker{display:block;color:var(--wood-dark);font-size:11px;font-weight:900;letter-spacing:1px;text-transform:uppercase}.hero-card,.game-card,.stat-card,.result-card{border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:4px 4px 0 var(--border-dark)}.hero-card{padding:16px}.city-hero{display:flex;align-items:stretch;justify-content:space-between;gap:16px;min-height:150px;margin-bottom:14px;position:relative;overflow:hidden}.hero-balance{display:block;margin-top:8px;font-size:32px;font-weight:900;line-height:1}.hero-level{display:grid;place-items:center;min-width:64px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);text-align:center}.hero-level span{color:var(--text);font-size:11px;font-weight:800}.hero-level strong{display:block;color:var(--gold);font-size:28px;font-weight:900}.hero-illustration{position:absolute;right:86px;bottom:14px;width:118px;height:auto;border-radius:4px;opacity:.85;pointer-events:none}.city-hero>div{position:relative;z-index:1}.stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:14px}.stat-card{min-width:0;min-height:80px;padding:12px}.stat-card-compact{min-height:72px;padding:10px 12px}.stat-card-wide{grid-column:1 / -1}.stat-card span,.housing-price-grid span,.stat-label-row{display:flex;align-items:center;gap:4px;color:var(--muted);font-size:11px;font-weight:800}.stat-icon{width:28px;height:28px;opacity:1}.stat-card strong,.housing-price-grid strong,.stat-value{display:block;margin-top:4px;color:var(--text);font-size:18px;font-weight:900;line-height:1.1}.progress-bar{height:8px;margin-top:8px;overflow:hidden;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark)}.progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--grass),var(--diamond))}.progress-bar-xp span{background:linear-gradient(90deg,var(--primary),var(--gold))}.section-stack{display:grid;gap:12px;margin-top:16px}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-heading h2{margin:0;font-size:18px;font-weight:900;text-shadow:1px 1px 0 rgba(255,255,255,.3)}.section-heading span{color:var(--muted);font-weight:800}.quick-actions,.list{display:grid;gap:10px}.block-button,.button{width:100%;min-height:44px;border:3px solid var(--border-dark);border-radius:4px;padding:0 16px;color:var(--text-light);font-weight:900;font-size:14px;letter-spacing:.5px;box-shadow:3px 3px 0 var(--border-dark);transition:transform .1s,box-shadow .1s}.block-button:active,.button:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border-dark)}.block-button-primary,.button-primary{background:linear-gradient(180deg,var(--grass),var(--grass-dark));color:var(--text-light);text-shadow:1px 1px 0 rgba(0,0,0,.2)}.button-secondary,.block-button-danger{border:3px solid var(--border-dark);background:var(--panel);color:var(--text);box-shadow:3px 3px 0 var(--border-dark)}.button:disabled,.block-button:disabled{cursor:wait;opacity:.6}.block-title{font-size:18px;font-weight:900;text-shadow:1px 1px 0 rgba(255,255,255,.3)}.block-subtitle{font-size:13px;font-weight:700;color:var(--muted)}.block-resource-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:2px 2px 0 var(--border-dark)}.block-stat{display:flex;align-items:center;gap:6px;padding:6px 10px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel);font-size:12px;font-weight:800;box-shadow:2px 2px 0 var(--border-dark)}.block-slot{display:grid;place-items:center;width:56px;height:56px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);box-shadow:2px 2px 0 var(--border-dark)}.block-inventory-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.block-alert{border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);padding:16px;box-shadow:4px 4px 0 var(--border-dark)}.block-progress{height:10px;overflow:hidden;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark)}.block-progress span{display:block;height:100%;background:var(--grass)}.block-badge{display:inline-flex;align-items:center;min-height:22px;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark);color:var(--text);padding:0 8px;font-size:11px;font-weight:900;white-space:nowrap;box-shadow:1px 1px 0 var(--border-dark)}.voxel-shadow{box-shadow:4px 4px 0 var(--border-dark)}.pixel-border{border:3px solid var(--border-dark);border-radius:4px}.block-icon{display:grid;place-items:center;width:32px;height:32px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:2px 2px 0 var(--border-dark)}.inline-action{min-height:34px;margin-top:10px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel);color:var(--text);padding:0 12px;font-size:12px;font-weight:900;box-shadow:2px 2px 0 var(--border-dark)}.game-card{padding:14px;color:var(--text)}.game-card h2,.game-card h3,.hero-card h2{margin:0}.game-card h2{font-size:18px;font-weight:900}.game-card h3{font-size:15px;font-weight:800}.game-card p,.street-card span,.locked-note{margin:8px 0 0;color:var(--muted);line-height:1.45;font-weight:600}.item-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.badge{display:inline-flex;align-items:center;min-height:22px;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark);color:var(--text);padding:0 8px;font-size:11px;font-weight:900;white-space:nowrap}.badge-info{border-color:var(--border-dark);background:#bfdbfe;color:#1e3a5f}.badge-warning{border-color:var(--border-dark);background:#fef3c7;color:#78350f}.badge-muted{border-color:var(--border-dark);background:#d1d5db;color:var(--muted)}.badge-glow{box-shadow:2px 2px 0 var(--border-dark),0 0 8px #facc1566}.card-meta-row,.job-metrics{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;color:var(--muted);font-size:12px;font-weight:800}.street-card-grid{display:grid;gap:10px;margin-bottom:16px}.street-card{width:100%;text-align:left}.street-card strong{display:block;margin-top:4px;font-size:20px;font-weight:900}.street-card-top,.item-title-with-icon,.active-work-heading{display:flex;align-items:center;gap:12px;min-width:0}.card-illustration{flex:0 0 auto;width:44px;height:44px;border:2px solid var(--border-dark);border-radius:4px;opacity:1}.street-card-active{border-color:var(--grass-dark);background:linear-gradient(145deg,#d4e8c5,var(--panel));box-shadow:4px 4px 0 var(--grass-dark)}.street-focus-card{display:flex;justify-content:space-between;gap:14px}.street-focus-card p{color:var(--muted);line-height:1.45}.place-card,.compact-card{border-radius:4px}.card-disabled{opacity:.5}.salary-value,.money-value{color:var(--grass-dark);font-size:18px;font-weight:900;white-space:nowrap}.job-card{display:grid;gap:12px}.street-filter{display:flex;gap:6px;margin:0 -16px 14px;overflow-x:auto;padding:0 16px 4px;scrollbar-width:none}.street-filter::-webkit-scrollbar{display:none}.filter-chip{flex:0 0 auto;min-height:32px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel);color:var(--muted);padding:0 10px;font-size:12px;font-weight:900;box-shadow:2px 2px 0 var(--border-dark);transition:transform .1s,box-shadow .1s}.filter-chip:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--border-dark)}.filter-chip-active{border-color:var(--grass-dark);background:var(--grass);color:var(--text-light);box-shadow:2px 2px 0 var(--grass-dark)}.active-job-card{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.active-job-card h2,.active-work-panel h2{margin:4px 0 0;font-size:18px;font-weight:900}.active-job-card strong{color:var(--gold);white-space:nowrap}.active-work-panel{display:grid;gap:12px;margin-bottom:14px}.active-work-heading p{margin:5px 0 0;color:var(--muted)}.active-work-timer{border:3px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);padding:12px;box-shadow:3px 3px 0 var(--border-dark)}.active-work-timer span{display:block;color:var(--muted);font-size:12px;font-weight:800}.active-work-timer strong{display:block;margin-top:5px;color:var(--gold);font-size:22px;font-weight:900}.empty-state{text-align:center}.result-card{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;padding:14px;border-color:var(--grass-dark);background:linear-gradient(145deg,#d4e8c5,var(--panel))}.result-card span{color:var(--muted);font-size:12px;font-weight:800}.result-card strong{display:block;margin-top:4px;color:var(--grass-dark);font-size:22px;font-weight:900}.result-metrics{display:grid;justify-items:end;gap:3px}.housing-price-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.housing-price-grid div{min-width:0;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);padding:10px}.profile-hero{display:flex;align-items:center;gap:14px;margin-bottom:14px}.avatar-placeholder{display:grid;flex:0 0 auto;width:64px;height:64px;place-items:center;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);color:var(--text);font-weight:950;font-size:20px;box-shadow:3px 3px 0 var(--border-dark)}.transaction-card{display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:4px}.transaction-card strong{color:var(--grass-dark);white-space:nowrap}.transaction-card .transaction-neutral{color:var(--muted)}.transaction-card p{font-size:13px}.app-alert-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#1f2937b3;padding:18px;animation:fade-in .16s ease-out}.app-alert{width:min(360px,100%);border:4px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:6px 6px 0 var(--border-dark);padding:20px;animation:alert-pop .18s ease-out}.app-alert-error{border-top:6px solid var(--danger)}.app-alert-success{border-top:6px solid var(--success)}.app-alert-info{border-top:6px solid var(--primary)}.app-alert-title{margin:0 0 8px;color:var(--text);font-size:20px;font-weight:900;line-height:1.2}.app-alert-message{margin:0;color:var(--muted);line-height:1.45;font-weight:600}.app-alert-actions{display:flex;justify-content:flex-end;margin-top:16px}.app-alert-button{min-height:40px;border:3px solid var(--border-dark);border-radius:4px;background:linear-gradient(180deg,var(--grass),var(--grass-dark));color:var(--text-light);padding:0 16px;font-weight:900;box-shadow:3px 3px 0 var(--border-dark);transition:transform .1s,box-shadow .1s}.app-alert-button:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border-dark)}.bottom-nav{position:fixed;right:max(10px,calc((100vw - 480px)/2 + 10px));bottom:calc(10px + env(safe-area-inset-bottom));left:max(10px,calc((100vw - 480px)/2 + 10px));z-index:10;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;max-width:460px;margin:0 auto;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);padding:6px;box-shadow:4px 4px 0 var(--border-dark)}.nav-item{display:grid;min-width:0;min-height:52px;place-items:center;border:0;border-radius:4px;background:transparent;color:var(--muted);font-size:10px;font-weight:800;transition:background .1s}.nav-icon{display:grid;width:32px;height:32px;place-items:center;border:2px solid transparent;border-radius:4px;color:var(--muted-strong);font-size:16px}.nav-icon img{width:28px;height:28px;opacity:.8}.nav-item-active{background:#5dbb4526;color:var(--text)}.nav-item-active .nav-icon{border-color:var(--border-dark);background:var(--grass);box-shadow:2px 2px 0 var(--grass-dark);color:var(--text-light)}.nav-item-active .nav-icon img{opacity:1}.fade-in{animation:fade-in .22s ease-out both}.slide-up{animation:slide-up .24s ease-out both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes alert-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:380px){.page{padding-right:12px;padding-left:12px}.page-header h1,.profile-hero h1{font-size:24px}.hero-balance{font-size:28px}.stat-value{font-size:16px}.nav-item{font-size:9px}}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:24px}.loading-spinner{width:32px;height:32px;border:4px solid var(--border-dark);border-top-color:var(--grass);border-radius:2px;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p,.error-screen p{color:var(--muted);font-weight:600}.error-screen h2{margin:0 0 8px;color:var(--danger)}.error-screen .button{margin-top:16px;min-width:160px}.landing-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding-top:48px}.landing-hero{text-align:center;margin-bottom:32px}.landing-logo{display:flex;align-items:center;justify-content:center;width:72px;height:72px;margin:0 auto 16px;border:4px solid var(--border-dark);border-radius:4px;background:var(--grass);box-shadow:4px 4px 0 var(--border-dark)}.landing-logo-text{color:var(--text-light);font-size:28px;font-weight:950;text-shadow:2px 2px 0 var(--grass-dark)}.landing-hero h1{margin:0;font-size:32px;font-weight:950;line-height:1.1;text-shadow:2px 2px 0 rgba(255,255,255,.3)}.landing-subtitle{margin:8px 0 0;color:var(--muted);font-size:15px;font-weight:700}.landing-card{width:100%;max-width:400px;margin-bottom:32px;border:4px solid var(--border-dark);border-radius:4px;background:var(--panel);padding:24px;text-align:center;box-shadow:4px 4px 0 var(--border-dark)}.landing-card h2{margin:0 0 8px;font-size:20px;font-weight:900}.landing-card p{margin:0 0 20px;color:var(--muted);font-weight:600;line-height:1.5}.landing-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.landing-features{width:100%;max-width:400px;display:grid;gap:10px}.landing-feature{display:flex;align-items:flex-start;gap:12px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);padding:14px;box-shadow:3px 3px 0 var(--border-dark)}.landing-feature-icon{font-size:24px;flex-shrink:0}.landing-feature strong{display:block;margin-bottom:2px}.landing-feature p{margin:0;color:var(--muted);font-size:13px;font-weight:600;line-height:1.4}.profile-settings-card{display:grid;gap:14px}.profile-field{display:grid;gap:6px}.profile-label{color:var(--muted);font-size:12px;font-weight:800}.profile-input{width:100%;min-height:40px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);color:var(--text);padding:0 12px;font-size:15px;font-family:inherit;font-weight:600;box-shadow:2px 2px 0 var(--border-dark)}.profile-input:focus{outline:none;border-color:var(--grass-dark)}.profile-input::placeholder{color:var(--muted)}.profile-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.profile-toggle-row strong{display:block;font-size:14px;font-weight:800}.profile-toggle-row p{margin:2px 0 0;color:var(--muted);font-size:12px;font-weight:600}.toggle-button{position:relative;flex-shrink:0;width:48px;height:28px;border:3px solid var(--border-dark);border-radius:4px;background:#9ca3af;padding:0;cursor:pointer;transition:background .2s}.toggle-button.toggle-on{background:var(--grass)}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:2px;background:var(--text-light);transition:transform .2s}.toggle-button.toggle-on .toggle-knob{transform:translate(20px)}.profile-save-message{margin:0;color:var(--grass-dark);font-size:13px;font-weight:700;text-align:center}.leaderboard-card{display:flex;align-items:center;gap:12px}.leaderboard-current{border-color:var(--grass-dark);background:linear-gradient(145deg,#d4e8c5,var(--panel));box-shadow:4px 4px 0 var(--grass-dark)}.leaderboard-rank{flex:0 0 auto;width:32px;text-align:center}.leaderboard-medal{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;border:2px solid var(--border-dark);font-size:13px;font-weight:900}.medal-1{background:var(--gold);color:#451a03;box-shadow:2px 2px 0 var(--border-dark)}.medal-2{background:#d1d5db;color:#1f2937;box-shadow:2px 2px 0 var(--border-dark)}.medal-3{background:#d97706;color:#451a03;box-shadow:2px 2px 0 var(--border-dark)}.leaderboard-rank-num{color:var(--muted);font-size:13px;font-weight:800}.leaderboard-info{flex:1;min-width:0}.leaderboard-info strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:800}.leaderboard-info span{color:var(--muted);font-size:12px;font-weight:700}.shop-card{cursor:pointer;text-align:left}.shop-card:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border-dark)}.item-card{display:grid;gap:10px}.inventory-card{display:grid;gap:8px}.game-hero{position:relative;overflow:hidden;border:3px solid var(--border-dark);border-radius:4px;background:linear-gradient(180deg,#87ceeb,#5ba3e8 60%,#5dbb45);box-shadow:4px 4px 0 var(--border-dark)}.player-summary-card{border:3px solid var(--border-dark);border-radius:4px;background:linear-gradient(135deg,var(--panel) 0%,#e8dcc0 100%);box-shadow:4px 4px 0 var(--border-dark);overflow:hidden;margin-bottom:12px}.player-summary-hero{display:flex;align-items:center;gap:14px;padding:16px}.player-summary-avatar-frame{width:72px;height:108px;flex-shrink:0;border:3px solid var(--border-dark);border-radius:4px;background:linear-gradient(180deg,#87ceeb,#5ba3e8,#5dbb45);box-shadow:3px 3px 0 var(--border-dark);display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.player-summary-avatar{width:56px;height:84px;object-fit:contain;image-rendering:pixelated}.player-summary-info{flex:1;min-width:0}.player-summary-name{margin:4px 0 0;font-size:20px;font-weight:900;line-height:1.1;text-shadow:1px 1px 0 rgba(255,255,255,.3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-summary-meta{display:flex;align-items:center;gap:8px;margin-top:6px}.player-summary-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:2px solid var(--border-dark)}.player-summary-stat{display:flex;align-items:center;gap:8px;padding:10px 12px;border-right:2px solid var(--border-dark)}.player-summary-stat:last-child{border-right:none}.player-summary-stat img{width:20px;height:20px;flex-shrink:0}.player-summary-stat>div{flex:1;min-width:0}.player-summary-label{display:block;font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.player-summary-stat strong{font-size:13px;font-weight:900}.player-summary-xp{padding:10px 12px 12px;border-top:2px solid var(--border-dark)}.player-xp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.player-xp-label{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.player-xp-value{font-size:11px;font-weight:800;color:var(--text)}.player-xp-bar{height:10px;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark);overflow:hidden}.player-xp-fill{height:100%;background:var(--grass);border-radius:1px;transition:width .3s ease}.player-xp-footer{margin-top:4px;font-size:10px;font-weight:700;color:var(--muted);text-align:right}.home-player-level-badge{display:inline-flex;align-items:center;padding:2px 8px;border:2px solid var(--border-dark);border-radius:4px;background:var(--grass);color:var(--text-light);font-size:12px;font-weight:900;box-shadow:2px 2px 0 var(--grass-dark)}.home-player-status{font-size:12px;font-weight:700;color:var(--muted)}.home-xp-label{display:flex;justify-content:space-between;font-size:10px;font-weight:700;color:var(--muted)}.progress-bar-compact{height:6px}.game-hero-illustration{width:100%;height:auto;display:block;opacity:.95}.game-hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:14px;background:linear-gradient(transparent,#2f2118d9)}.game-illustration{width:100%;height:auto;max-height:120px;object-fit:contain;opacity:.9}.icon-bubble{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:4px;border:2px solid var(--border-dark);background:var(--panel);flex-shrink:0;box-shadow:2px 2px 0 var(--border-dark)}.icon-bubble img{width:20px;height:20px}.icon-bubble-gold{background:#fef3c7;border-color:var(--border-dark)}.icon-bubble-green{background:#d4e8c5;border-color:var(--border-dark)}.icon-bubble-purple{background:#e9d5ff;border-color:var(--border-dark)}.game-action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.game-action-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);cursor:pointer;text-align:center;box-shadow:3px 3px 0 var(--border-dark);transition:transform .1s,box-shadow .1s}.game-action-card:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border-dark)}.game-action-card:hover{border-color:var(--grass-dark)}.game-action-card img{width:36px;height:36px}.game-action-card strong{font-size:13px;font-weight:900}.game-action-card span{color:var(--muted);font-size:11px;font-weight:700}.stat-card-game{display:flex;align-items:center;gap:10px;padding:10px 12px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:3px 3px 0 var(--border-dark)}.stat-card-game .stat-icon{width:28px;height:28px;opacity:1}.stat-card-game .stat-info{flex:1;min-width:0}.stat-card-game .stat-label{color:var(--muted);font-size:11px;font-weight:800}.stat-card-game .stat-value{margin-top:2px}.section-title{display:flex;align-items:center;gap:8px;margin-bottom:12px}.section-title h2{margin:0;font-size:16px;font-weight:900;text-shadow:1px 1px 0 rgba(255,255,255,.3)}.section-title img{width:20px;height:20px}.visual-card{position:relative;overflow:hidden;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:4px 4px 0 var(--border-dark)}.visual-card-illustration{width:100%;height:80px;object-fit:cover;opacity:.85}.visual-card-body{padding:14px}.inventory-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;text-align:center}.inventory-empty img{width:72px;height:auto;opacity:.7}.inventory-empty h2{margin:0;color:var(--text)}.inventory-empty p{margin:0;color:var(--muted)}.work-card-game{display:grid;gap:10px;padding:14px}.work-card-game .work-top{display:flex;align-items:flex-start;gap:10px}.work-card-game .work-icon{width:40px;height:40px;flex-shrink:0}.work-card-game .work-info{flex:1}.work-card-game .work-metrics{display:flex;flex-wrap:wrap;gap:6px}.work-card-game .work-metric{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark);font-size:11px;font-weight:800;box-shadow:1px 1px 0 var(--border-dark)}.work-card-game .work-metric img{width:14px;height:14px}.shop-card-game{display:flex;align-items:center;gap:12px;padding:14px}.shop-card-game .shop-icon{width:44px;height:44px;flex-shrink:0}.shop-card-game .shop-info{flex:1}.category-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:2px solid var(--border-dark);border-radius:2px;background:#bfdbfe;font-size:11px;font-weight:800;color:#1e3a5f}.category-tag img{width:12px;height:12px}.nav-icon img{filter:none}.progress-bar-game{height:8px;border:2px solid var(--border-dark);border-radius:2px;background:var(--panel-dark);overflow:hidden}.progress-bar-game span{display:block;height:100%;background:linear-gradient(90deg,var(--grass),var(--gold));transition:width .3s ease}.skin-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.skin-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);cursor:pointer;box-shadow:3px 3px 0 var(--border-dark);transition:transform .1s,box-shadow .1s}.skin-option:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border-dark)}.skin-option-active{border-color:var(--grass-dark);background:#d4e8c5;box-shadow:3px 3px 0 var(--grass-dark)}.skin-option img{width:40px;height:56px}.skin-option span{font-size:11px;font-weight:900;color:var(--text)}.voxel-deco{height:24px;background:repeating-linear-gradient(90deg,var(--grass) 0px,var(--grass) 12px,var(--grass-dark) 12px,var(--grass-dark) 24px);border-top:3px solid var(--border-dark)}.active-work-ready{border-color:var(--gold)!important;box-shadow:4px 4px 0 var(--gold),0 0 12px #facc1540!important}.active-work-ready .active-work-timer{border-color:var(--gold);background:#fef3c7}.active-work-ready .active-work-timer strong{color:var(--gold)}.button-ready{animation:button-pulse 1.5s ease-in-out infinite}@keyframes button-pulse{0%,to{box-shadow:3px 3px 0 var(--border-dark)}50%{box-shadow:3px 3px 0 var(--border-dark),0 0 8px #facc1566}}.active-housing-card{border-color:var(--grass-dark)!important;box-shadow:4px 4px 0 var(--grass-dark),0 0 8px #5dbb4533!important}.daily-reward-card{border-color:var(--gold)!important;box-shadow:4px 4px 0 var(--gold),0 0 8px #facc1533!important}.checklist-item{display:flex;align-items:center;gap:8px;padding:6px 0}.checklist-item+.checklist-item{border-top:1px solid var(--border-dark)}.checklist-check{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel-dark);font-size:14px;font-weight:900;flex-shrink:0}.checklist-done{background:var(--grass);color:var(--text-light);border-color:var(--grass-dark)}.checklist-text{font-size:13px;font-weight:600;color:var(--text)}.checklist-text-done{font-size:13px;font-weight:600;color:var(--muted);text-decoration:line-through}.inline-feedback{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:3px 3px 0 var(--border-dark)}.inline-feedback strong{font-size:13px;font-weight:900}.inline-feedback span{font-size:12px;font-weight:600;color:var(--muted)}.inline-feedback-success{border-color:var(--grass-dark);background:#d4e8c5}.inline-feedback-success strong{color:var(--grass-dark)}.inline-feedback-error{border-color:var(--red);background:#fecaca}.inline-feedback-error strong{color:var(--red)}.inline-feedback-info{border-color:var(--primary);background:#bfdbfe}.inline-feedback-info strong{color:#1e40af}.inline-feedback-warning{border-color:var(--warning);background:#fef3c7}.inline-feedback-warning strong{color:#92400e}.city-map-board{display:flex;flex-direction:column;gap:14px}.city-map-streets{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.street-zone{text-align:left;cursor:pointer;transition:transform .1s,box-shadow .1s,border-color .1s}.street-zone:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border-dark)}.street-zone-active{border-color:var(--grass-dark);background:linear-gradient(135deg,var(--panel) 0%,#d4e8c5 100%);box-shadow:4px 4px 0 var(--grass-dark)}.street-zone-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.street-zone-header strong{font-size:13px;font-weight:900}.street-zone-stats{display:flex;flex-wrap:wrap;gap:6px}.street-stat{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:700;color:var(--muted)}.city-map-details{display:flex;flex-direction:column;gap:8px}.street-detail-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.street-detail-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel)}.street-detail-stat strong{font-size:16px;font-weight:900}.street-detail-stat span{font-size:10px;font-weight:700;color:var(--muted)}.street-place-grid{display:flex;flex-wrap:wrap;gap:6px}.street-place-chip{display:flex;align-items:center;gap:4px;padding:4px 8px;border:2px solid var(--border-dark);border-radius:4px;background:var(--panel);font-size:11px;font-weight:700}.street-place-more{color:var(--muted);font-size:10px}.map-action-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}.map-action-button{display:flex;align-items:center;justify-content:center;gap:6px;width:100%}.street-place-clickable{cursor:pointer;transition:border-color .1s}.street-place-clickable:hover{border-color:var(--grass-dark)}.street-job-clickable{cursor:pointer;transition:border-color .1s,transform .1s;border:3px solid var(--border-dark);border-radius:4px;background:var(--panel);box-shadow:3px 3px 0 var(--border-dark)}.street-job-clickable:hover{border-color:var(--grass-dark)}.street-job-clickable:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--border-dark)}.city-tile-content{display:flex;flex-direction:column;gap:4px}.city-tile-title{font-size:14px;font-weight:900;line-height:1.2}.city-tile-description{font-size:12px;line-height:1.45;color:var(--muted);margin-top:2px}.city-tile-primary{border-color:var(--accent);box-shadow:3px 3px 0 var(--accent)}.city-tile-hero{background:linear-gradient(135deg,var(--panel) 0%,#d4e8c5 100%);border-width:4px}@media(min-width:768px){.block-app,.app-shell{max-width:900px}.page{padding:24px 24px 32px}.game-action-grid{grid-template-columns:repeat(2,1fr)}.list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.list>*{margin-bottom:0}.city-map-board{display:grid;grid-template-columns:1fr 1fr;gap:16px}.city-map-streets{grid-template-columns:1fr}.city-map-details{position:sticky;top:100px}.map-action-grid{grid-template-columns:repeat(3,1fr)}.stat-grid{grid-template-columns:repeat(2,1fr)}.card-meta-row,.job-metrics{flex-wrap:wrap}}@media(min-width:1024px){.block-app,.app-shell{max-width:1180px}.page{padding:28px 32px 36px}.bottom-nav{left:max(16px,calc((100vw - 1164px)/2 + 16px));right:max(16px,calc((100vw - 1164px)/2 + 16px))}.page-header h1,.profile-hero h1{font-size:32px}.game-card{transition:transform .1s,box-shadow .1s}.game-card:hover{transform:translateY(-1px);box-shadow:4px 6px 0 var(--border-dark)}.list{grid-template-columns:repeat(2,1fr)}.stat-grid{grid-template-columns:repeat(4,1fr)}.shop-card-game{flex-direction:row;align-items:center;gap:14px}.game-action-grid{grid-template-columns:repeat(2,1fr);gap:12px}.hero-card{padding:20px 24px}.game-card{padding:16px}.compact-card{padding:12px 16px}}@media(min-width:1280px){.block-app,.app-shell{max-width:1400px}.page{padding:32px 40px 40px}.bottom-nav{left:max(24px,calc((100vw - 1384px)/2 + 24px));right:max(24px,calc((100vw - 1384px)/2 + 24px))}.list{grid-template-columns:repeat(3,1fr)}.game-action-grid{grid-template-columns:repeat(2,1fr)}.stat-grid{grid-template-columns:repeat(4,1fr)}}.online-map-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#5a8a5a;display:flex;flex-direction:column;overscroll-behavior:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.online-map-auth-gate{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;text-align:center}.online-map-auth-gate h2{margin:0;font-size:18px}.online-map-auth-gate p{margin:0;font-size:13px;color:var(--muted)}.disclaimer-text{max-width:360px;text-align:left;background:var(--panel);border:2px solid var(--border-dark);border-radius:8px;padding:16px;margin:8px 0}.disclaimer-text p{margin:0 0 10px;font-size:13px;color:var(--text);line-height:1.5}.disclaimer-text p:last-child{margin-bottom:0}.disclaimer-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;text-align:center}.disclaimer-screen h2{margin:0;font-size:20px;color:var(--text)}.online-map-stage{position:relative;flex:1;overflow:hidden}.online-map-canvas{position:absolute;left:0;top:0;width:100%;height:100%;image-rendering:pixelated;cursor:pointer}.online-map-world{position:absolute;left:0;top:0;transform-origin:0 0;will-change:transform;overflow:hidden}.online-map-ground{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 15% 35%,#6aaa6a 0%,transparent 25%),radial-gradient(ellipse at 75% 55%,#6aaa6a 0%,transparent 20%),radial-gradient(ellipse at 45% 80%,#5a9a5a 0%,transparent 18%),radial-gradient(ellipse at 85% 20%,#7aaa7a 0%,transparent 15%),linear-gradient(135deg,#5a8a5a,#6a9a6a,#5a8a5a 60%,#6a9a6a)}.road{position:absolute;background:linear-gradient(180deg,#c8c8c8,#a8a8a8);border:1px solid #888;z-index:1}.road-h{height:22px;box-shadow:inset 0 1px #ffffff4d}.road-v{width:22px;box-shadow:inset 1px 0 #ffffff4d}.road-h:after{content:"";position:absolute;top:10px;left:0;right:0;height:2px;background:repeating-linear-gradient(90deg,#e8e8e8 0px,#e8e8e8 12px,transparent 12px,transparent 24px)}.road-v:after{content:"";position:absolute;left:10px;top:0;bottom:0;width:2px;background:repeating-linear-gradient(180deg,#e8e8e8 0px,#e8e8e8 12px,transparent 12px,transparent 24px)}.building{position:absolute;background:#d4a574;border:2px solid #b8956a;border-radius:3px;box-shadow:3px 3px #0000002e;z-index:2}.building:after{content:"";position:absolute;top:4px;left:4px;right:4px;height:40%;background:#ffffff1f;border-radius:2px 2px 0 0;pointer-events:none}.building-park{background:#5a9a5a;border-color:#4a8a4a}.online-map-poi{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:transform .15s;z-index:5}.online-map-poi img{width:10px;height:10px;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.3))}.online-map-poi.poi-active{transform:translate(-50%,-100%) scale(1.25)}.poi-label{font-size:3px;font-weight:900;color:var(--text);background:var(--panel);padding:.5px 2px;border:.5px solid var(--border-dark);border-radius:1px;white-space:nowrap;box-shadow:.5px .5px 0 var(--border-dark)}.online-player{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;z-index:10;pointer-events:none}.online-player--other .online-player-avatar{width:4px;height:4px;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.5))}.online-player--other .online-player-name{font-size:10px;max-width:80px}.online-player--self{z-index:15}.online-player--self .online-player-avatar{width:5px;height:5px;filter:drop-shadow(0 0 3px rgba(255,255,255,.6)) drop-shadow(1px 1px 0 rgba(0,0,0,.5))}.online-player--self .online-player-name{font-size:11px;max-width:90px}.online-player-avatar{width:4px;height:4px;image-rendering:pixelated}.online-player-nameplate{display:flex;gap:3px;align-items:center;margin-top:2px}.online-player-name{font-size:2px;font-weight:800;color:var(--text);background:var(--panel);padding:1px 5px;border:2px solid var(--border-dark);border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.online-player-level{font-size:2px;font-weight:900;color:var(--accent);background:var(--panel);padding:0 1px;border:.5px solid var(--border-dark);border-radius:1px}.online-player-you{font-size:2px;font-weight:900;color:#fff;background:var(--accent);padding:0 1px;border:.5px solid var(--border-dark);border-radius:1px}.online-map-hud-top{position:absolute;top:8px;left:12px;right:12px;display:flex;justify-content:space-between;align-items:flex-start;z-index:20;pointer-events:none}.online-map-hud-top>*{pointer-events:auto}.online-map-hud-left{display:flex;align-items:center;gap:6px;background:var(--panel);padding:4px 10px;border:2px solid var(--border-dark);border-radius:4px;box-shadow:2px 2px 0 var(--border-dark)}.online-count{font-size:12px;font-weight:800;color:var(--text)}.online-map-exit{font-size:11px;min-height:32px}.status-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--border-dark)}.status-connected{background:var(--success)}.status-connecting{background:var(--warning);animation:pulse 1s infinite}.status-disconnected{background:var(--muted)}.status-error,.status-auth_required{background:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.online-map-hud-action{position:absolute;bottom:180px;left:50%;transform:translate(-50%);z-index:20}.online-map-hud-action .button{font-size:13px;min-height:36px;white-space:nowrap;box-shadow:2px 2px 0 var(--border-dark)}.online-map-hud-controls{position:absolute;left:16px;bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:20}.online-map-dpad{display:flex;flex-direction:column;align-items:center;gap:2px}.online-map-dpad-row{display:flex;gap:2px;align-items:center}.online-map-dpad-btn{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--panel);border:3px solid var(--border-dark);border-radius:6px;box-shadow:2px 2px 0 var(--border-dark);cursor:pointer;color:var(--text);font-weight:900;touch-action:none;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.online-map-dpad-btn--active{background:var(--accent);color:#fff;transform:translateY(1px);box-shadow:1px 1px 0 var(--border-dark)}.online-map-dpad-center{width:56px;height:56px;background:var(--panel);border:3px solid var(--border-dark);border-radius:6px;opacity:.2}.online-map-district{position:absolute;border:2px dashed rgba(0,0,0,.12);border-radius:12px;pointer-events:none;z-index:1}.online-map-district-label{position:absolute;top:8px;left:12px;font-size:13px;font-weight:900;color:#00000040;letter-spacing:1px;text-transform:uppercase;pointer-events:none;white-space:nowrap}.online-map-street-label{position:absolute;font-size:9px;font-weight:800;color:#0000004d;letter-spacing:.5px;pointer-events:none;white-space:nowrap;z-index:2;transform-origin:0 0}.building-house{background:linear-gradient(180deg,#e0b888,#c4956a);border-color:#a87d55}.building-apartment{background:linear-gradient(180deg,#b8a898,#9a8a7a);border-color:#7a6a5a;border-radius:3px}.building-shop{background:linear-gradient(180deg,#f0d8a0,#d4b878);border-color:#b89858;border-radius:3px}.building-factory{background:linear-gradient(180deg,#9ca3af,#6b7280);border-color:#4b5563;border-radius:2px}.building-warehouse{background:linear-gradient(180deg,#b8b2ae,#8a8480);border-color:#6a6460;border-radius:2px}.online-map-tree{position:absolute;transform:translate(-50%,-100%);z-index:3;pointer-events:none}.online-map-tree-crown{width:26px;height:26px;background:radial-gradient(circle at 40% 35%,#86efac,#4ade80 40%,#22c55e);border-radius:50%;border:2px solid #16a34a;margin:0 auto;box-shadow:2px 2px #0000001a}.online-map-tree-trunk{width:6px;height:10px;background:#92400e;border:1px solid #78350f;margin:-2px auto 0;border-radius:0 0 2px 2px}.online-map-poi-building{width:20px;height:16px;background:linear-gradient(180deg,#f4e7c5,#c8a96a);border:1px solid var(--border-dark);border-radius:4px 4px 2px 2px;display:flex;align-items:center;justify-content:center;box-shadow:1px 1px 0 var(--border-dark);position:relative;transition:filter .2s,border-color .2s}.online-map-poi-building:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:40px;height:10px;background:var(--panel-dark);border:2px solid var(--border-dark);border-radius:4px 4px 0 0}.online-map-poi-building img{width:10px;height:10px;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.2))}.poi-active .online-map-poi-building{filter:drop-shadow(0 0 16px rgba(96,165,250,.6));border-color:var(--primary)}.online-player--other{transition:left .12s linear,top .12s linear}.online-map-svg-layer{position:absolute;left:0;top:0;z-index:1;pointer-events:none}.online-map-real-area--park{fill:#22c55e26;stroke:#22c55e4d;stroke-width:1}.online-map-real-area--yard{fill:#86efac1f;stroke:#22c55e33;stroke-width:1}.online-map-real-area--green{fill:#4ade801a;stroke:#22c55e26;stroke-width:.5}.online-map-real-road--residential{stroke:#b0b0b0;stroke-linecap:round;stroke-linejoin:round}.online-map-real-road--service{stroke:#c8c8c8;stroke-linecap:round;stroke-linejoin:round}.online-map-real-road--footway{stroke:#b4b4b499;stroke-dasharray:4 3;stroke-linecap:round}.online-map-real-road--path{stroke:#a0a0a080;stroke-dasharray:3 4;stroke-linecap:round}.online-map-real-building{fill:#d4a574;stroke:#b8956a;stroke-width:1;stroke-linejoin:round;transition:fill .15s,stroke .15s}.online-map-real-building:hover{fill:#e0b888;stroke:#a87d55}.online-map-real-building--low{fill:#d4a574;stroke:#b8956a;stroke-width:.8}.online-map-real-building--mid{fill:#b8a898;stroke:#8a7a6a;stroke-width:1.2}.online-map-real-building--high{fill:#9a8a7a;stroke:#6a5a4a;stroke-width:1.5;filter:drop-shadow(2px 2px 1px rgba(0,0,0,.2))}.online-building-level-label{font-size:2px;font-weight:800;fill:#fffc;text-anchor:middle;dominant-baseline:central;pointer-events:none}.online-map-real-street-label{font-size:3px;font-weight:800;fill:#0006;letter-spacing:.2px;pointer-events:none;text-anchor:middle;dominant-baseline:middle}.online-map-attribution{position:absolute;right:8px;bottom:8px;font-size:9px;opacity:.5;z-index:20;pointer-events:none;color:#fff}.online-map-hud-district{position:absolute;bottom:calc(180px + env(safe-area-inset-bottom,0px));right:16px;background:var(--panel);padding:4px 10px;border:2px solid var(--border-dark);border-radius:4px;font-size:11px;font-weight:800;color:var(--text);box-shadow:2px 2px 0 var(--border-dark);z-index:20;pointer-events:none;white-space:nowrap}.online-player--other{cursor:pointer;background:none;border:none;padding:0;text-align:inherit;font:inherit;color:inherit}.online-player--selected{filter:drop-shadow(0 0 8px rgba(96,165,250,.7))}.online-reaction-bubble{position:absolute;left:50%;top:-10px;transform:translate(-50%);font-size:6px;animation:onlineReactionFloat 2.6s ease-out forwards;pointer-events:none;z-index:25;filter:drop-shadow(1px 1px 1px rgba(0,0,0,.4))}@keyframes onlineReactionFloat{0%{opacity:0;transform:translate(-50%,8px) scale(.8)}15%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-32px) scale(1.08)}}.online-player-card{position:absolute;left:12px;right:12px;bottom:calc(92px + env(safe-area-inset-bottom,0px));background:#1e1e1eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.12);border-radius:12px;padding:16px;z-index:30;color:#f0f0f0;box-shadow:0 4px 20px #0006}.online-player-card-close{position:absolute;top:8px;right:10px;width:28px;height:28px;border:none;border-radius:50%;background:#ffffff1a;color:#ccc;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.online-player-card-close:active{background:#fff3}.online-player-card-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.online-player-card-avatar-frame{width:56px;height:80px;flex-shrink:0;border:2px solid rgba(255,255,255,.15);border-radius:8px;background:linear-gradient(180deg,#87ceeb,#5ba3e8,#5dbb45);display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.online-player-card-avatar{width:44px;height:66px;object-fit:contain;image-rendering:pixelated}.online-player-card-info{flex:1;min-width:0}.online-player-card-name{display:block;font-size:16px;font-weight:900;color:#fff;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.online-player-card-meta{display:flex;gap:10px;margin-bottom:4px}.online-player-card-level{font-size:12px;font-weight:700;color:var(--gold)}.online-player-card-rep{font-size:12px;font-weight:700;color:#93c5fd}.online-player-card-status{font-size:11px;font-weight:600;color:#ffffff80}.online-player-card-reactions{display:flex;gap:8px;align-items:center}.online-player-reaction-button{width:42px;height:42px;border:2px solid rgba(255,255,255,.12);border-radius:10px;background:#ffffff0f;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.online-player-reaction-button:active{background:#60a5fa40;border-color:var(--primary)}.online-player-reaction-sent{font-size:11px;font-weight:700;color:var(--success);margin-left:6px;animation:fadeInOut 1.5s ease-out forwards}@keyframes fadeInOut{0%{opacity:0}20%{opacity:1}to{opacity:0}}@media(min-width:768px){.online-player-card{left:auto;right:24px;bottom:110px;width:320px}}.online-map-real-building--selected{fill:#60a5fa59!important;stroke:var(--primary)!important;stroke-width:2!important}.online-map-hud-location{position:absolute;bottom:calc(180px + env(safe-area-inset-bottom,0px));right:16px;background:var(--panel);padding:6px 12px;border:2px solid var(--border-dark);border-radius:6px;box-shadow:2px 2px 0 var(--border-dark);z-index:20;pointer-events:none;display:flex;flex-direction:column;gap:2px;max-width:200px}.online-map-hud-street{font-size:11px;font-weight:800;color:var(--text)}.online-map-hud-address{font-size:9px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.online-building-card{position:absolute;left:12px;right:12px;bottom:calc(92px + env(safe-area-inset-bottom,0px));background:#1e1e1eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.12);border-radius:12px;padding:16px;z-index:30;display:flex;flex-direction:column;gap:10px}.online-building-card-close{position:absolute;top:8px;right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;font-size:16px;cursor:pointer}.online-building-card-close:active{background:#fff3}.online-building-card-header{display:flex;flex-direction:column;gap:4px}.online-building-card-address{font-size:16px;font-weight:800;color:#fff}.online-building-card-kind{font-size:12px;color:#fff9}.online-building-card-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#ffffff80}.online-building-card-osm{font-size:9px;color:#ffffff40;font-family:monospace}@media(min-width:768px){.online-building-card{left:auto;right:24px;bottom:110px;width:320px}}@media(pointer:coarse){.online-player-avatar{width:5px;height:5px}.online-player--self .online-player-avatar{width:6px;height:6px}}
