*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--bg: #0b0b0b;--bg-card: #1a1a1a;--bg-overlay: rgba(0, 0, 0, .85);--text: #f5f5f5;--text-muted: #888;--primary: #facc15;--primary-dark: #ca8a04;--success: #22c55e;--danger: #ef4444;--border: #333;--radius: 12px;--radius-sm: 8px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html,body,#root{height:100%;width:100%;overflow:hidden;background:var(--bg);color:var(--text);color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.screen{display:flex;flex-direction:column;height:100%;width:100%;position:relative}.header-actions{display:flex;align-items:center;gap:8px}.lang-toggle{display:inline-flex;align-items:center;gap:6px;padding:4px;border-radius:999px;background:#1111118c;border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lang-toggle.floating{position:absolute;top:calc(12px + var(--safe-top));right:12px;z-index:20}.lang-btn{min-width:34px;padding:4px 8px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;border-radius:999px;border:1px solid transparent;background:transparent;color:var(--text-muted)}.lang-btn.active{background:var(--primary);color:#111}.home-screen{position:relative;justify-content:center;align-items:center;padding:24px;padding-top:calc(24px + var(--safe-top));padding-bottom:calc(24px + var(--safe-bottom));background-size:cover;background-position:center;background-repeat:no-repeat}.home-screen:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,#0b0b0bbf,#0b0b0bf2);z-index:0}.home-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:320px}.home-logo{width:100px;height:100px;object-fit:contain;filter:drop-shadow(0 0 20px rgba(250,204,21,.4));animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 20px rgba(250,204,21,.4))}50%{filter:drop-shadow(0 0 30px rgba(250,204,21,.6))}}.home-content h1{font-size:28px;font-weight:700;color:var(--primary);text-align:center}.subtitle{color:var(--text-muted);font-size:14px}.form-field{width:100%;display:flex;flex-direction:column;gap:8px}.form-field label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.form-field input,.form-field select{width:100%;padding:14px 16px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:16px;outline:none;transition:transform .2s,opacity .2s,background-color .2s;font-family:inherit}.form-field input:focus,.form-field select:focus{border-color:var(--primary);background:var(--bg-card)}.form-field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23facc15' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-field select option{background:var(--bg-card);color:var(--text);padding:12px}.error{color:var(--danger);font-size:14px;text-align:center}.auth-user-info{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);width:100%}.auth-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--primary)}.auth-user-details{flex:1;display:flex;flex-direction:column;gap:2px}.auth-name{font-size:16px;font-weight:600;color:var(--text)}.auth-rank{font-size:12px;color:var(--primary);display:inline-flex;align-items:center;gap:6px}.auth-rank .tier-icon{width:16px;height:16px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}.btn.icon.small{width:36px;height:36px}.btn.icon.small svg{width:18px;height:18px}.btn.google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 20px;background:#fff;color:#333;border-radius:var(--radius);font-weight:600;font-size:15px}.btn.google:active{background:#f0f0f0}.auth-divider{display:flex;align-items:center;gap:12px;width:100%;margin:8px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{font-size:12px;color:var(--text-muted);white-space:nowrap}.auth-note{font-size:11px;color:var(--text-muted);text-align:center;margin-top:-4px}.home-buttons{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:8px}.lobby-screen{background-size:cover;background-position:center;background-repeat:no-repeat}.lobby-overlay{display:flex;flex-direction:column;height:100%;background:linear-gradient(180deg,#0b0b0bf2,#0b0b0bd9,#0b0b0bf2)}.lobby-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:calc(12px + var(--safe-top));background:#1a1a1ae6;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lobby-title{display:flex;align-items:center;gap:10px}.lobby-logo{width:32px;height:32px;object-fit:contain}.lobby-header h1{font-size:20px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:1px}.lobby-header .spin{animation:spin 1s linear infinite}.lobby-content{flex:1;overflow-y:auto;padding:16px;padding-bottom:calc(16px + var(--safe-bottom));display:flex;flex-direction:column;gap:16px}.lobby-error{padding:12px 16px;background:#ef444426;border:1px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger);font-size:14px;text-align:center}.lobby-quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s,background-color .2s}.quick-action-btn:active{transform:scale(.97)}.quick-action-btn.create{border-color:var(--primary);background:#facc151a}.quick-action-btn.create .quick-action-icon{color:var(--primary)}.quick-action-btn.solo{border-color:var(--success);background:#22c55e1a}.quick-action-btn.solo .quick-action-icon{color:var(--success)}.quick-action-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.quick-action-icon svg{width:32px;height:32px}.lobby-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.lobby-card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.lobby-card-icon{width:20px;height:20px;color:var(--primary);flex-shrink:0}.lobby-card-header h3{flex:1;font-size:14px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.rooms-count{padding:4px 10px;background:var(--primary);color:#000;font-size:12px;font-weight:700;border-radius:12px}.join-code-row{display:flex;gap:10px}.join-code-row input{flex:1;padding:14px 16px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:18px;font-family:monospace;font-weight:600;text-transform:uppercase;letter-spacing:4px;text-align:center;outline:none;transition:border-color .2s}.join-code-row input:focus{border-color:var(--primary)}.join-code-row input::placeholder{letter-spacing:2px;font-weight:500;color:var(--text-muted)}.join-code-row .btn{width:56px;padding:0}.join-code-row .btn svg{width:24px;height:24px}.create-room-modal{position:fixed;inset:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:100;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.create-room-card{width:100%;max-width:420px;background:var(--bg);border:2px solid var(--primary);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:20px;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px #00000080,0 0 0 1px #facc1533}@keyframes slideUp{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.create-room-card h3{font-size:22px;font-weight:700;color:var(--primary);text-align:center;margin:0;text-transform:uppercase;letter-spacing:1px}.create-room-card>input{padding:14px 16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:16px;outline:none;transition:transform .2s,opacity .2s,background-color .2s}.create-room-card>input:focus{border-color:var(--primary);background:var(--bg)}.create-room-actions{display:flex;gap:12px;margin-top:8px}.create-room-actions .btn{flex:1;padding:14px;font-weight:600;font-size:15px}.rooms-card{flex:1;display:flex;flex-direction:column;min-height:200px}.btn.full-width{width:100%}.loading-rooms{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;color:var(--text-muted);font-size:14px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.no-rooms{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;text-align:center}.no-rooms-icon{width:64px;height:64px;color:var(--text-muted);opacity:.5;margin-bottom:12px}.no-rooms p{color:var(--text-muted);font-size:15px;font-weight:500}.no-rooms .hint{margin-top:6px;font-size:13px;color:var(--text-muted);opacity:.7}.rooms-list{display:flex;flex-direction:column;gap:10px}.room-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .2s}.room-card:active{border-color:var(--primary)}.room-card.full{opacity:.6}.room-avatar{width:44px;height:44px;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#000;flex-shrink:0}.room-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.room-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-host{font-size:12px;color:var(--text-muted)}.room-tags{display:flex;gap:6px;flex-wrap:wrap}.room-tag{font-size:11px;padding:2px 6px;border-radius:999px;background:#facc1526;color:var(--primary);border:1px solid rgba(250,204,21,.4)}.room-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.room-players{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--text-muted)}.room-players svg{width:14px;height:14px}.btn.small{padding:8px 14px;font-size:12px;font-weight:600}.btn.disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.landing-screen{overflow-y:auto;padding:0;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.landing-hero{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:40px 24px;background-size:cover;background-position:center;background-repeat:no-repeat;text-align:center;overflow:hidden}.landing-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0b0b0bb3,#0b0b0be6);z-index:1}.landing-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;transform:translate(-50%,-50%);object-fit:cover;z-index:0;opacity:.6}.landing-hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}.landing-logo{width:120px;height:120px;object-fit:contain;margin-bottom:16px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.landing-hero h1{font-size:36px;font-weight:800;color:var(--primary);margin-bottom:8px;text-shadow:0 2px 20px rgba(250,204,21,.3)}.landing-tagline{font-size:18px;color:var(--text-muted);font-weight:500}.landing-characters{padding:32px 16px;background:var(--bg);text-align:center}.landing-characters h2{font-size:20px;font-weight:600;color:var(--text);margin-bottom:20px}.characters-row{display:flex;gap:12px;overflow-x:auto;padding:8px 0;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.character-card{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);scroll-snap-align:center;transition:transform .2s,border-color .2s}.character-card:active{transform:scale(.95);border-color:var(--primary)}.character-card img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--border);background:var(--bg)}.character-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap}.landing-features{display:flex;flex-direction:column;gap:20px;padding:40px 24px;background:var(--bg-card)}.feature{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:20px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border)}.feature-icon{font-size:40px;margin-bottom:4px}.feature-icon-img{width:56px;height:56px;object-fit:contain;margin-bottom:8px;filter:drop-shadow(0 2px 8px rgba(250,204,21,.3))}.feature h3{font-size:18px;font-weight:600;color:var(--text)}.feature p{font-size:14px;color:var(--text-muted);line-height:1.5}.landing-cta{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;text-align:center;background-size:cover;background-position:center;background-repeat:no-repeat}.landing-cta:before{content:"";position:absolute;inset:0;background:#0b0b0bd9}.btn.large{position:relative;z-index:1;padding:18px 48px;font-size:18px;font-weight:700;border-radius:50px;box-shadow:0 4px 20px #facc1566}.landing-note{position:relative;z-index:1;font-size:13px;color:var(--text-muted)}.landing-footer{padding:24px;text-align:center;border-top:1px solid var(--border)}.landing-footer p{font-size:12px;color:var(--text-muted)}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s,background-color .2s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--primary);color:#000}.btn.primary:active{background:var(--primary-dark)}.btn.secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn.ghost{background:transparent;color:var(--text-muted);padding:8px 16px;font-size:14px}.btn.ghost:active{color:var(--text)}.btn.icon{width:44px;height:44px;padding:0;background:transparent;color:var(--text)}.btn.icon svg{width:24px;height:24px}.sound-toggle.is-on{color:var(--success)}.sound-toggle.is-on svg{stroke:var(--success)}.btn.action{flex:1;flex-direction:column;gap:4px;padding:12px 8px;background:var(--bg-card);color:var(--text);font-size:12px}.btn.action svg{width:24px;height:24px}.btn.fab{position:fixed;width:60px;height:60px;border-radius:12px;background:#1a1a1a;color:var(--text);border:2px solid #333;box-shadow:0 4px 12px #000000b3,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .2s,opacity .2s,background-color .2s}.btn.fab:active{transform:scale(.92);border-color:#555;box-shadow:0 2px 8px #000c,inset 0 1px #ffffff14}.btn.fab svg{width:26px;height:26px;stroke-width:2.5;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.fab-container{position:fixed;right:20px;bottom:calc(100px + var(--safe-bottom));display:flex;flex-direction:column;gap:16px;z-index:50}.fab-container .btn.fab{position:relative;right:auto;bottom:auto}.fab-badge{position:absolute;top:-4px;right:-4px;min-width:24px;height:24px;padding:0 6px;background:#dc2626;color:#fff;font-size:12px;font-weight:800;border-radius:6px;display:flex;align-items:center;justify-content:center;border:2px solid #1a1a1a;box-shadow:0 2px 6px #0009,inset 0 -1px #0000004d;animation:badge-bounce .5s ease-out}@keyframes badge-bounce{0%{transform:scale(0)}50%{transform:scale(1.15)}to{transform:scale(1)}}.cards-fab{background:#1e293b;border-color:#334155}.cards-fab svg{color:#94a3b8}.cards-fab:active{border-color:#475569}.chat-fab{background:#292524;border-color:#44403c}.chat-fab svg{color:#a8a29e}.chat-fab:active{border-color:#57534e}.game-screen{position:relative}.game-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;padding-top:calc(8px + var(--safe-top));background:var(--bg-card);border-bottom:1px solid var(--border);z-index:10}.game-info{display:flex;flex-direction:column;align-items:center;gap:2px}.mode-tag{font-size:11px;padding:2px 8px;border-radius:999px;background:#22c55e33;color:var(--success);border:1px solid rgba(34,197,94,.5)}.turn-indicator{font-size:14px;font-weight:600;color:var(--primary);padding:4px 10px;background:#facc1526;border-radius:12px}.turn-indicator.my-turn{background:var(--primary);color:#000;animation:pulse 1.5s ease-in-out infinite}.tile-count{font-size:12px;color:var(--text-muted)}.help-btn{font-weight:700!important;font-size:16px!important}.first-time-hint{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 16px;background:linear-gradient(135deg,#ffc107f2,#ff9800f2);color:#1a1a1a;font-size:13px;font-weight:500;animation:hint-slide-down .3s ease-out}.first-time-hint .hint-dismiss{background:#0003;border:none;color:#1a1a1a;width:24px;height:24px;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}@keyframes hint-slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.resource-bar{display:flex;flex-direction:column;gap:8px;padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.resource-row{display:flex;align-items:center;justify-content:center;gap:16px}.resource{display:flex;align-items:center;gap:6px;font-size:16px;font-weight:600;position:relative}.resource img{width:44px;height:44px;object-fit:contain}.resource-img-fallback{width:44px;height:44px;object-fit:contain}.resource.sanity span{color:var(--danger)}.resource.sanity.warning{padding:6px 10px;background:#fb923c26;border-radius:8px;border:1px solid rgba(251,146,60,.4)}.resource.sanity.critical{padding:6px 10px;background:#ef444433;border-radius:8px;border:1px solid var(--danger);animation:pulse-danger 1.5s ease-in-out infinite}@keyframes pulse-danger{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.resource .warning-icon{font-size:18px;margin-left:4px;animation:shake .5s ease-in-out infinite}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.resource.points{color:var(--primary);font-size:18px;padding:6px 10px;background:#facc1526;border-radius:8px;border:1px solid rgba(250,204,21,.4)}.upcoming-tiles-bar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.upcoming-label{font-size:12px;color:var(--muted);white-space:nowrap}.upcoming-tiles-list{display:flex;gap:8px}.upcoming-tile{position:relative;width:36px;height:36px;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--bg)}.upcoming-tile img{width:100%;height:100%;object-fit:cover}.upcoming-index{position:absolute;bottom:1px;right:1px;width:14px;height:14px;background:#000000bf;border-radius:3px;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;color:var(--muted)}.upcoming-tile .tile-edge{position:absolute}.upcoming-tile .tile-edge.n{top:0;left:25%;width:50%;height:2px}.upcoming-tile .tile-edge.s{bottom:0;left:25%;width:50%;height:2px}.upcoming-tile .tile-edge.e{right:0;top:25%;width:2px;height:50%}.upcoming-tile .tile-edge.w{left:0;top:25%;width:2px;height:50%}.points-label{font-size:16px}.game-canvas{flex:1;position:relative;overflow:hidden;touch-action:none}.game-canvas canvas{display:block;width:100%;height:100%}.game-canvas.bebedeira canvas{--bebedeira-blur: .35px;--bebedeira-sat: 1.4;--bebedeira-contrast: 1.1;--bebedeira-hue: 12deg;--bebedeira-wobble-sat: .16;--bebedeira-wobble-contrast: .04;--bebedeira-wobble-hue: 7deg;--bebedeira-wobble-blur: 1.2px;filter:saturate(var(--bebedeira-sat)) contrast(var(--bebedeira-contrast)) hue-rotate(var(--bebedeira-hue)) blur(var(--bebedeira-blur));animation:bebedeira-filter-mobile var(--bebedeira-speed, 3.2s) ease-in-out infinite}@keyframes bebedeira-filter-mobile{0%{filter:saturate(var(--bebedeira-sat)) contrast(var(--bebedeira-contrast)) hue-rotate(calc(var(--bebedeira-hue) * -1)) blur(var(--bebedeira-blur))}50%{filter:saturate(calc(var(--bebedeira-sat) + var(--bebedeira-wobble-sat))) contrast(calc(var(--bebedeira-contrast) + var(--bebedeira-wobble-contrast))) hue-rotate(calc(var(--bebedeira-hue) + var(--bebedeira-wobble-hue))) blur(calc(var(--bebedeira-blur) + var(--bebedeira-wobble-blur)))}to{filter:saturate(var(--bebedeira-sat)) contrast(var(--bebedeira-contrast)) hue-rotate(calc(var(--bebedeira-hue) * -1)) blur(var(--bebedeira-blur))}}@media(prefers-reduced-motion:reduce){.game-canvas.bebedeira canvas{animation:none;filter:saturate(var(--bebedeira-sat)) contrast(var(--bebedeira-contrast)) hue-rotate(var(--bebedeira-hue)) blur(var(--bebedeira-blur))}}.game-footer{display:flex;align-items:center;gap:10px;padding:10px 12px;padding-bottom:calc(10px + var(--safe-bottom));background:var(--bg-card);border-top:1px solid var(--border);z-index:10;flex-wrap:wrap}.game-footer.active{border-top:2px solid var(--primary)}.game-footer.waiting{justify-content:center}.waiting-message{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:14px}.waiting-message strong{color:var(--primary)}.waiting-spinner{animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.current-tile{flex-shrink:0}.tile-preview{position:relative;width:90px;height:90px;background:var(--bg);border:3px solid var(--primary);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted);transition:transform .2s;overflow:hidden;box-shadow:0 2px 8px #facc154d}.tile-preview img{width:100%;height:100%;object-fit:cover}.edge-marker{position:absolute;border-radius:3px;box-shadow:0 0 4px #00000080}.edge-marker.edge-n{top:0;left:50%;transform:translate(-50%);width:45%;height:6px}.edge-marker.edge-s{bottom:0;left:50%;transform:translate(-50%);width:45%;height:6px}.edge-marker.edge-e{right:0;top:50%;transform:translateY(-50%);width:6px;height:45%}.edge-marker.edge-w{left:0;top:50%;transform:translateY(-50%);width:6px;height:45%}.game-actions{flex:1;display:flex;gap:8px}.edge-legend{display:flex;flex-wrap:wrap;gap:6px;padding:6px 8px;background:var(--bg);border-radius:var(--radius-sm);font-size:10px}.legend-item{display:flex;align-items:center;gap:4px;color:var(--text-muted)}.legend-color{width:10px;height:10px;border-radius:2px}.overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;flex-direction:column;z-index:100;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.overlay-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.overlay-header h2{font-size:18px;font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.chat-message{padding:10px 14px;background:var(--bg-card);border-radius:var(--radius-sm);font-size:14px}.chat-message strong{color:var(--primary);margin-right:8px}.chat-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.chat-input input{flex:1;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:16px;outline:none}.chat-input input:focus{border-color:var(--primary)}.chat-input .btn{flex-shrink:0}.players-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.player-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.player-row.active{border-color:var(--primary)}.player-row.knocked{opacity:.6;filter:grayscale(.8) saturate(.5);animation:ko-pulse 1.8s ease-in-out infinite}.player-name{font-weight:500}.player-score{color:var(--primary);font-weight:600}.player-row.me{background:#facc151a}.player-info{display:flex;flex-direction:column;gap:2px}.player-resources{display:flex;gap:8px;font-size:12px;color:var(--text-muted)}.player-resources span{display:flex;align-items:center;gap:2px}.ko-tag{margin-left:6px;padding:2px 6px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.04em;color:#fff1f2;background:#ef444466;border:1px solid rgba(239,68,68,.6);text-transform:uppercase}.player-icon{width:30px;height:30px;object-fit:contain}@keyframes ko-pulse{0%,to{opacity:.85}50%{opacity:.45}}.cards-grid{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;align-content:start}.card-item{display:flex;gap:12px;background:var(--bg-card);border-radius:var(--radius);border:2px solid var(--border);padding:12px;cursor:pointer;transition:transform .2s,opacity .2s,background-color .2s}.card-item:active{transform:scale(.98)}.card-item.selected{border-color:var(--primary);box-shadow:0 0 12px #facc154d}.card-item img{width:60px;height:80px;object-fit:cover;border-radius:6px;background:var(--bg);flex-shrink:0}.card-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.card-title{font-size:14px;font-weight:600;color:var(--text)}.card-text{font-size:12px;color:var(--text-muted);line-height:1.4}.card-effects{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.card-effects-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:4px}.card-effects-base{margin-top:4px}.card-effects-empty,.card-hint,.card-adjustments{display:block;font-size:12px;color:var(--text-muted);margin-top:4px}.card-effects .effect{font-size:13px;padding:3px 8px;border-radius:4px;background:var(--bg);font-weight:500}.card-effects .effect.base{opacity:.6}.card-effects .effect.positive{color:var(--success)}.card-effects .effect.negative{color:var(--danger)}.card-costs{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;font-size:13px}.cost-label{color:var(--text-muted);font-weight:500}.card-costs .cost{font-weight:600;padding:2px 6px;border-radius:4px;color:var(--text);background:var(--bg)}.card-costs .cost.cannot-afford{color:var(--danger);background:#ef444426}.cost-adjusted{font-size:12px;color:var(--text-muted)}.card-target{display:inline-block;margin-top:4px;font-size:12px;padding:4px 8px;background:var(--bg);border-radius:4px;color:var(--text-muted);font-weight:500}.card-actions{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.target-select{display:flex;flex-direction:column;gap:8px}.target-select p{font-size:14px;color:var(--text-muted)}body{overscroll-behavior:none}::-webkit-scrollbar{width:0;height:0}.game-over-overlay{justify-content:center;align-items:center;background:#000000f2}.game-over-content{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 24px;max-width:400px;width:100%}.game-over-title{font-size:32px;font-weight:700;color:var(--primary);text-align:center;animation:bounce .5s ease-out}@keyframes bounce{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.ranked-badge{display:inline-block;padding:6px 14px;background:linear-gradient(135deg,var(--primary),#ea580c);border-radius:8px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.1em;box-shadow:0 2px 8px #facc154d;margin-bottom:8px}.elo-changes{width:100%;padding:16px;background:#facc150d;border-radius:var(--radius-sm);border:1px solid rgba(250,204,21,.2)}.elo-changes h3{font-size:13px;color:var(--text-muted);margin-bottom:12px;text-align:center;text-transform:uppercase;letter-spacing:1px;font-weight:700}.elo-change-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#0003;border-radius:6px;margin-bottom:6px}.elo-change-row:last-child{margin-bottom:0}.elo-player{font-weight:600;font-size:14px}.elo-change{font-family:Courier New,monospace;color:var(--primary);font-weight:600;font-size:12px}.final-standings{display:flex;flex-direction:column;gap:8px;width:100%}.standing-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.standing-row.winner{border-color:var(--primary);background:#facc151a}.standing-row.me{box-shadow:0 0 0 2px var(--primary)}.standing-position{font-size:18px;font-weight:700;color:var(--primary);min-width:32px}.standing-row.winner .standing-position:before{content:"🏆 "}.standing-name{flex:1;font-weight:500}.standing-score{font-weight:600;color:var(--primary)}.my-final-stats{width:100%;padding:24px;background:linear-gradient(135deg,var(--bg-card) 0%,rgba(250,204,21,.05) 100%);border-radius:var(--radius);border:2px solid var(--border);position:relative;overflow:hidden}.my-final-stats:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent)}.my-final-stats h3{font-size:13px;color:var(--text-muted);margin-bottom:20px;text-align:center;text-transform:uppercase;letter-spacing:1px;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:var(--bg);border-radius:var(--radius-sm);border:2px solid var(--border)}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-value{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:700;color:var(--text)}.stat-icon{width:32px!important;height:32px!important;object-fit:contain!important;flex-shrink:0}.resource-icon{font-size:16px}.card-item .inline-icon,.inline-icon{width:40px!important;height:40px!important;vertical-align:text-bottom;margin-right:4px;display:inline-block;border-radius:0!important;object-fit:contain!important}.lobby-ready-overlay{z-index:100;background:#000000e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.lobby-ready-content{background:var(--bg);border:2px solid var(--primary);border-radius:var(--radius);padding:28px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:24px;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px #00000080,0 0 0 1px #facc1533}.lobby-ready-content h2{font-size:24px;text-align:center;color:var(--primary);margin:0;text-transform:uppercase;letter-spacing:1px;font-weight:700}.room-code-display{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;background:linear-gradient(135deg,var(--bg-card) 0%,rgba(250,204,21,.05) 100%);border-radius:var(--radius-sm);border:2px solid var(--border);position:relative;overflow:hidden}.room-code-display:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent)}.room-code-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:600}.room-code{font-size:24px;font-weight:900;letter-spacing:4px;color:var(--primary);font-family:monospace;text-shadow:0 0 20px rgba(250,204,21,.3)}.lobby-ready-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:2px solid var(--border)}.lobby-ready-header span{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.lobby-ready-header strong{font-size:16px;color:var(--success);font-weight:700}.lobby-mode-tag{margin:10px 0 4px;display:inline-flex;align-self:flex-start;padding:4px 10px;border-radius:999px;font-size:12px;color:var(--success);background:#22c55e2e;border:1px solid rgba(34,197,94,.45)}.lobby-modifier-active{font-size:12px;color:var(--text-muted);margin-bottom:6px}.lobby-ready-list{display:flex;flex-direction:column;gap:10px}.lobby-ready-row{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-sm);border:2px solid var(--border);transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.lobby-ready-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:transparent;transition:background .25s}.lobby-ready-row.ready{border-color:var(--success);background:linear-gradient(135deg,#22c55e14,#22c55e05)}.lobby-ready-row.ready:before{background:var(--success);box-shadow:0 0 12px var(--success)}.lobby-ready-row.host{border-color:var(--primary);background:linear-gradient(135deg,#facc1514,#facc1505)}.lobby-ready-row.host:before{background:var(--primary)}.ready-dot{width:14px;height:14px;border-radius:50%;background:var(--text-muted);flex-shrink:0;transition:transform .25s,opacity .25s;border:2px solid transparent}.lobby-ready-row.ready .ready-dot{background:var(--success);box-shadow:0 0 12px var(--success),0 0 4px var(--success) inset;border-color:#22c55e4d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.ready-name{flex:1;font-weight:600;font-size:15px}.ready-character{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);object-fit:cover}.ready-tag{font-size:9px;font-weight:800;padding:5px 10px;background:var(--primary);color:var(--bg);border-radius:6px;letter-spacing:1px;text-transform:uppercase;box-shadow:0 2px 8px #facc154d}.ready-tag.bot{background:var(--text-muted);box-shadow:0 2px 8px #8888884d}.ready-state{font-size:13px;color:var(--text-muted);font-weight:500}.lobby-ready-row.ready .ready-state{color:var(--success);font-weight:700}.kick-btn{background:var(--danger);color:#fff;border:none;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;flex-shrink:0}.kick-btn:hover{background:#dc2626}.lobby-bot-controls{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg-card);border-radius:var(--radius-sm);border:2px solid var(--border)}.lobby-modifier-select{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--bg-card);border-radius:var(--radius-sm);border:2px solid var(--border)}.lobby-modifier-select label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.lobby-modifier-select select{padding:12px 14px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;outline:none}.modifier-desc{font-size:12px;color:var(--text-muted)}.lobby-character-select{display:flex;flex-direction:column;gap:12px}.lobby-character-header{display:flex;justify-content:space-between;gap:10px;align-items:baseline}.character-note{font-size:11px;color:var(--text-muted)}.lobby-character-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.lobby-character-card{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:center;padding:12px;background:var(--bg-card);border-radius:var(--radius-sm);border:2px solid var(--border);text-align:left;color:var(--text);cursor:pointer;transition:transform .2s,opacity .2s,background-color .2s}.lobby-character-card:active{transform:scale(.98)}.lobby-character-card.selected{border-color:var(--primary);box-shadow:0 0 12px #facc1540}.lobby-character-card:disabled{opacity:.6}.lobby-character-card img{width:64px;height:64px;border-radius:10px;border:2px solid var(--border);object-fit:cover}.lobby-character-info{display:flex;flex-direction:column;gap:4px}.lobby-character-name{font-size:13px;font-weight:700}.lobby-character-passive{font-size:11px;color:var(--text-muted);line-height:1.3}@media(max-width:360px){.lobby-character-grid{grid-template-columns:1fr}}.lobby-bot-controls .muted{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.bot-buttons{display:flex;gap:10px}.bot-buttons .btn{font-weight:600}.lobby-ready-actions{display:flex;gap:12px;padding-top:16px;border-top:2px solid var(--border)}.lobby-ready-actions .btn{flex:1;padding:14px;font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.5px}.seasons-banner{display:flex;align-items:center;gap:16px;padding:16px;background:linear-gradient(135deg,#fb923c26,#ea580c1a);border:1px solid rgba(251,146,60,.3);border-radius:12px;margin-bottom:16px}.seasons-icon{font-size:32px;flex-shrink:0}.seasons-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}.seasons-subtitle{font-size:12px;color:var(--text-muted)}.leaderboard-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:4px;background:#0003;border-radius:12px;margin-bottom:16px}.leaderboard-tab{padding:12px 16px;background:transparent;border:none;border-radius:8px;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s ease,opacity .2s ease,background-color .2s ease,border-color .2s ease;white-space:nowrap}.leaderboard-tab:active{transform:scale(.95)}.leaderboard-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #fb923c4d}.leaderboard-list{display:flex;flex-direction:column;gap:8px;padding:12px;max-height:60vh;overflow-y:auto}.leaderboard-entry{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;transition:transform .2s ease,opacity .2s ease,background-color .2s ease,border-color .2s ease}.leaderboard-entry:active{transform:scale(.98);border-color:var(--accent)}.leaderboard-rank{font-size:18px;font-weight:700;color:var(--accent);min-width:40px;text-align:center;flex-shrink:0;display:grid;place-items:center}.leaderboard-rank img{width:26px;height:26px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}.leaderboard-player{flex:1;min-width:0}.leaderboard-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-stats{display:flex;gap:6px;flex-wrap:wrap}.stat-badge{font-size:11px;padding:4px 8px;border-radius:6px;font-weight:600;white-space:nowrap}.stat-badge.elo{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000}.stat-badge.games{background:#64748b4d;color:var(--text-muted)}.stat-badge.wins{background:#22c55e33;color:#22c55e}.stat-badge.winrate{background:#3b82f633;color:#3b82f6}.checkbox-field{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-card);border-radius:8px;border:2px solid var(--border);cursor:pointer}.checkbox-field input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}.checkbox-field input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.checkbox-field label{flex:1;cursor:pointer;font-size:14px;font-weight:600;color:var(--text);margin:0}.checkbox-field label .hint{color:var(--text-muted);font-size:12px;font-weight:500}.checkbox-field.unavailable{background:#f8717114;border-color:#f871714d}.checkbox-field.unavailable label{cursor:not-allowed}.profile-content{gap:12px}.profile-login-prompt{text-align:center;padding:32px 24px}.profile-login-prompt h3{font-size:22px;font-weight:700;color:var(--text);margin-bottom:12px}.profile-login-prompt .muted{font-size:14px;color:var(--text-muted);margin-bottom:20px}.profile-header-card{padding:20px}.profile-avatar-section{display:flex;align-items:center;gap:16px}.profile-avatar-large{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--primary);flex-shrink:0}.profile-avatar-large.profile-avatar-initials{display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--primary);font-size:24px;font-weight:700}.profile-identity{display:flex;flex-direction:column;gap:4px}.profile-display-name{font-size:20px;font-weight:700;color:var(--text);margin:0}.profile-username{font-size:14px;color:var(--text-muted)}.profile-guest-tag{display:inline-block;padding:2px 8px;background:#facc1526;border:1px solid var(--primary);border-radius:4px;font-size:11px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;width:fit-content}.profile-section{padding:16px}.profile-section-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.profile-rank-display{display:flex;align-items:center;gap:12px;margin-bottom:16px}.profile-tier-icon{width:48px;height:48px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.profile-rank-text{font-size:18px;font-weight:700;color:var(--primary)}.profile-progress-container{width:100%}.profile-progress-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-bottom:6px}.profile-progress-bar{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.profile-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.profile-progress-fill.bronze{background:linear-gradient(90deg,#cd7f32,#b87333)}.profile-progress-fill.silver{background:linear-gradient(90deg,silver,#a8a8a8)}.profile-progress-fill.gold{background:linear-gradient(90deg,gold,#daa520)}.profile-progress-fill.platinum{background:linear-gradient(90deg,#e5e4e2,#b8b8b8)}.profile-progress-fill.diamond{background:linear-gradient(90deg,#b9f2ff,#7be0f5)}.profile-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.profile-stat-card{background:var(--bg);border-radius:var(--radius-sm);padding:16px;display:flex;flex-direction:column;align-items:center;gap:4px}.profile-stat-value{font-size:24px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:4px}.profile-stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.profile-stat-sublabel{font-size:11px;color:var(--text-muted);margin-top:2px}.profile-stat-streak .streak-icon{font-size:20px}.profile-badges-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.profile-badge{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.profile-badge.common{border-color:#6b7280}.profile-badge.rare{border-color:#3b82f6}.profile-badge.epic{border-color:#a855f7}.profile-badge.legendary{border-color:#f59e0b;background:#f59e0b1a}.profile-badge-icon{width:40px;height:40px;object-fit:contain}.profile-badge-name{font-size:11px;font-weight:600;color:var(--text);text-align:center;line-height:1.2}.profile-actions{display:flex;flex-direction:column;gap:12px;margin-top:4px}button.auth-user-info{cursor:pointer;transition:transform .2s,background-color .2s}button.auth-user-info:active{transform:scale(.98);background:#1a1a1ae6}.auth-avatar-initials{display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--primary);font-size:16px;font-weight:700;width:44px;height:44px;border-radius:50%;border:2px solid var(--primary)}.auth-arrow{color:var(--text-muted);display:flex;align-items:center}
