@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box}body{font-family:Inter,sans-serif}.hub-layout{position:fixed;top:0;right:0;bottom:0;left:0;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);display:grid;grid-template-columns:260px 1fr;background:#070e1b;color:#e2e8f0;overflow:hidden;touch-action:manipulation}.hub-sidebar{display:flex;flex-direction:column;gap:0;background:#0f172af5;border-right:1px solid #1e293b;overflow-y:auto;overflow-x:hidden;padding:0}.hub-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid #1e293b}.hub-brand-icon{font-size:1.5rem}.hub-brand-name{font-size:1.1rem;font-weight:800;background:linear-gradient(90deg,#f59e0b,#ef4444);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hub-profile-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid #0f172a;background:#f59e0b0a}.hub-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#f59e0b,#ef4444);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:#fff}.hub-profile-info{flex:1;min-width:0}.hub-username{font-weight:700;font-size:.95rem;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hub-wins-row{margin-top:2px}.hub-wins-badge{font-size:.75rem;color:#f59e0b;font-weight:600}.hub-game-wins{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.hub-mini-badge{font-size:.68rem;font-weight:700;padding:1px 6px;border-radius:4px;border:1px solid}.hub-mini-badge.slingshot{background:#ef444418;border-color:#ef4444;color:#fca5a5}.hub-mini-badge.cards{background:#3b82f618;border-color:#3b82f6;color:#93c5fd}.hub-mini-badge.mafia{background:#8b5cf618;border-color:#8b5cf6;color:#c4b5fd}.hub-nav{display:flex;flex-direction:column;gap:4px;padding:.75rem .75rem 0}.hub-nav-btn{width:100%;text-align:left;padding:.55rem .75rem;border-radius:10px;background:transparent;border:1px solid transparent;color:#94a3b8;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s}.hub-nav-btn:hover{background:#1e293bcc;border-color:#334155;color:#e2e8f0}.hub-nav-btn.danger:hover{background:#ef444414;border-color:#ef4444;color:#fca5a5}.hub-solo-section{padding:.75rem .75rem 1rem;margin-top:.25rem}.hub-section-label{font-size:.68rem;font-weight:700;color:#334155;letter-spacing:.1em;padding:0 .25rem .5rem}.hub-solo-card{display:flex;align-items:center;gap:.75rem;padding:.7rem .75rem;border-radius:12px;margin-bottom:6px;background:#0f172a99;border:1px solid #1e293b;cursor:pointer;transition:all .2s}.hub-solo-card:hover{background:#1e293be6;border-color:#334155;transform:translate(3px)}.hub-solo-emoji{font-size:1.3rem;flex-shrink:0}.hub-solo-name{font-size:.88rem;font-weight:700;color:#e2e8f0}.hub-solo-desc{font-size:.72rem;color:#64748b;margin-top:1px}.hub-main{position:relative;overflow-y:auto;overflow-x:hidden;padding:1.75rem 2rem 2rem;background:radial-gradient(ellipse at 70% 0%,rgba(245,158,11,.06) 0%,transparent 60%),radial-gradient(ellipse at 0% 100%,rgba(59,130,246,.05) 0%,transparent 50%),#070e1b}.hub-rooms-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.hub-rooms-title{margin:0 0 .25rem;font-size:1.4rem;font-weight:800;color:#e2e8f0}.hub-rooms-subtitle{margin:0;font-size:.85rem;color:#64748b}.hub-create-btn{padding:.65rem 1.25rem;border:none;border-radius:12px;white-space:nowrap;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #f59e0b40}.hub-create-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 20px #f59e0b59}.hub-create-btn.large{padding:.75rem 2rem;font-size:1rem}.hub-error{background:#ef44441f;border:1px solid #ef4444;color:#fca5a5;border-radius:10px;padding:.65rem 1rem;font-size:.88rem;margin-bottom:1rem}.hub-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;gap:.75rem;border:1px dashed #1e293b;border-radius:20px;background:#0f172a66}.hub-empty-icon{font-size:3.5rem}.hub-empty-title{font-size:1.1rem;font-weight:700;color:#e2e8f0}.hub-empty-sub{font-size:.88rem;color:#64748b;max-width:300px}.hub-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.hub-room-card{background:#0f172ad9;border:1px solid #1e293b;border-radius:16px;padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.65rem;transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hub-room-card:hover:not(.full){border-color:#334155;transform:translateY(-2px);box-shadow:0 8px 30px #0006}.hub-room-card.full{opacity:.65}.hub-room-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.hub-room-name{font-size:1rem;font-weight:700;color:#e2e8f0}.hub-lock{font-size:.8rem}.hub-room-status{font-size:.72rem;font-weight:700;white-space:nowrap}.hub-room-members{display:flex;flex-direction:column;gap:2px}.hub-room-count{font-size:.8rem;color:#94a3b8;font-weight:600}.hub-room-names{font-size:.72rem;color:#475569}.hub-room-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.25rem}.hub-room-id{font-size:.7rem;color:#334155;font-family:monospace}.hub-join-btn{padding:.4rem 1rem;border:none;border-radius:8px;font-size:.82rem;font-weight:700;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;transition:all .2s;white-space:nowrap}.hub-join-btn:hover:not(.disabled):not(:disabled){filter:brightness(1.1)}.hub-join-btn.disabled,.hub-join-btn:disabled{background:#334155;color:#64748b;cursor:not-allowed}.hub-pass-row{display:flex;gap:6px;flex:1;min-width:0;align-items:center}.hub-pass-input{padding:.35rem .6rem;border:1px solid #334155;border-radius:7px;background:#0f172a;color:#e2e8f0;font-size:.82rem;width:90px;min-width:0;flex:1 1 72px;max-width:160px}.hub-pass-input:focus{outline:none;border-color:#f59e0b}.hub-create-panel{max-width:520px}.hub-create-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.hub-back-btn{padding:.45rem .85rem;border:1px solid #334155;border-radius:8px;background:transparent;color:#94a3b8;font-size:.88rem;cursor:pointer;transition:all .15s}.hub-back-btn:hover{background:#1e293b;color:#e2e8f0}.game-header{position:absolute;top:env(safe-area-inset-top,10px);left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:0 10px;pointer-events:none;z-index:1010}.game-header>*{pointer-events:auto}.hub-create-form{display:flex;flex-direction:column;gap:1.1rem}.hub-form-row{display:flex;gap:1rem;flex-wrap:wrap}.hub-form-row .hub-form-group{flex:1 1 200px;min-width:0}.hub-form-group{display:flex;flex-direction:column;gap:.4rem}.hub-label{font-size:.82rem;font-weight:700;color:#94a3b8;letter-spacing:.04em}.hub-input{padding:.7rem .9rem;border:1px solid #334155;border-radius:10px;background:#0f172acc;color:#e2e8f0;font-size:.95rem;transition:border-color .15s}.hub-input:focus{outline:none;border-color:#f59e0b}.hub-create-note{font-size:.8rem;color:#475569;padding:.65rem .85rem;background:#f59e0b0d;border:1px solid rgba(245,158,11,.15);border-radius:8px;margin:0}.hub-form-actions{display:flex;gap:.75rem;margin-top:.25rem}.hub-cancel-btn{flex:1;padding:.75rem;border:1px solid #334155;border-radius:10px;background:transparent;color:#64748b;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.hub-cancel-btn:hover{background:#1e293b;color:#e2e8f0;border-color:#475569}.hub-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;animation:hub-fade-in .2s ease-out}@keyframes hub-fade-in{0%{opacity:0}to{opacity:1}}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 20% 50%,rgba(245,158,11,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(239,68,68,.1) 0%,transparent 45%),#070e1b;overflow:hidden}.auth-glow{position:absolute;width:600px;height:600px;background:radial-gradient(ellipse,rgba(245,158,11,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none;animation:glow-float 6s ease-in-out infinite}@keyframes glow-float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.auth-card{position:relative;z-index:1;background:#0f172ae6;border:1px solid #1e293b;border-radius:24px;padding:2.5rem;width:100%;max-width:400px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 30px 80px #0009,0 0 0 1px #ffffff0a}.auth-logo{text-align:center;font-size:3rem;margin-bottom:.5rem}.auth-title{text-align:center;font-size:1.75rem;font-weight:800;margin:0 0 .25rem;background:linear-gradient(90deg,#f59e0b,#ef4444);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.auth-subtitle{text-align:center;color:#64748b;font-size:.88rem;margin:0 0 1.5rem}.auth-tabs{display:flex;border:1px solid #1e293b;border-radius:12px;overflow:hidden;margin-bottom:1.5rem}.auth-tab{flex:1;padding:.6rem;background:transparent;border:none;color:#64748b;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.auth-tab.active{background:#f59e0b1f;color:#f59e0b}.auth-tab:not(.active):hover{background:#1e293b80;color:#94a3b8}.auth-form{display:flex;flex-direction:column;gap:.85rem}.auth-error{background:#ef44441f;border:1px solid #ef4444;color:#fca5a5;border-radius:8px;padding:.6rem .85rem;font-size:.85rem}.auth-input{padding:.75rem 1rem;border:1px solid #334155;border-radius:12px;background:#0f172acc;color:#e2e8f0;font-size:1rem;transition:border-color .2s}.auth-input:focus{outline:none;border-color:#f59e0b}.auth-input::placeholder{color:#475569}.auth-submit{padding:.85rem;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;margin-top:.25rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;transition:all .2s;box-shadow:0 4px 20px #f59e0b4d}.auth-submit:hover{filter:brightness(1.1);transform:translateY(-1px)}.room-lobby-root{position:fixed;top:0;right:0;bottom:0;left:0;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);display:grid;grid-template-rows:60px 1fr;grid-template-columns:240px 1fr;background:radial-gradient(ellipse at 80% 0%,rgba(245,158,11,.07) 0%,transparent 50%),#070e1b;font-family:Inter,sans-serif;color:#e2e8f0;overflow:hidden}.room-lobby-topbar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 1.5rem;background:#0f172af5;border-bottom:1px solid #1e293b}.room-topbar-left{display:flex;align-items:center;gap:1rem}.room-topbar-center{display:flex;flex-direction:column;align-items:center;gap:1px;flex:1}.room-topbar-name{font-size:1.05rem;font-weight:800;color:#e2e8f0}.room-topbar-id{font-size:.7rem;color:#475569;font-family:monospace}.room-leave-btn{padding:.35rem .75rem;border:1px solid #334155;border-radius:8px;background:transparent;color:#64748b;font-size:.82rem;cursor:pointer;transition:all .15s}.room-leave-btn:hover{background:#ef44441a;border-color:#ef4444;color:#fca5a5}.room-copy-btn{padding:.35rem .85rem;border:none;border-radius:8px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.room-copy-btn.copied{background:#22c55e}.room-copy-btn:hover{filter:brightness(1.1)}.room-lobby-sidebar{background:#0f172af5;border-right:1px solid #1e293b;overflow-y:auto;padding:1rem}.room-members-title{font-size:.7rem;font-weight:700;color:#334155;letter-spacing:.1em;margin:0 0 .75rem;padding:0 .25rem}.room-member-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem .7rem;margin-bottom:5px;border-radius:10px;border:1px solid #1e293b;background:#0f172a99;transition:all .15s}.room-member-row.me{background:#f59e0b14;border-color:#f59e0b33}.room-member-name{font-size:.88rem;font-weight:500;color:#e2e8f0}.room-member-name.me{font-weight:700;color:#fbbf24}.room-member-badges{display:flex;gap:4px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.room-badge{font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:4px;border:1px solid}.room-badge.playing{background:#22c55e18;border-color:#22c55e;color:#86efac}.room-badge.queued{background:#f59e0b18;border-color:#f59e0b;color:#fcd34d}.room-badge.watching{color:#475569;font-size:.6rem;border-color:transparent;background:transparent}.room-host-btn{font-size:.65rem;padding:1px 5px;border-radius:4px;cursor:pointer;background:#f59e0b1a;border:1px solid rgba(245,158,11,.4);color:#fcd34d}.room-add-btn{font-size:.65rem;padding:1px 5px;border-radius:4px;cursor:pointer;background:#22c55e18;border:1px solid #22c55e;color:#86efac}.room-rem-btn{font-size:.65rem;padding:1px 5px;border-radius:4px;cursor:pointer;background:#ef444418;border:1px solid #ef4444;color:#fca5a5}.room-lobby-main{overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.room-status-toast{background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:.6rem 1.1rem;color:#fcd34d;font-size:.88rem;text-align:center;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.room-phase-panel{background:#0f172ad9;border:1px solid #1e293b;border-radius:18px;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.room-phase-panel.voting{border-color:#f59e0b33}.room-phase-panel.playing{border-color:#22c55e33}.room-waiting-icon{font-size:3rem;text-align:center;margin-bottom:.75rem}.room-waiting-title{font-size:1.25rem;font-weight:800;text-align:center;margin:0 0 .5rem}.room-waiting-sub{text-align:center;color:#64748b;font-size:.88rem;margin:0 0 1.25rem}.room-start-vote-btn{display:block;width:100%;padding:.9rem;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;margin-bottom:.75rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;box-shadow:0 4px 18px #f59e0b40;transition:all .2s}.room-start-vote-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.room-divider{text-align:center;color:#334155;font-size:.8rem;margin:.5rem 0}.room-direct-games{display:flex;gap:8px;flex-wrap:wrap}.room-direct-btn{flex:1;min-width:120px;padding:.55rem .85rem;border-radius:10px;border:1px solid #334155;background:#1e293bb3;color:#e2e8f0;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.room-direct-btn:hover{border-color:#f59e0b;background:#f59e0b14;color:#fcd34d}.room-vote-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.room-vote-title{font-size:1.1rem;font-weight:800;margin:0}.room-vote-timer{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;flex-shrink:0;border:3px solid #f59e0b;background:#f59e0b1f;color:#fcd34d;transition:all .3s}.room-vote-timer.urgent{border-color:#ef4444;background:#ef444426;color:#fca5a5}.room-vote-hint{font-size:.8rem;color:#475569;margin:0 0 1rem}.room-vote-options{display:flex;flex-direction:column;gap:.6rem}.room-vote-option{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;border-radius:12px;border:2px solid #1e293b;background:#0f172a99;color:#e2e8f0;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s}.room-vote-option:hover{border-color:#334155;background:#1e293bcc}.room-vote-option.voted{border-color:#f59e0b;background:#f59e0b1a}.room-vote-option.leading{border-color:#22c55e;background:#22c55e0f}.room-vote-count{background:#334155;color:#e2e8f0;font-weight:800;border-radius:20px;padding:2px 10px;min-width:28px;text-align:center}.room-vote-count.voted{background:#f59e0b;color:#0f172a}.room-force-btns{display:flex;gap:6px;margin-top:.85rem}.room-force-btn{flex:1;padding:.5rem;border-radius:8px;font-size:.78rem;border:1px solid #334155;background:transparent;color:#64748b;cursor:pointer;transition:all .15s}.room-force-btn:hover{border-color:#f59e0b;color:#fcd34d;background:#f59e0b0f}.room-playing-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.room-playing-title{font-size:1.05rem;font-weight:800;color:#86efac;margin:0}.room-winner-badge{font-size:.88rem;color:#fcd34d}.room-playing-section{margin-bottom:.85rem}.room-playing-label{font-size:.7rem;color:#475569;font-weight:700;letter-spacing:.08em;margin-bottom:.4rem}.room-player-chips{display:flex;gap:6px;flex-wrap:wrap}.room-player-chip{padding:.25rem .7rem;border-radius:8px;font-size:.82rem;font-weight:600;background:#22c55e18;border:1px solid #22c55e66;color:#86efac}.room-player-chip.queue{background:#f59e0b18;border-color:#f59e0b66;color:#fcd34d}.room-queue-toggle-btn{display:block;width:100%;padding:.7rem;border-radius:10px;border:none;font-size:.9rem;font-weight:700;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;transition:all .2s;margin-bottom:.75rem}.room-queue-toggle-btn.in-queue{background:#ef444433;color:#fca5a5;border:1px solid #ef4444}.room-action-row{display:flex;gap:8px}.room-leave-game-btn{flex:1;padding:.65rem;border-radius:10px;border:1px solid #ef4444;background:transparent;color:#fca5a5;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .15s}.room-abort-btn{flex:1;padding:.65rem;border-radius:10px;border:1px solid #ef4444;background:#ef444414;color:#ef4444;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .15s}.room-next-round-btn{display:block;width:100%;padding:.75rem;border-radius:10px;border:none;margin-top:.75rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s}.room-spectating-note{margin-top:.75rem;text-align:center;font-size:.82rem;color:#475569}@media (max-width: 850px){.hub-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr;position:relative;overflow:auto}.hub-sidebar{position:relative;max-height:none;height:auto;border-right:none;border-bottom:1px solid #1e293b;z-index:10}.hub-brand{padding:.75rem 1rem;justify-content:center}.hub-profile-card{padding:.6rem 1rem;background:#0f172afa}.hub-nav{flex-direction:row;padding:.5rem;gap:8px;overflow-x:auto;background:#070e1b80;white-space:nowrap}.hub-nav::-webkit-scrollbar{display:none}.hub-nav-btn{flex:0 0 auto;width:auto;padding:.45rem 1rem;background:#1e293b}.hub-nav-sections{display:flex;overflow-x:auto;padding:0 .5rem 1rem;gap:1rem;background:#070e1b4d;-webkit-overflow-scrolling:touch}.hub-nav-sections::-webkit-scrollbar{display:none}.hub-solo-section{flex:0 0 280px;padding:.5rem 0;margin-top:0;border-right:1px solid rgba(255,255,255,.05)}.hub-solo-section:last-child{border-right:none;padding-right:2rem}.hub-section-label{padding-left:.5rem;color:#64748b}.hub-main{padding:1.25rem 1rem;position:relative;background:#070e1b}.hub-create-panel{position:fixed;top:0;right:0;bottom:0;width:90%;max-width:400px;background:#0f172a;z-index:1000;box-shadow:-10px 0 40px #000c;padding:2rem 1.5rem;transform:translate(0);animation:drawer-in .3s ease-out;border-left:1px solid #1e293b}@keyframes drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.hub-create-header{background:#0f172a;position:sticky;top:-2rem;padding-bottom:1rem}.hub-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hub-rooms-header{flex-direction:column;align-items:stretch;gap:.75rem}.hub-rooms-title{font-size:1.2rem}.hub-create-btn{width:100%;text-align:center}.hub-rooms-grid{grid-template-columns:1fr!important;gap:.75rem}.room-lobby-root{grid-template-columns:1fr;grid-template-rows:auto auto 1fr;overflow:auto}.room-lobby-sidebar{max-height:40vh;min-height:0;overflow-y:auto;border-right:none;border-bottom:1px solid #1e293b}.room-lobby-topbar{padding:.75rem 1rem;flex-direction:column;height:auto;gap:.5rem}.room-topbar-center{order:-1}.room-lobby-main{padding:.75rem}.room-phase-panel{padding:1rem}.room-vote-header{flex-wrap:wrap;gap:.5rem}.room-vote-title{font-size:1rem}.ab-config-box{min-width:0;width:95%;padding:1.5rem;border-radius:20px}.ab-grid-options{grid-template-columns:1fr}}@media (max-width: 480px){.auth-card{padding:1.5rem;margin:1rem}.auth-title{font-size:1.5rem}.auth-logo{font-size:2.5rem}}.menu{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(145deg,#0f172a,#1e293b);z-index:10;padding:2rem;overflow-y:auto}.menu-games-grid{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}.menu-game-card{background:#0f172acc;border:1px solid #1e293b;border-radius:14px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.6rem;min-width:160px;text-align:center;transition:border-color .2s,transform .2s}.menu-game-card:hover{border-color:#334155;transform:translateY(-2px)}.menu-game-card h3{margin:0 0 .25rem;font-size:1rem;color:#e2e8f0}.menu-title{font-size:2rem;margin-bottom:.25rem;background:linear-gradient(90deg,#f59e0b,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.menu-sub{color:#94a3b8;margin-bottom:2rem;text-align:center}.menu-buttons{display:flex;flex-direction:column;gap:1rem;min-width:220px}.menu-btn{padding:.9rem 1.5rem;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s,opacity .15s}.menu-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0000004d}.menu-btn:active:not(:disabled){transform:translateY(0)}.menu-btn:disabled{opacity:.5;cursor:not-allowed}.menu-btn.single{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.menu-btn.multi{background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a}.lobby-section{margin:1.5rem 0;padding:1rem 1.25rem;background:#0f172ab3;border-radius:12px;border:1px solid #1e293b;min-width:280px;max-width:360px}.lobby-title{font-size:1rem;margin:0 0 .75rem;color:#e2e8f0}.lobby-name-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.lobby-name-input{flex:1;padding:.45rem .65rem;border:2px solid #334155;border-radius:8px;background:#0f172a;color:#e2e8f0;font-size:.95rem}.lobby-name-input:focus{outline:none;border-color:#f59e0b}.lobby-status{font-size:.8rem}.lobby-status.connected{color:#22c55e}.lobby-status.disconnected{color:#64748b}.lobby-status.error{color:#f87171;font-size:.75rem}.lobby-row-me td{color:#f59e0b;font-weight:600}.lobby-table-wrap{overflow-x:auto}.lobby-table{width:100%;border-collapse:collapse;font-size:.9rem}.lobby-table th,.lobby-table td{padding:.4rem .5rem;text-align:left;border-bottom:1px solid #1e293b}.lobby-table th{color:#94a3b8;font-weight:600}.lobby-table tbody tr:hover td{background:#1e293b80}.lobby-empty{color:#64748b;font-style:italic;padding:.75rem}.back-btn{position:absolute;top:1rem;left:1rem;padding:.4rem .75rem;border:1px solid #475569;border-radius:8px;background:transparent;color:#94a3b8;font-size:.9rem;cursor:pointer}.back-btn:hover{background:#334155;color:#e2e8f0}.intro{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(145deg,#0f172a,#1e293b);z-index:10;padding:2rem}.play-single-btn{padding:.7rem 2rem;border:none;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:filter .15s,transform .15s}.play-single-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.play-single-btn:active{transform:translateY(0)}.intro h1{font-size:1.75rem;margin-bottom:.5rem;background:linear-gradient(90deg,#f59e0b,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.intro p{color:#94a3b8;margin-bottom:1rem;text-align:center}.join-box{display:flex;gap:.5rem;margin-bottom:1rem}.join-box input{padding:.5rem .75rem;border:2px solid #334155;border-radius:8px;background:#1e293b;color:#e2e8f0;font-size:1rem;min-width:160px}.join-box button{padding:.5rem 1rem;border:none;border-radius:8px;background:#f59e0b;color:#0f172a;font-weight:600;cursor:pointer;transition:filter .15s,opacity .15s}.join-box button:hover:not(:disabled){filter:brightness(1.1)}.join-box button:disabled{opacity:.5;cursor:not-allowed}.hint{font-size:.85rem;color:#64748b}.hud{position:fixed;top:0;left:0;right:0;padding:.5rem 1rem;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent);pointer-events:none;font-size:.9rem;z-index:2}canvas{touch-action:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.hud button{pointer-events:auto}.hud-menu-btn{margin-right:.75rem;padding:.25rem .6rem;border:1px solid #475569;border-radius:6px;background:#0f172acc;color:#e2e8f0;font-size:.85rem;cursor:pointer}.hud-menu-btn:hover{background:#334155}.score{color:#22c55e}.turn{color:#e2e8f0}.me{color:#f59e0b;font-weight:600}.mute-btn{margin-left:.5rem;padding:.25rem .55rem;border:1px solid #475569;border-radius:6px;background:#0f172ad9;color:#e5e7eb;font-size:.85rem;cursor:pointer}.mute-btn:hover{background:#334155}.rematch-wrap{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:2;display:flex;gap:.75rem;align-items:center}.rematch-wrap button{padding:.5rem 1.25rem;border:none;border-radius:8px;background:#f59e0b;color:#0f172a;font-weight:600;cursor:pointer;transition:filter .15s}.rematch-wrap button:hover{filter:brightness(1.1)}.rematch-wrap button:active{transform:scale(.98)}.rematch-wrap .rematch-back{background:#475569;color:#e2e8f0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172acc;z-index:20}.hub-main>.overlay{z-index:2000}.overlay-panel{background:#020617;border-radius:12px;padding:1.5rem 2rem;box-shadow:0 16px 40px #00000080;display:flex;flex-direction:column;gap:.75rem;min-width:260px;max-height:80vh;align-items:stretch}.overlay-panel h2{margin:0 0 .5rem;text-align:center}.overlay-panel button{padding:.55rem 1.25rem;border:none;border-radius:8px;background:#f59e0b;color:#0f172a;font-weight:600;cursor:pointer;transition:filter .15s,transform .1s}.overlay-panel button:hover{filter:brightness(1.1)}.overlay-panel button:active{transform:scale(.98)}.overlay-panel button:nth-of-type(2){background:#3b82f6;color:#e2e8f0}.overlay-panel button:nth-of-type(3){background:#475569;color:#e2e8f0}.overlay-scroll{overflow:auto}.board-table{width:100%;border-collapse:collapse;margin:.5rem 0 .75rem;font-size:.85rem}.board-table tr:nth-child(2n) td{background:#0f172a99}.coup-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:radial-gradient(ellipse at 20% 0%,rgba(124,58,237,.12) 0%,transparent 55%),radial-gradient(ellipse at 80% 100%,rgba(6,78,59,.15) 0%,transparent 55%),linear-gradient(160deg,#030b18,#020617,#040c1a);color:#e5e7eb;min-height:100vh;min-height:100dvh}.coup-root--room{padding-top:calc(env(safe-area-inset-top,0px) + 52px);box-sizing:border-box}.coup-root--room .menu-title{margin:0 0 .35rem;padding:0 .75rem;text-align:center;font-size:clamp(1.15rem,4.5vw,1.85rem);line-height:1.2}.coup-root--room .menu-sub{margin:0 auto .65rem;padding:0 .85rem;max-width:28rem;text-align:center;font-size:.82rem;line-height:1.35}.coup-root--room .coup-spectator-banner{margin:0 .75rem .5rem;flex-shrink:0}.coup-root--room .coup-lobby-layout{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;align-items:flex-start;justify-content:flex-start;padding:0 1rem 1rem;width:100%;box-sizing:border-box}.coup-root--room .coup-lobby-panel-wrap{width:100%;max-width:400px;margin:0 auto}.coup-root--room .coup-layout{padding:.5rem 1rem 1rem;gap:.85rem;min-height:0}.coup-root--room .mafia-phase-label--room{margin-top:.15rem!important;margin-bottom:.65rem!important}.coup-root--room .mafia-layout{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;align-self:center;box-sizing:border-box}.coup-layout{flex:1;display:grid;grid-template-columns:minmax(0,4fr) minmax(260px,2fr);gap:1.25rem;padding:4rem 1.5rem 1.5rem}.coup-table{border-radius:18px;overflow:hidden;box-shadow:0 24px 60px #000000d9,0 0 0 1px #ffffff0d,inset 0 0 60px #0e6b2e14;background:#020a16;min-height:420px;position:relative}.coup-side{display:flex;flex-direction:column;gap:1rem}.coup-panel{background:#030b18eb;border-radius:14px;padding:1rem 1.25rem;box-shadow:0 14px 30px #000000b3,0 0 0 1px #ffffff0d;border:1px solid #1e2d45;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.coup-panel h2{margin-top:0;margin-bottom:.6rem;font-size:.95rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.coup-actions{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.5rem}.coup-actions button{flex:1 1 45%;padding:.5rem .6rem;border-radius:9px;border:1px solid rgba(255,255,255,.08);background:#0f172a;color:#e5e7eb;font-size:.82rem;font-weight:600;cursor:pointer;transition:filter .15s,transform .1s,box-shadow .15s;display:flex;align-items:center;gap:.4rem;justify-content:space-between}.coup-actions button span{font-size:.72rem;opacity:.75;font-weight:500}.coup-actions button:hover:not(:disabled){filter:brightness(1.18);transform:translateY(-1px);box-shadow:0 4px 14px #00000080}.coup-actions button:active:not(:disabled){transform:scale(.97)}.coup-actions button:disabled{opacity:.35;cursor:not-allowed}.ca-income{background:linear-gradient(135deg,#065f46,#047857);border-color:#059669!important;color:#a7f3d0!important}.ca-foreign-aid{background:linear-gradient(135deg,#78350f,#92400e);border-color:#d97706!important;color:#fde68a!important}.ca-tax{background:linear-gradient(135deg,#3b0764,#4c1d95);border-color:#7c3aed!important;color:#c4b5fd!important}.ca-steal{background:linear-gradient(135deg,#1e3a8a,#1d4ed8);border-color:#3b82f6!important;color:#bfdbfe!important}.ca-assassinate{background:linear-gradient(135deg,#7f1d1d,#991b1b);border-color:#dc2626!important;color:#fca5a5!important}.ca-exchange{background:linear-gradient(135deg,#064e3b,#065f46);border-color:#059669!important;color:#6ee7b7!important}.ca-coup{background:linear-gradient(135deg,#7c2d12,#9a3412);border-color:#ea580c!important;color:#fed7aa!important}.coup-waiting{color:#64748b;font-size:.9rem;margin:.25rem 0}.coup-your-turn{color:#fbbf24;font-size:.88rem;margin:0 0 .25rem;font-weight:600}.coup-win-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#030712e0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50;animation:coup-win-fade .35s ease-out}@keyframes coup-win-fade{0%{opacity:0}to{opacity:1}}.coup-win-panel{text-align:center;background:linear-gradient(160deg,#0c1220,#030b18);border:1px solid rgba(245,158,11,.25);border-radius:22px;padding:2.5rem 3rem;box-shadow:0 40px 90px #000000d9,0 0 0 1px #ffffff0a,0 0 60px #f59e0b1a;display:flex;flex-direction:column;align-items:center;gap:.75rem;min-width:300px;animation:coup-win-scale .4s cubic-bezier(.34,1.56,.64,1)}@keyframes coup-win-scale{0%{transform:scale(.65);opacity:0}to{transform:scale(1);opacity:1}}.coup-win-trophy{font-size:4rem;line-height:1;animation:coup-win-bounce .55s cubic-bezier(.34,1.56,.64,1) .15s both}@keyframes coup-win-bounce{0%{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0)}}.coup-win-title{font-size:2.1rem;font-weight:800;margin:0;background:linear-gradient(135deg,#fde68a,#fbbf24,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.coup-win-sub{color:#94a3b8;font-size:.95rem;margin:0;max-width:240px;line-height:1.4}.coup-win-actions{display:flex;gap:.75rem;margin-top:.5rem;flex-wrap:wrap;justify-content:center}.coup-win-btn-primary{padding:.7rem 1.8rem;border:none;border-radius:12px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#0f172a;font-size:1rem;font-weight:700;cursor:pointer;transition:filter .15s,transform .15s,box-shadow .15s;box-shadow:0 4px 22px #f59e0b73}.coup-win-btn-primary:hover{filter:brightness(1.12);transform:translateY(-2px);box-shadow:0 8px 28px #f59e0b8c}.coup-win-btn-primary:active{transform:scale(.97)}.coup-win-btn-secondary{padding:.7rem 1.5rem;border:1px solid #334155;border-radius:12px;background:#0f172ab3;color:#94a3b8;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.coup-win-btn-secondary:hover{background:#1e293b;color:#e2e8f0;border-color:#475569}.coup-log{max-height:40vh;overflow-y:auto}.coup-log::-webkit-scrollbar{width:4px}.coup-log::-webkit-scrollbar-track{background:transparent}.coup-log::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.coup-log ul{list-style:none;padding-left:0;margin:0;font-size:.82rem;display:flex;flex-direction:column;gap:.1rem}.coup-log li{padding:.3rem .5rem;border-radius:6px;border-left:2px solid #1e3a5f;color:#94a3b8;background:#0f172a66}.coup-log li:first-child{border-left-color:#f59e0b;color:#e2e8f0;background:#f59e0b14}.coup-winner{margin-top:.5rem;font-size:1.05rem;font-weight:700;padding:.6rem .8rem;border-radius:10px;background:#22c55e1a;border:1px solid rgba(34,197,94,.35);color:#4ade80;text-align:center}.coup-phase{margin-bottom:.5rem}.coup-phase p{margin:0 0 .5rem}.coup-exchange{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.coup-exchange-card{padding:.55rem .9rem;border-radius:10px;border:2px solid #334155;background:linear-gradient(135deg,#0f172a,#1e293b);color:#e5e7eb;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,transform .1s}.coup-exchange-card:hover{background:linear-gradient(135deg,#1e293b,#293548);border-color:#475569;transform:translateY(-1px)}.coup-exchange-card.selected{border-color:#22c55e;background:linear-gradient(135deg,#14532d,#166534);color:#86efac;box-shadow:0 0 12px #22c55e4d}.coup-hint{font-size:.8rem;color:#94a3b8;margin-top:.25rem}.coup-lobby-layout{display:flex;align-items:center;justify-content:center}.coup-lobby-panel-wrap{max-width:360px}.coup-lobby-panel h2{margin-top:0}.coup-connected{color:#22c55e;font-size:.9rem}.coup-disconnected{color:#64748b;font-size:.9rem}.coup-players-list{list-style:none;padding:0;margin:.75rem 0;display:flex;flex-direction:column;gap:.35rem}.coup-players-list li{padding:.45rem .75rem;border-radius:8px;border:1px solid #1e293b;background:#0f172a80;font-size:.9rem;color:#cbd5e1;display:flex;align-items:center;gap:.5rem}.coup-mycards-panel{margin-top:0}.coup-panel-toggle-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:0;padding-bottom:0;border-bottom:1px solid #1e293b;padding-bottom:.5rem;margin-bottom:.1rem}.coup-panel-toggle-header h2{margin:0!important}.coup-toggle-icon{color:#64748b;font-size:.78rem;font-weight:700;letter-spacing:.04em;flex-shrink:0}.coup-panel-toggle-header:hover .coup-toggle-icon{color:#94a3b8}.coup-mycards-list{display:flex;flex-direction:column;gap:.4rem;margin-top:.55rem}.coup-mycard-item{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:9px;border:1px solid #1e293b;border-left:3px solid #3b82f6;background:#0f172a8c;transition:background .15s}.coup-mycard-item.dead{opacity:.45;border-left-color:#374151!important;background:#080c168c}.coup-mycard-icon{font-size:1.05rem;line-height:1;flex-shrink:0}.coup-mycard-role{font-weight:800;font-size:.88rem;letter-spacing:.08em;text-transform:uppercase;flex:1}.coup-mycard-status{font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:5px;background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3);letter-spacing:.05em;flex-shrink:0}.coup-mycard-status.dead{background:#ef44441a;color:#f87171;border-color:#ef444440}.coup-target-prompt{font-size:.92rem;font-weight:700;color:#fbbf24;margin:0 0 .5rem}.coup-target-list{flex-direction:column!important;gap:.4rem!important}.ca-target{display:flex;justify-content:space-between;align-items:center;padding:.55rem 1rem!important;font-size:.88rem;border-radius:10px!important;cursor:pointer;transition:filter .15s,transform .1s;border:2px solid transparent!important}.ca-target:hover:not(:disabled){filter:brightness(1.2);transform:translate(3px)}.ca-target:disabled{opacity:.35;cursor:not-allowed}.ca-target-steal{background:linear-gradient(135deg,#1e3a8a,#1d4ed8)!important;border-color:#3b82f6!important;color:#bfdbfe!important}.ca-target-assassinate{background:linear-gradient(135deg,#7f1d1d,#991b1b)!important;border-color:#dc2626!important;color:#fca5a5!important}.ca-target-coup{background:linear-gradient(135deg,#7c2d12,#9a3412)!important;border-color:#ea580c!important;color:#fed7aa!important}.ca-target-coins{font-size:.78rem;opacity:.8;font-weight:600}.ca-cancel{background:#1e293bb3!important;border:1.5px solid #334155!important;color:#94a3b8!important;padding:.45rem 1rem!important;border-radius:9px!important;cursor:pointer;font-size:.85rem;transition:background .15s}.ca-cancel:hover{background:#1e293b!important;color:#e2e8f0!important}.ca-challenge{background:linear-gradient(135deg,#92400e,#b45309)!important;border-color:#f59e0b!important;color:#fde68a!important}.ca-pass{background:#1e293bb3!important;border-color:#334155!important;color:#94a3b8!important}.ca-block{background:linear-gradient(135deg,#1e3a5f,#1d4ed8)!important;border-color:#60a5fa!important;color:#bfdbfe!important}.coup-waiting-panel{padding:.1rem 0}.coup-spectator-banner{background:linear-gradient(135deg,#1e3a8a59,#061022d9);border:1.5px solid rgba(99,179,237,.5);border-radius:12px;padding:.65rem 1.2rem;margin:.5rem 0 .75rem;font-size:.9rem;color:#93c5fd;text-align:center;box-shadow:0 0 22px #3b82f633;animation:coup-win-fade .4s ease-out}.coup-spectator-banner-join{background:linear-gradient(135deg,#14532d66,#061022d9);border-color:#34d39980;color:#6ee7b7;box-shadow:0 0 22px #34d3992e}.coup-spectator-watch{padding:.1rem 0}.coup-spectator-live{margin-top:.6rem;background:#080f1e99;border:1px solid #1e293b;border-radius:9px;padding:.5rem .75rem}.coup-spectator-players{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:600}.coup-coins{margin-top:.75rem}.coup-coins-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem;font-size:.85rem}.coup-coins-list li{display:flex;align-items:center;justify-content:space-between;color:#cbd5f5}.coup-coins-list li.me{color:#facc15;font-weight:700}.coup-coins-list span{font-variant-numeric:tabular-nums}.coup-rules-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#0f172ae6,#020617f2);z-index:60}.coup-rules-card{width:min(640px,94vw);max-height:80vh;background:radial-gradient(circle at top left,#1e40af8c,#0f172afa);border-radius:18px;border:1px solid rgba(148,163,184,.45);box-shadow:0 30px 80px #0f172ae6;padding:1.1rem 1.3rem 1.2rem;overflow:hidden;display:flex;flex-direction:column}.coup-rules-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.coup-rules-header h2{font-size:1.1rem;letter-spacing:.08em;text-transform:uppercase;color:#e5e7eb}.coup-rules-close{border:none;border-radius:999px;padding:.1rem .6rem;font-size:.9rem;background:#0f172acc;color:#9ca3af;cursor:pointer}.coup-rules-close:hover{background:#1f2937e6;color:#e5e7eb}.coup-rules-sub{font-size:.82rem;color:#9ca3af;margin-bottom:.6rem}.coup-rules-grid{display:grid;grid-template-columns:1.1fr 1.4fr 1.6fr;gap:.25rem .6rem;font-size:.8rem;color:#e5e7eb;padding:.55rem .1rem .65rem;border-radius:12px;background:radial-gradient(circle at top,#0f172af2,#0f172acc);border:1px solid rgba(30,64,175,.65);overflow-y:auto}.coup-rules-col.head{font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#9ca3af}.coup-rules-col{padding:.05rem 0}.coup-rules-note{margin-top:.55rem;font-size:.75rem;color:#9ca3af}.role.duke{color:#c4b5fd}.role.assassin{color:#fecaca}.role.contessa{color:#f9a8d4}.role.captain{color:#bfdbfe}.role.ambassador{color:#a7f3d0}.coup-rules-table{margin-top:.2rem;background:radial-gradient(circle at top,#0f172af5,#0f172ae6);border-radius:14px;border:1px solid rgba(30,64,175,.8);box-shadow:inset 0 0 0 1px #0f172acc;overflow:hidden}.coup-rules-row{display:grid;grid-template-columns:1.15fr 1.45fr 1.7fr;gap:.4rem;padding:.32rem .9rem;font-size:.8rem;align-items:center;position:relative}.coup-rules-row:nth-child(2n):not(.head){background:radial-gradient(circle at left,#0f172ae6,#0f172ad9)}.coup-rules-row.head{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#9ca3af;background:linear-gradient(90deg,#1e40afb3,#0f172ae6);border-bottom:1px solid rgba(30,64,175,.9)}.coup-rules-row.head div{font-weight:700}.coup-rules-row.basic:first-of-type{margin-top:.05rem}.coup-rules-row.role-duke:before,.coup-rules-row.role-assassin:before,.coup-rules-row.role-ambassador:before,.coup-rules-row.role-captain:before{content:"";position:absolute;left:0;top:0;bottom:0;width:.3rem}.coup-rules-row.role-duke:before{background:linear-gradient(to bottom,#7c3aed,#4c1d95)}.coup-rules-row.role-assassin:before{background:linear-gradient(to bottom,#dc2626,#7f1d1d)}.coup-rules-row.role-ambassador:before{background:linear-gradient(to bottom,#059669,#064e3b)}.coup-rules-row.role-captain:before{background:linear-gradient(to bottom,#2563eb,#1e3a8a)}.ab-center-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:20;pointer-events:none;background:radial-gradient(circle at center,#0f172a66,#020617cc);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ab-waiting-box{background:#0f172aa6;border:1px solid rgba(59,130,246,.3);border-radius:24px;padding:2.5rem 3rem;text-align:center;color:#e2e8f0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 20px 40px #00000080,inset 0 0 20px #3b82f61a;pointer-events:auto}.ab-lobby-box{min-width:320px}.ab-lobby-players{margin:1.5rem 0;display:flex;flex-direction:column;gap:.8rem}.ab-lobby-p-row{display:flex;align-items:center;gap:.8rem;background:#ffffff0d;padding:.6rem 1rem;border-radius:12px}.ab-p-dot{width:10px;height:10px;border-radius:50%}.ab-p-dot.team-0{background:#3b82f6;box-shadow:0 0 8px #3b82f6}.ab-p-dot.team-1{background:#ef4444;box-shadow:0 0 8px #ef4444}.ab-p-name{flex:1;text-align:left;font-weight:500;font-size:.95rem}.ab-p-status{font-size:.8rem;font-weight:700;text-transform:uppercase}.ab-p-status.ready{color:#22c55e}.ab-p-status.not-ready{color:#94a3b8}.ab-ready-btn{width:100%;padding:.8rem;border-radius:12px;border:none;background:#3b82f6;color:#fff;font-weight:700;cursor:pointer;transition:all .2s ease}.ab-ready-btn.is-ready{background:#22c55e}.ab-ready-btn:hover{transform:translateY(-2px);filter:brightness(1.1)}.ab-lobby-hint{margin-top:1rem;color:#94a3b8;font-size:.8rem}.ab-waiting-box h2{margin:.5rem 0;font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ab-waiting-box p{color:#94a3b8;margin:0;font-size:.95rem}.ab-waiting-spinner{font-size:3rem;animation:ab-spin 2s cubic-bezier(.68,-.55,.265,1.55) infinite;filter:drop-shadow(0 0 10px rgba(59,130,246,.5))}@keyframes ab-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ab-build-overlay{position:absolute;right:20px;top:20px;width:250px;background:#0f172a8c;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.25rem;z-index:20;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 12px 40px #00000080,inset 0 0 0 1px #ffffff0d;display:flex;flex-direction:column;gap:.6rem;max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 40px);overflow-y:auto}.ab-build-overlay h3{margin:0 0 .2rem;font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;color:#f8fafc;font-weight:800}.ab-build-hint{font-size:.78rem;color:#64748b;margin:0}.ab-inventory{display:flex;flex-direction:column;gap:.3rem}.ab-inv-btn{background:#0f172acc;border:1.5px solid rgba(148,163,184,.3);border-radius:8px;color:#cbd5e1;font-size:.8rem;padding:.4rem .7rem;cursor:pointer;text-align:left;transition:all .15s}.ab-inv-btn:hover:not(:disabled){border-color:#3b82f6b3;background:#1e3a8a4d;color:#e2e8f0}.ab-inv-btn.sel{border-color:#3b82f6;background:#1e3a8a8c;color:#93c5fd;font-weight:700;box-shadow:0 0 12px #3b82f666}.ab-inv-btn.empty{opacity:.35;cursor:not-allowed}.ab-build-actions{display:flex;gap:.4rem}.ab-undo-btn{flex:1;background:#1f2937cc;border:1px solid rgba(107,114,128,.5);border-radius:8px;color:#9ca3af;font-size:.78rem;padding:.45rem;cursor:pointer}.ab-undo-btn:hover:not(:disabled){color:#e5e7eb;border-color:#9ca3af}.ab-undo-btn:disabled{opacity:.35;cursor:not-allowed}.ab-ready-btn{flex:2;background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:8px;color:#fff;font-size:.82rem;font-weight:700;padding:.45rem;cursor:pointer;transition:all .15s}.ab-ready-btn.done{background:linear-gradient(135deg,#1e3a8a,#1d4ed8);cursor:default}.ab-ready-btn:hover:not(:disabled):not(.done){filter:brightness(1.1)}.ab-placed-count{font-size:.73rem;color:#475569;margin:0}.ab-play-hud{position:absolute;bottom:calc(env(safe-area-inset-bottom,0px) + 10px);left:0;right:0;margin-inline:auto;display:flex;align-items:center;gap:2rem;background:#0f172aa6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:.75rem 1.15rem;z-index:20;box-shadow:0 8px 32px #00000080,inset 0 0 0 1px #ffffff0d;pointer-events:none;width:min(96vw,860px);justify-content:space-between;max-width:calc(100vw - 8px)}.ab-hud-my,.ab-hud-opp{display:flex;flex-direction:column;align-items:center;gap:.15rem}.ab-hud-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600}.ab-hud-count{font-size:1.6rem;font-weight:900;color:#e2e8f0;font-variant-numeric:tabular-nums}.ab-hud-turn{font-size:.88rem;color:#cbd5e1;font-weight:600;text-align:center;min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ab-gameover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,#0f172a99,#020617e6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:30}.ab-gameover-card{background:#0f172abf;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:32px;padding:3rem;text-align:center;box-shadow:0 30px 60px #000c,inset 0 0 0 1px #ffffff0d;max-width:400px}.ab-gameover-trophy{font-size:3.5rem;margin-bottom:.5rem}.ab-gameover-title{font-size:1.8rem;font-weight:900;color:#f1f5f9;margin:0 0 .4rem}.ab-gameover-sub{font-size:.9rem;color:#94a3b8;margin-bottom:1.2rem}.ab-gameover-btns{display:flex;gap:.7rem;justify-content:center}.ab-btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:10px;color:#fff;font-weight:700;font-size:.9rem;padding:.65rem 1.3rem;cursor:pointer}.ab-btn-primary:hover{filter:brightness(1.12)}.ab-btn-secondary{background:#1f2937e6;border:1px solid rgba(148,163,184,.3);border-radius:10px;color:#9ca3af;font-size:.88rem;padding:.65rem 1.1rem;cursor:pointer}.ab-btn-secondary:hover{color:#e2e8f0;border-color:#64748b}@media (max-width: 600px){.hud{flex-direction:column;align-items:flex-start;gap:.25rem}.menu-buttons{min-width:0;width:100%}.overlay-panel{width:90vw;padding:1rem 1.25rem}.coup-layout{grid-template-columns:1fr;grid-template-rows:minmax(300px,1fr) auto;padding:3rem 1rem 1rem}.coup-table{min-height:300px}.coup-side{max-height:50vh;overflow-y:auto}.lobby-section{min-width:0;max-width:100%}.menu{padding:1rem}.menu-title{font-size:1.5rem}.rematch-wrap{flex-direction:column;bottom:1rem;width:90%;left:5%;transform:none}.rematch-wrap button{width:100%}}.ab-wind-bar{position:absolute;top:60px;left:0;right:0;margin-inline:auto;width:220px;padding:8px 15px;background:#0f172ad9;border:1px solid rgba(255,255,255,.1);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;display:flex;flex-direction:column;gap:5px;align-items:center;pointer-events:none}.ab-wind-label{font-size:.72rem;font-weight:800;letter-spacing:.05em;color:#94a3b8;text-transform:uppercase}.ab-wind-track{position:relative;width:100%;height:6px;background:#0006;border-radius:3px;overflow:hidden}.ab-wind-center{position:absolute;left:50%;top:0;width:2px;height:100%;background:#fff3;z-index:2}.ab-wind-fill{position:absolute;height:100%;transition:all .4s ease-out;border-radius:2px}.ab-config-box{background:#0f172ab3;border:1px solid rgba(59,130,246,.4);border-radius:28px;padding:2.5rem;text-align:center;color:#f1f5f9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 25px 50px #0009,inset 0 0 25px #3b82f626;pointer-events:auto;min-width:380px}.ab-config-title{margin:0 0 10px;font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.ab-config-p{color:#94a3b8;font-size:.95rem;margin-bottom:1.5rem}.ab-grid-options{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2rem}.ab-grid-opt{background:#ffffff08;border:2px solid rgba(148,163,184,.15);border-radius:16px;padding:1rem;color:#94a3b8;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s cubic-bezier(.4,0,.2,1)}.ab-grid-opt:hover{background:#3b82f61a;border-color:#3b82f666;color:#e2e8f0}.ab-grid-opt.sel{background:#2563eb26;border-color:#3b82f6;color:#fff;box-shadow:0 0 20px #3b82f64d}.ab-grid-thumb{width:50px;height:50px;background:#0000004d;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:monospace;font-weight:800;color:#3b82f6;border:1px dashed rgba(59,130,246,.3)}.ab-grid-opt.sel .ab-grid-thumb{border-style:solid;background:#3b82f6;color:#fff}.ab-items-voter{display:flex;flex-direction:column;gap:.8rem;margin-bottom:2rem}.ab-item-row{display:flex;align-items:center;justify-content:space-between;background:#ffffff0d;padding:.8rem 1.2rem;border-radius:14px}.ab-item-label{font-weight:600;font-size:.95rem}.ab-item-ctrl{display:flex;align-items:center;gap:1rem}.ab-counter-btn{width:32px;height:32px;border-radius:50%;border:none;background:#334155;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.ab-counter-btn:hover{background:#475569}.ab-item-val{font-family:monospace;font-size:1.2rem;font-weight:800;min-width:25px;text-align:center}.ab-config-status{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:.8rem;font-size:.9rem}.ab-v-row{display:flex;justify-content:space-between;align-items:center}.ab-v-badge{padding:4px 10px;border-radius:8px;background:#334155;color:#94a3b8;font-weight:700}.ab-v-badge.match{background:#16a34a;color:#fff;box-shadow:0 0 10px #16a34a66}.ab-v-table{width:100%;border-collapse:separate;border-spacing:0 4px}.ab-v-head{display:grid;grid-template-columns:2fr 1fr 1fr;padding:.5rem 1rem;font-weight:800;font-size:.75rem;color:#64748b;text-transform:uppercase}.ab-v-data{display:grid;grid-template-columns:2fr 1fr 1fr;padding:.6rem 1rem;background:#0003;border-radius:8px;align-items:center;font-weight:600}.ab-v-type{color:#94a3b8;font-size:.8rem}.ab-v-data .match{color:#22c55e}.ab-config-hint{font-size:.8rem;color:#f59e0b;font-weight:600;margin-bottom:.5rem}.presi-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:radial-gradient(circle at center,#1e293b,#0f172a);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#f8fafc;font-family:Outfit,sans-serif}.presi-root.game{justify-content:space-between;padding:1rem}.presi-lobby{background:#1e293bb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:3rem;border-radius:2rem;border:1px solid rgba(255,255,255,.1);text-align:center;width:100%;max-width:450px}.presi-p-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.presi-p-status.ready{color:#22c55e;font-weight:800}.presi-hud-top{width:100%;display:flex;justify-content:center}.presi-opponents{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.presi-opp-box{background:#1e293bcc;border:1px solid rgba(255,255,255,.1);padding:.5rem 1rem;border-radius:12px;display:flex;align-items:center;gap:.75rem;position:relative;transition:all .3s}.presi-opp-box.active{border-color:#3b82f6;box-shadow:0 0 15px #3b82f64d;transform:scale(1.05)}.presi-opp-box.passed{opacity:.5;filter:grayscale(1)}.presi-opp-rank{font-weight:900;color:#fbbf24;font-size:.8rem}.presi-opp-name{font-weight:700;font-size:.9rem}.presi-opp-cards{font-size:.8rem;color:#94a3b8}.presi-turn-beam{position:absolute;bottom:-2px;left:10%;width:80%;height:2px;background:#3b82f6;box-shadow:0 0 8px #3b82f6}.presi-table{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.presi-pile{min-height:180px;display:flex;align-items:center;justify-content:center}.presi-played-cards{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.presi-last-actor{position:absolute;bottom:10%;color:#64748b;font-size:.85rem}.presi-empty-pile{font-size:2rem;color:#ffffff0d;font-weight:900;text-transform:uppercase;letter-spacing:4px}.presi-log{position:absolute;right:2rem;bottom:30%;width:220px;font-size:.8rem;color:#94a3b8;text-align:right;line-height:1.4}.presi-hand-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem;padding-bottom:2rem}.presi-hand{display:flex;margin:0 3rem;flex-wrap:wrap;justify-content:center}.presi-hand .presi-card{margin:0 -.5rem .5rem}.presi-my-turn-label{font-weight:900;letter-spacing:2px;color:#3b82f6;text-shadow:0 0 10px rgba(59,130,246,.5);font-size:1.2rem}.presi-card{width:70px;height:100px;background:#fff;border-radius:8px;border:1px solid #cbd5e1;color:#0f172a;position:relative;cursor:pointer;transition:all .2s;flex-shrink:0;box-shadow:0 4px 6px #0000001a}.presi-card.small{width:50px;height:75px;font-size:.8rem}.presi-card.selected{transform:translateY(-20px);border-color:#3b82f6;border-width:3px;z-index:10}.presi-card.red{color:#ef4444}.presi-card-inner{padding:8px;display:flex;flex-direction:column;align-items:flex-start;height:100%}.presi-card-rank{font-weight:900;font-size:1.2rem;line-height:1}.presi-card-suit{font-size:1.5rem;position:absolute;bottom:8px;right:8px}.presi-my-actions{display:flex;gap:1rem}.presi-btn{padding:.75rem 2rem;border-radius:12px;border:none;font-weight:800;cursor:pointer;transition:all .2s}.presi-btn.play{background:#3b82f6;color:#fff;box-shadow:0 4px 14px #3b82f666}.presi-btn.play:disabled{background:#334155;opacity:.4}.presi-btn.pass{background:#ef4444;color:#fff}.presi-btn.ghost{background:transparent;color:#94a3b8;border:1px solid #334155}.presi-my-rank-tag{position:absolute;top:1.5rem;right:1.5rem;padding:.5rem 1.25rem;border-radius:2rem;font-weight:900;letter-spacing:1px;color:#fff}.presi-my-rank-tag.king{background:linear-gradient(135deg,#fbbf24,#d97706);box-shadow:0 0 20px #fbbf2480}.presi-my-rank-tag.beggar{background:#475569}@media (max-width: 900px){.hub-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.hub-sidebar{height:auto;max-height:35vh;border-right:none;border-bottom:2px solid #1e293b;z-index:1000}.hub-brand{padding:.75rem 1rem}.hub-nav{flex-direction:row;overflow-x:auto;padding:.5rem;gap:8px}.hub-nav-btn{white-space:nowrap;width:auto;padding:.4rem 1rem}.hub-main{padding:1rem}.hub-rooms-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.hub-rooms-title{font-size:1.2rem}.hub-rooms-subtitle{display:none}.hub-create-btn.large{width:auto;padding:.5rem 1rem;font-size:.85rem}.hub-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.overlay-panel{width:92vw!important;padding:1.5rem!important;max-height:85vh}.coup-layout,.mafia-layout,.presi-layout{flex-direction:column!important;overflow-y:auto!important}.coup-side,.mafia-side,.presi-side{width:100%!important;flex:none!important}.coup-table,.mafia-table,.presi-table{height:40vh!important;min-height:300px!important}.ca-actions-grid,.coup-actions,.presi-my-actions{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(130px,1fr))!important;gap:8px!important}.ca-actions-grid button,.coup-actions button,.presi-btn{padding:12px 6px!important;font-size:.85rem!important}.room-lobby-root{grid-template-columns:1fr!important;grid-template-rows:auto auto 1fr!important}.room-lobby-sidebar{width:100%!important;max-height:min(38vh,280px);min-height:0;overflow-y:auto!important;border-right:none!important;border-bottom:1px solid #1e293b;display:flex!important;flex-direction:column}.room-phase-panel{padding:1rem!important}.room-vote-options{grid-template-columns:1fr!important}.ab-build-overlay{width:auto!important;inset:auto 10px 10px 10px!important;transform:none!important;padding:10px!important;border-radius:16px!important}.ab-inventory{justify-content:center;gap:5px}.ab-inv-btn{font-size:10px!important;padding:5px 8px!important;flex:1;text-align:center}.ab-play-hud{padding:8px 12px!important;gap:8px!important;font-size:11px!important;bottom:calc(env(safe-area-inset-bottom,0px) + 8px)!important;width:min(96vw,760px)!important;max-width:calc(100vw - 8px)!important}.ab-hud-count{font-size:1.2rem!important}.ab-hud-turn{min-width:0;flex:1}.ab-wind-bar{top:calc(env(safe-area-inset-top,0px) + 62px)!important;width:160px!important;padding:6px 10px!important;border-radius:10px!important}.ab-wind-label{font-size:.65rem!important}.ab-wind-track{height:4px!important}.coup-win-panel,.mafia-win-panel,.ab-gameover-card{width:90vw!important;padding:2rem 1rem!important}.coup-win-title,.mafia-win-title,.ab-gameover-title{font-size:1.5rem!important}.hub-create-modal{max-height:95vh;animation:hub-modal-zoom .25s cubic-bezier(.34,1.56,.64,1)}}@media (max-width: 900px) and (orientation: portrait){.ab-play-hud{width:calc(100vw - 10px)!important;padding:8px 10px!important;gap:6px!important}.ab-hud-label{font-size:.62rem;letter-spacing:.05em}.ab-hud-count{font-size:1.15rem!important}.ab-hud-turn{font-size:.82rem}}@keyframes hub-modal-zoom{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 900px) and (orientation: landscape){.ab-build-overlay{top:calc(env(safe-area-inset-top,0px) + 58px)!important;right:10px!important;left:auto!important;bottom:auto!important;width:min(340px,42vw)!important;max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 74px);border-radius:14px!important;padding:.8rem!important}.ab-inv-btn{font-size:.75rem!important;padding:.35rem .55rem!important}.ab-play-hud{width:min(68vw,760px)!important;bottom:calc(env(safe-area-inset-bottom,0px) + 6px)!important}.ab-hud-label{font-size:.65rem}.ab-hud-count{font-size:1.05rem!important}.ab-hud-turn{font-size:.78rem}.ab-wind-bar{top:calc(env(safe-area-inset-top,0px) + 58px)!important;width:170px!important}.room-lobby-root{grid-template-columns:minmax(140px,32vw) minmax(0,1fr)!important;grid-template-rows:auto minmax(0,1fr)!important;overflow:hidden!important}.room-lobby-topbar{grid-column:1 / -1;flex-direction:row!important;flex-wrap:nowrap;align-items:center;gap:.35rem;padding:.3rem .55rem!important}.room-topbar-left{flex-shrink:0}.room-topbar-center{order:0!important;flex:1;min-width:0;align-items:center}.room-topbar-name{font-size:.88rem!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.room-topbar-id{font-size:.6rem!important}.room-leave-btn{padding:.26rem .45rem!important;font-size:.7rem!important}.room-copy-btn{padding:.26rem .5rem!important;font-size:.7rem!important}.room-lobby-sidebar{grid-column:1;grid-row:2;max-height:none!important;min-height:0;align-self:stretch;overflow-y:auto!important;-webkit-overflow-scrolling:touch;border-right:1px solid #1e293b!important;border-bottom:none!important;padding:.4rem .5rem!important}.room-lobby-main{grid-column:2;grid-row:2;min-height:0;overflow-y:auto!important;-webkit-overflow-scrolling:touch;padding:.4rem .6rem!important;gap:.45rem!important}.room-members-title{margin-bottom:.28rem!important;font-size:.58rem!important}.room-member-row{padding:.26rem .38rem!important;margin-bottom:3px!important}.room-member-name{font-size:.76rem!important}.room-phase-panel{padding:.6rem .7rem!important;border-radius:12px!important}.room-waiting-icon{font-size:1.5rem!important;margin-bottom:.2rem!important}.room-waiting-title{font-size:.92rem!important;margin-bottom:.15rem!important}.room-waiting-sub{font-size:.7rem!important;margin-bottom:.45rem!important;line-height:1.35}.room-start-vote-btn{padding:.48rem .55rem!important;font-size:.8rem!important;margin-bottom:.3rem!important}.room-divider{margin:.3rem 0!important;font-size:.68rem!important}.room-direct-games{gap:4px!important}.room-direct-btn{min-width:0!important;flex:1 1 calc(50% - 3px)!important;padding:.35rem .45rem!important;font-size:.72rem!important}.room-vote-header{margin-bottom:.45rem!important}.room-vote-title{font-size:.88rem!important}.room-vote-option{padding:.5rem .6rem!important;font-size:.78rem!important}.room-vote-timer{width:44px!important;height:44px!important;font-size:1rem!important}.room-playing-header{margin-bottom:.5rem!important}.room-playing-title{font-size:.85rem!important}.room-queue-toggle-btn{padding:.5rem!important;font-size:.8rem!important;margin-bottom:.45rem!important}}.leaderboard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:max(.75rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(.75rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch}.leaderboard-panel{background:linear-gradient(145deg,#0f172a,#1e293b);border:1px solid #334155;border-radius:20px;padding:1.75rem;width:100%;max-width:560px;max-height:min(90vh,100dvh - 2rem);overflow-y:auto;font-family:Inter,sans-serif;color:#e2e8f0;box-shadow:0 25px 60px #0009}@media (max-width: 480px){.leaderboard-panel{padding:1.1rem;border-radius:16px}.leaderboard-panel h2{font-size:1.15rem!important}}@media (max-height: 580px) and (orientation: landscape){.hub-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr;position:relative;overflow:hidden}.hub-sidebar{position:relative;max-height:none!important;height:auto!important;border-right:none;border-bottom:1px solid #1e293b;z-index:1000;display:flex!important;flex-direction:row!important;flex-wrap:wrap!important;align-items:center!important;justify-content:space-between!important;padding:.25rem .75rem!important;gap:0!important;background:#0f172afa}.hub-brand,.hub-wins-badge,.hub-game-wins{display:none!important}.hub-profile-card{padding:.2rem 0!important;border:none!important;background:transparent!important;flex:0 1 auto!important;order:1;display:flex;align-items:center;gap:.5rem}.hub-avatar{width:24px;height:24px;font-size:.7rem}.hub-username{font-size:.8rem;max-width:120px}.hub-nav{display:flex!important;flex-direction:row!important;padding:0!important;margin:0!important;gap:8px!important;flex:0 1 auto!important;order:2;overflow:visible!important}.hub-nav-btn{font-size:.7rem!important;padding:4px 10px!important;border-radius:6px!important;height:28px!important;width:auto!important;background:#1e293b}.hub-nav-sections{display:flex!important;flex:0 0 100%!important;overflow-x:auto!important;padding:.35rem 0 .5rem!important;border-top:1px solid rgba(255,255,255,.05)!important;gap:.75rem!important;order:3;scrollbar-width:none;-webkit-overflow-scrolling:touch}.hub-nav-sections::-webkit-scrollbar{display:none}.hub-solo-section{display:flex!important;flex:0 0 auto!important;padding:0!important;margin:0!important;border:none!important;flex-direction:row!important;align-items:center!important;gap:.4rem!important}.hub-solo-section:last-child{padding-right:2rem!important}.hub-section-label{font-size:.6rem!important;padding:0 2px!important;color:#64748b!important;white-space:nowrap;letter-spacing:.05em}.hub-solo-card{display:flex!important;flex-direction:row!important;align-items:center!important;padding:.3rem .6rem!important;margin:0!important;border-radius:8px!important;min-width:auto!important;gap:.4rem!important;background:#1e293b99!important;border-color:#ffffff0d!important;transform:none!important}.hub-solo-emoji{font-size:1rem!important}.hub-solo-info{display:block!important}.hub-solo-name{font-size:.75rem!important;white-space:nowrap}.hub-solo-desc{display:none!important}.hub-main{padding:.5rem .75rem!important}.hub-rooms-header{margin-bottom:.4rem!important;flex-direction:row!important;gap:1rem!important;align-items:center!important}.hub-rooms-title{font-size:1rem!important;margin:0!important}.hub-rooms-subtitle{display:none!important}.hub-create-btn{width:auto!important;padding:5px 14px!important;font-size:.75rem!important;border-radius:8px!important;margin:0!important}.hub-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))!important;gap:.6rem!important}.hub-room-card{padding:.75rem!important;border-radius:12px!important}.hub-room-name{font-size:.85rem!important}.hub-room-count{font-size:.75rem!important}.hub-join-btn{padding:4px 12px!important;font-size:.75rem!important}.overlay-panel{padding:1rem!important;max-height:98vh;border-radius:16px!important}.hub-create-modal{width:95vw!important;max-width:600px!important}.hub-create-form{display:grid!important;grid-template-columns:1fr 1fr;gap:.4rem .8rem!important}.hub-form-actions{grid-column:span 2}}@media (max-width: 900px) and (orientation: portrait){.hub-layout{grid-template-columns:1fr!important;grid-template-rows:auto 1fr!important;position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden}.hub-sidebar{display:block!important;max-height:56vh!important;overflow-y:auto!important;border-right:none;border-bottom:1px solid #1e293b;padding-bottom:.65rem;background:#0b1221fa}.hub-brand{padding:.75rem 1rem .65rem!important;justify-content:center}.hub-profile-card{padding:.75rem 1rem!important;margin:0 .75rem .6rem;border:1px solid #1e293b;border-radius:14px;background:#0f172adb!important}.hub-nav{display:grid!important;grid-template-columns:1fr 1fr;gap:.45rem;padding:0 .75rem .75rem!important;overflow:visible!important;white-space:normal!important}.hub-nav-btn{width:100%!important;text-align:center;padding:.55rem .75rem!important;border-radius:10px;background:#1e293bf2}.hub-nav-sections{display:block!important;padding:0 .75rem .5rem!important;overflow:visible!important;background:transparent!important}.hub-solo-section{display:block!important;margin:0 0 .85rem!important;padding:.6rem!important;border:1px solid rgba(148,163,184,.14)!important;border-radius:12px;background:#0f172aa6}.hub-solo-section:last-child{padding-right:.6rem!important}.hub-section-label{display:block;padding:0 .2rem .5rem!important;color:#64748b!important;font-size:.67rem!important;letter-spacing:.08em}.hub-solo-card{margin-bottom:.45rem!important;padding:.7rem .75rem!important;border-radius:12px!important;transform:none!important;min-width:0!important}.hub-solo-card:last-child{margin-bottom:0!important}.hub-solo-info{min-width:0}.hub-solo-name{font-size:.9rem!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hub-solo-desc{display:block!important;font-size:.72rem!important;color:#64748b}.hub-main{padding:.9rem .75rem 1rem!important;overflow-y:auto!important}.hub-rooms-header{flex-direction:column!important;align-items:stretch!important;gap:.7rem!important;margin-bottom:.85rem!important}.hub-rooms-title{font-size:1.25rem!important}.hub-rooms-subtitle{display:block!important;font-size:.8rem}.hub-create-btn{width:100%!important;font-size:1.02rem!important;padding:.72rem 1rem!important;border-radius:13px!important}.hub-empty-state{padding:2.4rem 1rem!important;border-radius:16px}.hub-empty-icon{font-size:2.65rem}.hub-empty-title{font-size:1.2rem}.hub-empty-sub{max-width:100%;font-size:.86rem}.hub-rooms-grid{grid-template-columns:1fr!important;gap:.75rem!important}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{min-height:100vh;min-height:100dvh;background:#0f172a;color:#e2e8f0;font-family:system-ui,sans-serif;overflow:hidden}#root{width:100%;max-width:100vw;height:100vh;height:100dvh}canvas{display:block}
