:root{--bg: #0f1115;--bg-elev: #161a22;--bg-elev2: #1d222c;--line: #262c39;--text: #eef1f5;--text-dim: #98a1b3;--text-mute: #5f6878;--accent: #4ecdc4;--accent-warm: #ffe66d;--danger: #ff6b6b;--good: #34d399;--warn: #fb923c;--shadow: 0 8px 30px rgba(0, 0, 0, .4);color-scheme:dark}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:radial-gradient(ellipse at top,#1a1d28 0%,var(--bg) 60%) fixed;color:var(--text);overflow:hidden}#app{display:flex;flex-direction:column}.connecting{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.2rem;color:var(--text-dim)}.layout{display:flex;flex-direction:column;height:100%;position:relative}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:var(--bg-elev);border-bottom:1px solid var(--line);flex-shrink:0}.app-title{font-size:1.05rem;font-weight:600;letter-spacing:.2px}.header-right{display:flex;gap:12px;align-items:center}.name-input-wrap{display:flex;align-items:center;gap:8px}.name-label{color:var(--text-dim);font-size:.85rem}.name-input{background:var(--bg-elev2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:.95rem;outline:none;min-width:140px}.name-input:focus{border-color:var(--accent)}.main-grid{flex:1;display:grid;grid-template-columns:1fr 320px;min-height:0}@media (max-width: 900px){.main-grid{grid-template-columns:1fr;grid-template-rows:1fr auto}}.participants{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(280px,1fr);gap:12px;padding:12px;overflow:auto;align-content:start}@media (max-width: 900px){.participants{grid-auto-flow:row;grid-auto-columns:unset;grid-template-columns:1fr}}.placeholder{color:var(--text-mute);font-size:.9rem;padding:8px}.participant{--p-color: #4ecdc4;background:var(--bg-elev);border:1px solid var(--line);border-radius:14px;padding:12px;display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:var(--shadow);position:relative;transition:border-color .2s ease,transform .2s ease}.participant.me{border-color:color-mix(in srgb,var(--p-color) 50%,var(--line))}.participant.ready{border-color:var(--good);box-shadow:0 0 0 1px var(--good),var(--shadow)}.participant.disconnected{opacity:.55;filter:grayscale(.4)}.participant-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}.p-dot{width:14px;height:14px;border-radius:50%;background:var(--p-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--p-color) 30%,transparent)}.p-name{font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:6px}.name-badge{font-size:1.1em;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 6px color-mix(in srgb,currentColor 25%,transparent))}.p-status{font-size:.8rem;color:var(--text-dim);padding:3px 8px;background:var(--bg-elev2);border-radius:99px;white-space:nowrap}.participant.ready .p-status{color:#0f1115;background:var(--good);font-weight:600}.my-picks{display:flex;flex-direction:column;gap:8px;min-height:0;flex:1}.pick-summary{color:var(--text-dim);font-size:.85rem}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;overflow-y:auto;padding:2px;min-height:0;flex:1}.tile{position:relative;aspect-ratio:1;background:var(--bg-elev2);border:2px solid transparent;border-radius:10px;padding:6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:transform .12s ease,border-color .12s ease,background .15s ease;color:var(--text);overflow:hidden}.tile:hover:not(:disabled){transform:translateY(-2px);background:#232936}.tile:disabled{opacity:.4;cursor:not-allowed}.tile.picked{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--bg-elev2))}.tile.vetoed{opacity:.25;filter:grayscale(1)}.tile img{max-width:70%;max-height:60%;object-fit:contain;pointer-events:none}.custom-tile-bg{width:70%;height:60%;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:.75rem;font-weight:600;text-align:center;padding:2px}.tile-name{font-size:.7rem;color:var(--text-dim);text-align:center;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-badge{position:absolute;top:4px;right:4px;background:var(--accent);color:#0f1115;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.tile-badge.weighted{background:var(--accent-warm)}.heart-btn{position:absolute;bottom:4px;right:4px;width:24px;height:24px;border-radius:50%;background:var(--bg-elev);color:var(--text-dim);border:1px solid var(--line);font-size:13px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s,transform .15s}.heart-btn:hover:not(:disabled){background:#2a3140;color:#ff8a9a;transform:scale(1.08)}.heart-btn.on{background:#ff4d6d;color:#fff;border-color:#ff4d6d;box-shadow:0 0 10px #ff4d6d99}.heart-btn.on:hover:not(:disabled){background:#f35}.remove-custom{position:absolute;top:4px;left:4px;width:18px;height:18px;border-radius:50%;background:var(--bg-elev);color:var(--text-dim);border:1px solid var(--line);font-size:11px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .1s}.tile:hover .remove-custom{opacity:1}.remove-custom:hover{background:var(--danger);color:#0f1115}.custom-add{display:flex;gap:6px;align-items:stretch}.custom-add textarea{flex:1;background:var(--bg-elev2);border:1px solid var(--line);border-radius:8px;padding:6px 10px;color:var(--text);font-size:.85rem;outline:none;resize:vertical;min-height:32px;max-height:200px;font-family:inherit}.custom-add textarea:focus{border-color:var(--accent)}.custom-add .btn{align-self:stretch}.add-custom-btn{min-width:80px;padding:10px 18px;font-size:1rem;font-weight:600;letter-spacing:.02em}.their-picks{flex:1;overflow-y:auto;min-height:0}.their-pick-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.their-pick{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-elev2);border-radius:8px;font-size:.85rem}.their-pick.weighted{box-shadow:inset 0 0 0 1px #ff4d6d}.their-pick img{width:24px;height:24px;object-fit:contain}.their-color-dot{width:18px;height:18px;border-radius:4px;flex-shrink:0}.their-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.heart-tag{color:#ff4d6d;font-size:.95rem}.p-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.btn{background:var(--bg-elev2);color:var(--text);border:1px solid var(--line);padding:8px 12px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .12s,border-color .12s,transform .1s}.btn:hover:not(:disabled){background:#2a3140;border-color:#3a4356}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.small{padding:6px 10px;font-size:.85rem}.btn.ghost{background:transparent}.btn.primary{background:var(--accent);color:#0f1115;border-color:var(--accent)}.btn.primary:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 90%,white)}.btn.danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn.danger:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 15%,transparent)}.btn.warn{background:transparent;color:var(--warn);border-color:var(--warn)}.btn.warn:hover:not(:disabled){background:color-mix(in srgb,var(--warn) 15%,transparent)}.ready-btn{flex:1;min-width:100px}.ready-btn.on{background:var(--good);color:#0f1115;border-color:var(--good)}.sidebar{background:var(--bg-elev);border-left:1px solid var(--line);padding:16px;display:flex;flex-direction:column;min-height:0;overflow-y:auto}@media (max-width: 900px){.sidebar{border-left:none;border-top:1px solid var(--line);max-height:35vh}}.side-h{font-size:.95rem;margin:0 0 10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.side-h-sub{font-size:.8rem;margin:16px 0 6px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.master-list,.vetoed-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.master-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-elev2);border-radius:8px;border:1px solid transparent;transition:border-color .2s,opacity .2s,filter .2s}.master-item.grayed{opacity:.4;filter:grayscale(.9)}.master-item.i-downvoted{border-color:#ff8a4d}.master-item img{width:28px;height:28px;object-fit:contain}.master-color-dot{width:22px;height:22px;border-radius:5px;flex-shrink:0}.master-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem}.master-mult{padding:2px 8px;border-radius:99px;font-size:.75rem;font-weight:700}.master-mult.boost{background:#ff4d6d;color:#fff}.master-mult.cut{background:#5a6478;color:#fff}.downvote-btn{width:26px;height:26px;border-radius:50%;background:var(--bg-elev);color:var(--text-dim);border:1px solid var(--line);font-size:13px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .1s,color .1s,transform .12s}.downvote-btn:hover:not(:disabled){background:#2a3140;color:#ff8a4d;transform:scale(1.08)}.downvote-btn.on{background:#ff8a4d;color:#0f1115;border-color:#ff8a4d;box-shadow:0 0 8px #ff8a4d80}.downvote-btn:disabled{opacity:.4;cursor:not-allowed}.vetoed-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:transparent;color:var(--text-mute);font-size:.85rem}.vetoed-name{flex:0 1 auto;text-decoration:line-through}.vetoed-by{color:var(--text-mute);font-size:.75rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-footer{margin-top:auto;padding-top:12px;font-size:.8rem;color:var(--text-dim);border-top:1px solid var(--line)}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f1115eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:50}.countdown-num{font-size:clamp(120px,20vw,240px);font-weight:800;color:var(--accent-warm);text-shadow:0 0 40px color-mix(in srgb,var(--accent-warm) 60%,transparent);animation:pop 1s ease-in-out infinite}.countdown-sub{color:var(--text-dim);font-size:1.1rem;margin-top:8px}@keyframes pop{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.wheel-overlay{gap:16px;padding:20px}.wheel-stage{width:min(80vmin,560px);aspect-ratio:1;flex-shrink:0}.wheel-canvas{width:100%;height:100%;filter:drop-shadow(0 12px 24px rgba(0,0,0,.5))}.result-panel{background:var(--bg-elev);border:1px solid var(--line);border-radius:16px;padding:20px 28px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;max-width:min(90vw,480px);box-shadow:var(--shadow)}.result-eyebrow{text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim);font-size:.8rem}.result-name{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-warm) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.result-logo{max-width:120px;max-height:80px;object-fit:contain;margin:6px 0}.result-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:10px}.revote-status{width:100%;text-align:center;color:var(--warn);font-size:.9rem;margin-bottom:4px}.revote-waiting{color:var(--text-dim);font-size:.9rem;padding:8px}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%,30px);background:var(--bg-elev);border:1px solid var(--line);border-radius:8px;padding:10px 16px;font-size:.9rem;box-shadow:var(--shadow);opacity:0;transition:opacity .25s,transform .25s;z-index:100;pointer-events:none}.toast-show{opacity:1;transform:translate(-50%)}.toast-error{border-color:var(--danger);color:var(--danger)}.toast-warn{border-color:var(--warn);color:var(--warn)}.toast-info{border-color:var(--accent)}.home-layout{height:100%;overflow-y:auto;padding:32px clamp(16px,4vw,48px);display:flex;flex-direction:column;gap:24px}.home-header{text-align:center}.home-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;letter-spacing:.2px}.home-subtitle{color:var(--text-dim);margin-top:6px;font-size:1rem}.home-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:24px;align-items:start;max-width:1100px;width:100%;margin:0 auto}@media (max-width: 800px){.home-grid{grid-template-columns:1fr}}.home-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:var(--shadow)}.card-h{margin:0 0 16px;font-size:1.05rem;font-weight:600}.create-form{display:flex;flex-direction:column;gap:14px}.form-row{display:flex;flex-direction:column;gap:6px}.form-row-inline{flex-direction:row;align-items:center;gap:10px;cursor:pointer}.form-label{color:var(--text-dim);font-size:.85rem;font-weight:500}.form-label-inline{color:var(--text);font-size:.95rem}.form-hint{color:var(--text-mute);font-size:.8rem;margin-left:4px}.form-input{background:var(--bg-elev2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:1rem;outline:none}.form-input:focus{border-color:var(--accent)}.form-checkbox{width:18px;height:18px;accent-color:var(--accent)}.type-radios{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.type-radio{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;background:var(--bg-elev2);border:2px solid var(--line);border-radius:10px;cursor:pointer;transition:border-color .12s,transform .1s}.type-radio:hover{border-color:#3a4356;transform:translateY(-1px)}.type-radio input{display:none}.type-radio.on{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--bg-elev2))}.type-icon{font-size:1.4rem;line-height:1}.type-label-text{font-size:.85rem;color:var(--text-dim);font-weight:500}.type-radio.on .type-label-text{color:var(--text)}.btn.big{padding:12px 20px;font-size:1.05rem;font-weight:600}.create-btn{margin-top:4px}.list-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}.list-head .card-h{margin:0}.join-form{display:flex;gap:6px;align-items:center}.join-code-input{background:var(--bg-elev2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:.95rem;font-family:ui-monospace,monospace;letter-spacing:.1em;outline:none;width:130px}.join-code-input:focus{border-color:var(--accent)}.room-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.room-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-elev2);border:1px solid transparent;border-radius:10px;transition:border-color .12s,transform .12s}.room-row:hover{border-color:#3a4356;transform:translateY(-1px)}.room-row-icon{font-size:1.6rem;line-height:1;flex-shrink:0}.room-row-main{flex:1;min-width:0}.room-row-title{font-weight:600;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-row-sub{color:var(--text-dim);font-size:.85rem;margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}.room-row-code{font-family:ui-monospace,monospace;letter-spacing:.08em;color:var(--accent);font-weight:600}.sep{color:var(--text-mute)}.header-left{display:flex;align-items:center;gap:12px;min-width:0}.back-btn{flex-shrink:0}.room-title{display:flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap}.room-title-text{font-weight:600;font-size:1.05rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-type-badge{font-size:.75rem;padding:2px 8px;background:var(--bg-elev2);border-radius:99px;color:var(--text-dim);text-transform:capitalize;font-weight:500}.room-code{font-family:ui-monospace,monospace;letter-spacing:.1em;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 10px;border-radius:6px;font-size:.85rem;cursor:pointer;-webkit-user-select:all;user-select:all}.admin-layout{height:100%;overflow-y:auto;display:flex;flex-direction:column}.admin-layout>.app-header{flex-shrink:0}.admin-section{padding:24px clamp(16px,4vw,48px);border-bottom:1px solid var(--line)}.admin-section:last-child{border-bottom:none}.admin-section-h{margin:0 0 16px;font-size:1.05rem;font-weight:600}.admin-section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.admin-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.admin-tab{padding:8px 16px;background:var(--bg-elev2);border:1px solid var(--line);color:var(--text-dim);border-radius:8px;cursor:pointer;font-size:.95rem;transition:background .12s,color .12s,border-color .12s}.admin-tab:hover{color:var(--text)}.admin-tab.on{background:color-mix(in srgb,var(--accent) 15%,var(--bg-elev2));border-color:var(--accent);color:var(--text)}.catalog-tab{display:flex;flex-direction:column;gap:16px}.logo-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:32px 20px;border:2px dashed var(--line);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg-elev2)}.logo-upload:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-elev2))}.upload-icon{font-size:2rem;color:var(--accent)}.upload-text{font-weight:600}.upload-hint{color:var(--text-dim);font-size:.85rem;text-align:center}.admin-logo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.admin-logo-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--bg-elev2);border:1px solid var(--line);border-radius:10px}.admin-logo-card img{max-width:100%;max-height:80px;object-fit:contain}.admin-logo-name{font-weight:500;text-align:center;word-break:break-word}.admin-logo-file{color:var(--text-mute);font-size:.75rem;font-family:ui-monospace,monospace;word-break:break-all;text-align:center}.admin-room-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.admin-room-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-elev2);border:1px solid var(--line);border-radius:10px}.room-row-listed{color:var(--text-mute);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.admin-login{display:flex;align-items:center;justify-content:center;height:100%;padding:32px}.admin-login .home-card{max-width:420px;width:100%}.admin-error{background:color-mix(in srgb,var(--danger) 15%,transparent);border:1px solid var(--danger);color:var(--danger);padding:8px 12px;border-radius:8px;margin-bottom:12px;font-size:.9rem}.admin-shortcut{color:var(--accent-warm);border-color:color-mix(in srgb,var(--accent-warm) 30%,var(--line))}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}*::-webkit-scrollbar-thumb:hover{background:#3a4356}
