@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg-dark: #07070a;--bg-gradient-start: #111118;--bg-gradient-end: #050508;--text-main: #f3f4f6;--text-muted: #9ca3af;--accent-primary: #8b5cf6;--accent-hover: #7c3aed;--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-shadow: 0 4px 30px rgba(0, 0, 0, .3);--grid-line: rgba(255, 255, 255, .05);--cell-bg: rgba(20, 20, 30, .4);--cell-hover: rgba(255, 255, 255, .05);--orb-glow-intensity: .8;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Outfit,system-ui,-apple-system,sans-serif;background:radial-gradient(circle at 50% 0%,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);background-attachment:fixed;color:var(--text-main);height:100dvh;height:100vh;-webkit-tap-highlight-color:transparent;line-height:1.5;overflow:hidden}#root{height:100dvh;height:100vh;display:flex;flex-direction:column;overflow:hidden}h1,h2,h3,h4{font-weight:700;letter-spacing:-.02em}button{cursor:pointer;font-family:Outfit,sans-serif;font-weight:600;font-size:1rem;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:14px 28px;min-height:52px;background:linear-gradient(135deg,#ffffff1a,#ffffff05);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 15px #0003}button:before{content:"";position:absolute;inset:0;background:var(--accent-primary);opacity:0;transition:opacity .3s ease;z-index:-1;border-radius:inherit}button:hover:not(:disabled){transform:translateY(-2px);border-color:#ffffff4d;box-shadow:0 8px 25px #8b5cf640}button:hover:not(:disabled):before{opacity:1}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(100%)}button.primary{background:var(--accent-primary);border:none;box-shadow:0 4px 15px #8b5cf666}button.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 8px 25px #8b5cf699}input,select{font-family:Outfit,sans-serif;font-size:1rem;padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text-main);transition:all .2s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}input:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf633;background:#ffffff0d}.glass-panel{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--glass-shadow);padding:32px;width:100%}.home{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;animation:fadeIn .6s ease-out}.title-container{text-align:center;margin-bottom:40px}.home h1{font-size:clamp(2.5rem,8vw,4rem);font-weight:800;margin:0;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.home .subtitle{color:var(--accent-primary);font-size:clamp(1rem,3vw,1.25rem);font-weight:500;letter-spacing:.1em;text-transform:uppercase;margin-top:8px}.btn-group{display:flex;flex-direction:column;gap:16px;width:100%;max-width:320px}.btn-group button{width:100%}.connection-error{color:#fb7185;background:#fb71851a;border:1px solid rgba(251,113,133,.2);padding:12px 16px;border-radius:var(--radius-sm);font-size:.9rem;text-align:center;max-width:400px;margin-bottom:24px}.connection-status{color:var(--accent-primary);font-size:1rem;font-weight:500;margin-bottom:24px;display:flex;align-items:center;gap:8px}.connection-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent-primary);animation:pulse-ring 1.5s infinite}.connect-hint{color:var(--text-muted);font-size:.9rem;text-align:center;max-width:320px;margin-top:32px}.screen-container{height:100dvh;height:100vh;padding:24px;display:flex;align-items:center;justify-content:center;overflow-y:auto;box-sizing:border-box}.setup-wrapper{max-width:440px;margin:0 auto}.setup-wrapper h2{font-size:2rem;margin-bottom:24px;text-align:center;color:#fff}.setup-wrapper p.desc{text-align:center;color:var(--text-muted);margin-bottom:32px}.setup-row{margin:20px 0;display:flex;flex-direction:column;gap:8px}.setup-row label{color:var(--text-muted);font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.setup-mode label{display:flex;align-items:center;gap:12px;cursor:pointer;color:var(--text-main);text-transform:none;font-size:1rem}.setup-mode input[type=checkbox]{width:24px;height:24px;accent-color:var(--accent-primary)}.player-list{display:flex;flex-direction:column;gap:12px;margin:24px 0}.player-row{display:flex;align-items:center;gap:12px;background:#0003;padding:8px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.05);transition:border-color .2s}.player-row:focus-within{border-color:var(--accent-primary)}.player-row input[type=text]{flex:1;background:transparent;border:none;padding:8px;box-shadow:none!important}.player-row input[type=color]{width:36px;height:36px;padding:0;border:2px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;overflow:hidden}.player-row input[type=color]::-webkit-color-swatch-wrapper{padding:0}.player-row input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}.actions{display:flex;gap:16px;margin-top:32px}.actions button{flex:1}.actions button.secondary{background:transparent}.color-selector{display:flex;gap:10px;flex-wrap:wrap}.color-dot{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .2s ease;box-shadow:0 2px 6px #0000004d}.color-dot:hover:not(.taken){transform:scale(1.15);border-color:#ffffff80}.color-dot.selected{border-color:#fff;box-shadow:0 0 12px currentColor;transform:scale(1.1)}.color-dot.taken{cursor:not-allowed;transform:scale(.85)}.room-code-display{background:#0000004d;border:1px solid var(--accent-primary);border-radius:var(--radius-md);padding:20px;text-align:center;margin-bottom:32px;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(--accent-primary),transparent)}.room-code-label{color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}.room-code-value{font-family:Courier New,monospace;font-size:3rem;letter-spacing:.2em;font-weight:800;color:#fff;text-shadow:0 0 20px rgba(139,92,246,.4)}.lobby-players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:32px}.lobby-player-card{background:#ffffff08;border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px;display:flex;flex-direction:column;align-items:center;gap:8px;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}.lobby-player-card .avatar{width:48px;height:48px;border-radius:50%;border:3px solid rgba(255,255,255,.1);box-shadow:0 4px 10px #0000004d}.lobby-player-card .name{font-weight:600;font-size:.95rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.host-badge{background:#8b5cf633;color:#a5b4fc;font-size:.7rem;padding:2px 6px;border-radius:4px;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.game-board{height:100dvh;height:100vh;max-height:100dvh;display:flex;flex-direction:column;padding:8px max(8px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left));background:var(--bg-dark);overflow:hidden;box-sizing:border-box}.board-top-bar{display:flex;align-items:center;justify-content:space-between;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:8px 16px;margin-bottom:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.turn-indicator{display:flex;align-items:center;gap:12px;font-size:1.1rem;font-weight:600}.turn-swatch{width:16px;height:16px;border-radius:50%;box-shadow:0 0 10px currentColor}.room-code-pill{font-family:Courier New,monospace;font-size:.75rem;font-weight:700;letter-spacing:.15em;color:var(--text-muted);background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px 10px;user-select:all;-webkit-user-select:all;cursor:text;transition:border-color .2s ease,color .2s ease}.room-code-pill:hover{color:#fff;border-color:var(--accent-primary)}.board-canvas{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.player-stats-overlay{position:absolute;right:12px;top:52px;z-index:10;display:flex;flex-direction:column;gap:10px;width:200px;max-height:calc(100% - 64px);overflow-y:auto;background:#0a0a12bf;border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:12px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 32px #00000080;transition:opacity .25s ease,transform .25s ease}.player-stats-overlay.visible{opacity:1;transform:translate(0);pointer-events:auto}.player-stats-overlay.hidden{opacity:0;transform:translate(20px);pointer-events:none}.player-stats-overlay::-webkit-scrollbar{width:4px}.player-stats-overlay::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.score-toggle-btn{position:absolute;right:12px;top:12px;z-index:11;width:32px;height:32px;min-height:unset;padding:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;border-radius:50%;background:#0a0a12b3;border:1px solid var(--glass-border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 10px #0006;transition:all .2s ease}.score-toggle-btn:hover:not(:disabled){transform:scale(1.1);border-color:var(--accent-primary)}.score-toggle-btn:hover:not(:disabled):before{opacity:0}.player-stat-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px;display:flex;flex-direction:column;transition:all .3s ease;position:relative;overflow:hidden}.player-stat-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:currentColor;opacity:.5}.player-stat-card.active{background:#ffffff0f;border-color:#ffffff26;transform:translate(4px);box-shadow:0 4px 15px #0003}.player-stat-card.active:before{opacity:1}.player-stat-card[data-alive=false]{opacity:.4;filter:grayscale(80%)}.player-stat-card[data-alive=false]:after{content:"ELIMINATED";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-15deg);font-weight:800;letter-spacing:.1em;color:#ef444466;font-size:1.2rem;pointer-events:none}.stat-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.stat-header .swatch{width:14px;height:14px;border-radius:50%;box-shadow:0 0 8px currentColor}.stat-header .name{font-weight:700;font-size:1.05rem}.stat-metrics{display:flex;justify-content:space-between}.metric{display:flex;flex-direction:column}.metric-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.1rem;font-weight:600}.board2d-wrapper{display:flex;align-items:center;justify-content:center;position:relative}.board2d-wrapper.rotated,.board2d-wrapper .board-rotate-inner{display:flex;align-items:center;justify-content:center}.board2d-grid{display:grid;gap:0px;background:transparent;padding:0;border:2px solid rgba(255,255,255,.1);border-radius:0;box-shadow:0 10px 40px #00000080;transform:translateZ(0);margin:0 auto;overflow:hidden}.board2d-cell{background:var(--cell-bg);border:1px solid var(--grid-line);border-radius:0;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;overflow:hidden;width:100%;height:100%;outline:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.board2d-cell:active:not(.cell-disabled){background:#ffffff14}.board2d-cell:hover:not(.cell-disabled){background:var(--cell-hover)}.board2d-cell.cell-disabled{cursor:default;pointer-events:none}.cell-orbs{width:100%;height:100%;position:absolute;inset:0;pointer-events:none}.orb{position:absolute;width:var(--orb-size, 40%);height:var(--orb-size, 40%);transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.9),var(--orb-color) 45%,rgba(0,0,0,.5) 100%);box-shadow:0 0 calc(5px * var(--orb-glow-intensity, .8)) var(--orb-color),0 1px 4px #0006,inset -1px -1px 3px #0000004d;z-index:2;will-change:transform}.orb-alive{animation:orb-wobble 2.5s cubic-bezier(.4,0,.2,1) infinite}@keyframes orb-wobble{0%,to{transform:translate(-50%,-50%) scale(1);filter:brightness(1)}25%{transform:translate(-50%,-51%) scale(1.06);filter:brightness(1.08)}50%{transform:translate(-50%,-50%) scale(1.02);filter:brightness(1.04)}75%{transform:translate(-51%,-50%) scale(1.08);filter:brightness(1.1)}}.explosion-orb{animation:orb-explode .45s cubic-bezier(.22,1,.36,1) forwards}@keyframes orb-explode{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(calc(-50% + var(--explode-x, 0)),calc(-50% + var(--explode-y, 0))) scale(.3);opacity:0}}.board2d-cell.cell-critical{animation:critical-glow 1.2s ease-in-out infinite alternate}@keyframes critical-glow{0%{box-shadow:inset 0 0 6px #ff646426}to{box-shadow:inset 0 0 14px #ff646459}}.board2d-cell.cell-exploding{animation:cell-flash .45s cubic-bezier(.22,1,.36,1);z-index:5}@keyframes cell-flash{0%{transform:scale(1.06);background:#ffffff1f}to{transform:scale(1);background:transparent}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-ring{0%{box-shadow:0 0 #8b5cf666}70%{box-shadow:0 0 0 6px #8b5cf600}to{box-shadow:0 0 #8b5cf600}}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.overlay-backdrop{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;animation:fadeIn .3s ease-out}.game-over-modal{text-align:center}.game-over-modal h2{font-size:3rem;margin-bottom:8px;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.winner-avatar{width:80px;height:80px;border-radius:50%;margin:24px auto;border:4px solid rgba(255,255,255,.2);box-shadow:0 0 30px currentColor}.settings-panel{max-width:400px}.settings-panel h2{font-size:1.5rem;margin-bottom:24px;color:#fff}.settings-group{margin-bottom:24px}.settings-group label{display:block;font-size:.9rem;color:var(--text-muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.settings-group input[type=range]{width:100%;accent-color:var(--accent-primary)}.settings-close{margin-top:32px;width:100%}@media(max-width:800px){.player-stats-overlay{right:8px;top:44px;width:160px;padding:8px;gap:8px}.score-toggle-btn{right:8px;top:8px}.player-stat-card{min-width:unset;padding:10px}.board-top-bar{padding:10px 16px;margin-bottom:8px;font-size:.95rem}.board-top-bar button{padding:8px 16px;min-height:38px;font-size:.9rem}}@media(max-width:480px){.game-board{padding:8px}.home h1{font-size:2.5rem}.glass-panel{padding:20px}.setup-wrapper h2{font-size:1.5rem}.room-code-value{font-size:2.2rem}button{padding:12px 20px}.player-stats-overlay{width:140px;padding:6px}.player-stat-card{padding:8px}.stat-header .name{font-size:.85rem}.metric-label{font-size:.65rem}.metric-value{font-size:.9rem}}.explosion-orb{z-index:10;animation:explode-particle .4s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes explode-particle{0%{transform:translate(-50%,-50%) scale(1);opacity:1;filter:brightness(1.5)}to{transform:translate(calc(-50% + var(--explode-x)),calc(-50% + var(--explode-y))) scale(.2);opacity:0;filter:brightness(.5)}}
