@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-orientation-lock{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2200;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));background:#020817f5;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:auto}.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-icon{flex-shrink:0;width:1.35rem;height:1.35rem;display:block}.hub-solo-icon--slingshot{color:#f59e0b;filter:drop-shadow(0 0 6px rgba(245,158,11,.25))}.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-lobby-panel{width:100%;min-width:0}.hub-rooms-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem;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:1.75rem 1.25rem;gap:.45rem;border:1px dashed #1e293b;border-radius:16px;background:#0f172a66}.hub-empty-icon{font-size:2.25rem;line-height:1}.hub-empty-title{font-size:1rem;font-weight:700;color:#e2e8f0}.hub-empty-sub{font-size:.82rem;color:#64748b;max-width:320px;line-height:1.4}.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:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding-top:max(12px,calc(env(safe-area-inset-top,0px) + 8px));padding-bottom:6px;padding-left:max(10px,env(safe-area-inset-left,0px));padding-right:max(10px,env(safe-area-inset-right,0px));pointer-events:none;z-index:1010;flex-wrap:nowrap;box-sizing:border-box}.game-header>*{pointer-events:auto;min-width:0}@media (max-width: 540px){.game-header{flex-wrap:wrap;row-gap:.5rem;padding-left:max(8px,env(safe-area-inset-left,0px));padding-right:max(8px,env(safe-area-inset-right,0px))}.game-header .hub-back-btn,.game-header .hub-join-btn{min-height:44px;touch-action:manipulation;font-size:.8rem}.game-header .hub-back-btn,.game-header .hub-join-btn{flex:1 1 calc(50% - .25rem);padding:.5rem .65rem}}@media (max-width: 400px){.game-header{flex-direction:column;align-items:stretch;row-gap:.45rem}.game-header .hub-back-btn,.game-header .hub-join-btn{flex:none!important;width:100%;max-width:none}}.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-solo-play-hint{max-width:28rem;margin:0 auto 1.15rem;padding:.75rem 1rem;border-radius:12px;border:1px solid rgba(59,130,246,.28);background:#0f172abf;text-align:center}.room-solo-play-hint-title{margin:0 0 .35rem;font-size:.8rem;font-weight:800;color:#93c5fd;letter-spacing:.04em;text-transform:uppercase}.room-solo-play-hint-text{margin:0;font-size:.8rem;line-height:1.45;color:#94a3b8}.room-solo-play-hint-text strong{color:#e2e8f0;font-weight:700}.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}.room-comms-wrapper{position:fixed;left:12px;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);z-index:1100}.room-comms-wrapper.compact{position:relative;left:auto;bottom:auto;width:100%;margin-bottom:.45rem}.room-comms-launcher{position:relative;width:52px;height:52px;border-radius:999px;border:1px solid rgba(148,163,184,.4);background:#0f172adb;color:#e2e8f0;font-size:1.2rem;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 24px #00000073}.room-comms-launcher.open{border-color:#3b82f6;color:#93c5fd}.room-comms-badge{position:absolute;top:-5px;right:-4px;min-width:20px;height:20px;border-radius:999px;background:#ef4444;color:#fff;font-size:.66rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;border:1px solid rgba(2,6,23,.8)}.room-comms-panel{position:fixed;left:12px;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);width:min(360px,40vw);background:#080f1eb8;border:1px solid rgba(148,163,184,.26);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 30px #00000073;z-index:1100;padding:10px;display:flex;flex-direction:column;gap:7px;transform-origin:bottom left;transition:opacity .18s ease,transform .18s ease}.room-comms-panel.compact{position:relative;left:auto;bottom:auto;width:100%;max-width:none;z-index:auto;margin-bottom:.45rem}.room-comms-panel.closed{opacity:0;transform:translateY(8px) scale(.98);pointer-events:none}.room-comms-panel.open,.room-comms-panel.compact{opacity:1;transform:translateY(0) scale(1)}.room-comms-voice-row{display:flex;gap:6px}.room-comms-btn,.room-comms-send{border:1px solid #334155;background:#0f172a;color:#e2e8f0;border-radius:8px;font-size:.75rem;font-weight:700;padding:6px 8px;cursor:pointer}.room-comms-btn.icon-btn{flex:0 0 38px;min-width:38px;padding:6px 0;text-align:center}.room-comms-btn{flex:1}.room-comms-btn.on{border-color:#22c55e;color:#86efac}.room-comms-hide-btn{flex:0 0 auto;min-width:46px}.room-comms-btn.ptt.talking{border-color:#38bdf8;color:#7dd3fc;background:#0e749059}.room-comms-btn:disabled{opacity:.45;cursor:not-allowed}.room-comms-voice-status{font-size:.69rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.room-comms-voice-status.on{color:#22c55e}.room-comms-voice-status.connecting{color:#f59e0b}.room-comms-voice-status.error{color:#ef4444}.room-comms-chat-list{height:130px;overflow-y:auto;border:1px solid rgba(148,163,184,.2);border-radius:9px;background:#02061799;padding:7px;display:flex;flex-direction:column;gap:5px}.room-comms-empty{color:#64748b;font-size:.75rem}.room-comms-msg{font-size:.78rem;color:#dbeafe;display:flex;gap:5px;line-height:1.2}.room-comms-msg.system{font-size:.74rem;color:#94a3b8;font-style:italic;padding:4px 0;border-bottom:1px solid rgba(51,65,85,.5)}.room-comms-msg.system .room-comms-from{color:#64748b;font-style:normal;font-weight:800;text-transform:uppercase;font-size:.62rem;letter-spacing:.06em}.room-comms-msg.mine .room-comms-from{color:#fbbf24}.room-comms-from{color:#93c5fd;font-weight:700;flex-shrink:0}.room-comms-text{color:#e2e8f0;word-break:break-word}.room-comms-input-row{display:flex;gap:6px}.room-comms-input{flex:1;min-width:0;border:1px solid #334155;border-radius:8px;background:#0b1325;color:#f8fafc;padding:7px 8px;font-size:.78rem}.room-comms-input:focus{outline:none;border-color:#3b82f6}@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:row;align-items:center;justify-content:space-between;gap:.65rem;margin-bottom:.75rem}.hub-rooms-title{font-size:1.05rem;margin:0 0 .15rem}.hub-rooms-subtitle{font-size:.78rem;margin:0}.hub-create-btn{width:auto;text-align:center;padding:.45rem .85rem;font-size:.78rem;border-radius:10px;flex-shrink:0}.hub-empty-state{padding:1.25rem .9rem;gap:.35rem;border-radius:14px}.hub-empty-icon{font-size:1.85rem}.hub-empty-title{font-size:.92rem}.hub-empty-sub{font-size:.76rem;max-width:100%}.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%;max-width:100%;padding:1.5rem;border-radius:20px;box-sizing:border-box}.ab-grid-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}}@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}@media (max-width: 540px){.coup-root--room{padding-top:calc(env(safe-area-inset-top,0px) + 66px)}}@media (max-width: 400px){.coup-root--room{padding-top:calc(env(safe-area-inset-top,0px) + 148px)}}.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-root.coup-root--room.mafia-chronicle-root{padding-bottom:calc(env(safe-area-inset-bottom,0px) + 72px);box-sizing:border-box}.mafia-chronicle-root{--mafia-font-display: "Syne", system-ui, sans-serif;--mafia-font-phase-title: "Cormorant", "Crimson Pro", Georgia, "Times New Roman", serif;--mafia-font-story: "Crimson Pro", Georgia, "Times New Roman", serif;--mafia-ink: #e8e4dc;--mafia-mist: rgba(148, 163, 184, .85);--mafia-card: rgba(15, 23, 42, .72);--mafia-card-edge: rgba(251, 191, 36, .22);--mafia-accent: #fbbf24;--mafia-glow: rgba(251, 191, 36, .12);position:relative;background-image:radial-gradient(ellipse 120% 80% at 50% -20%,var(--mafia-glow),transparent 55%),linear-gradient(180deg,#070b14,#0a1020 40%,#070a12);background-attachment:fixed;transition:background .6s ease}.mafia-chronicle-root[data-mafia-sky=night]{--mafia-accent: #c4b5fd;--mafia-card-edge: rgba(167, 139, 250, .28);--mafia-glow: rgba(99, 102, 241, .14);background-image:radial-gradient(ellipse 100% 60% at 50% 0%,rgba(99,102,241,.18),transparent 50%),radial-gradient(ellipse 80% 50% at 80% 100%,rgba(30,27,75,.5),transparent 45%),linear-gradient(180deg,#06060f,#0c0e1a,#070810)}.mafia-chronicle-root[data-mafia-sky=dawn]{--mafia-accent: #fdba74;--mafia-card-edge: rgba(251, 146, 60, .35);--mafia-glow: rgba(251, 146, 60, .12);background-image:radial-gradient(ellipse 90% 55% at 50% -10%,rgba(251,146,60,.15),transparent 50%),linear-gradient(180deg,#0d0a12,#120e18 45%,#080a14)}.mafia-chronicle-root[data-mafia-sky=finale]{--mafia-accent: #f87171;--mafia-card-edge: rgba(248, 113, 113, .3);--mafia-glow: rgba(220, 38, 38, .1);background-image:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(127,29,29,.25),transparent 55%),linear-gradient(180deg,#0a0608,#100a0c)}.mafia-chronicle-root--lobby{--mafia-accent: #d4a574;--mafia-card-edge: rgba(212, 165, 116, .35);--mafia-glow: rgba(212, 165, 116, .1)}.mafia-sky-anim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden;-webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 18%,rgba(0,0,0,.75) 42%,rgba(0,0,0,.2) 68%,transparent 88%);mask-image:linear-gradient(to bottom,#000 0%,#000 18%,rgba(0,0,0,.75) 42%,rgba(0,0,0,.2) 68%,transparent 88%)}.mafia-chronicle-root>*:not(.mafia-sky-anim){position:relative;z-index:1}.mafia-sky-svg{width:100%;height:100%;min-height:260px;display:block}.mafia-sky-layer{transition:opacity 1.85s cubic-bezier(.42,0,.18,1)}.mafia-sky-layer--day,.mafia-sky-layer--dawn,.mafia-sky-layer--night,.mafia-sky-layer--finale,.mafia-sky-layer--lobby{opacity:0}.mafia-chronicle-root[data-mafia-sky=day] .mafia-sky-layer--day,.mafia-chronicle-root[data-mafia-sky=dawn] .mafia-sky-layer--dawn,.mafia-chronicle-root[data-mafia-sky=night] .mafia-sky-layer--night,.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-layer--finale,.mafia-chronicle-root[data-mafia-sky=lobby] .mafia-sky-layer--lobby{opacity:1}.mafia-chronicle-root[data-mafia-sky=lobby] .mafia-sky-layer--day{opacity:.32}.mafia-sky-sun-wrap,.mafia-sky-moon-wrap{transition:transform 1.85s cubic-bezier(.42,0,.18,1),opacity 1.65s ease}.mafia-sky-sun-wrap{transform:translate(580px,92px);opacity:1}.mafia-sky-moon-wrap{transform:translate(768px,86px);opacity:0}.mafia-chronicle-root[data-mafia-sky=day] .mafia-sky-sun-wrap{transform:translate(580px,78px) scale(1);opacity:1}.mafia-chronicle-root[data-mafia-sky=day] .mafia-sky-sun-group{opacity:.82}.mafia-chronicle-root[data-mafia-sky=day] .mafia-sky-moon-wrap{transform:translate(768px,340px) scale(.92);opacity:0}.mafia-chronicle-root[data-mafia-sky=dawn] .mafia-sky-sun-wrap{transform:translate(560px,198px) scale(1.02);opacity:1}.mafia-chronicle-root[data-mafia-sky=dawn] .mafia-sky-moon-wrap{transform:translate(768px,260px) scale(.85);opacity:.25}.mafia-chronicle-root[data-mafia-sky=night] .mafia-sky-sun-wrap{transform:translate(520px,368px) scale(.82);opacity:0}.mafia-chronicle-root[data-mafia-sky=night] .mafia-sky-moon-wrap{transform:translate(748px,72px) scale(1);opacity:1}.mafia-chronicle-root[data-mafia-sky=lobby] .mafia-sky-sun-wrap{transform:translate(600px,208px) scale(1.05);opacity:.92}.mafia-chronicle-root[data-mafia-sky=lobby] .mafia-sky-moon-wrap{transform:translate(820px,300px) scale(.9);opacity:0}.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-sun-wrap{transform:translate(540px,352px) scale(.75);opacity:.12}.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-moon-wrap{transform:translate(720px,108px) scale(1.05);opacity:.55}.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-moon-lit{fill:#fecdd3}.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-moon-shade{fill:#450a0a}.mafia-sky-stars{transition:opacity 1.6s ease;opacity:0}.mafia-chronicle-root[data-mafia-sky=night] .mafia-sky-stars,.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-stars{opacity:.92}.mafia-chronicle-root[data-mafia-sky=dawn] .mafia-sky-stars{opacity:.22}.mafia-chronicle-root[data-mafia-sky=lobby] .mafia-sky-stars{opacity:.15}.mafia-sky-star{transition:opacity .8s ease}.mafia-sky-star--twinkle{animation:mafia-star-twinkle 2.8s ease-in-out infinite}.mafia-chronicle-root[data-mafia-sky=day] .mafia-sky-star--twinkle{animation:none;opacity:0}@keyframes mafia-star-twinkle{0%,to{opacity:.28}50%{opacity:1}}.mafia-sky-sun-rays{transition:opacity 1.4s ease}.mafia-chronicle-root[data-mafia-sky=night] .mafia-sky-sun-rays,.mafia-chronicle-root[data-mafia-sky=finale] .mafia-sky-sun-rays{opacity:0}.mafia-chronicle-root[data-mafia-sky=dawn] .mafia-sky-sun-rays{opacity:.55}.mafia-sky-hills,.mafia-sky-hills-fg{transition:opacity 1.4s ease}@media (prefers-reduced-motion: reduce){.mafia-sky-layer,.mafia-sky-sun-wrap,.mafia-sky-moon-wrap,.mafia-sky-stars{transition-duration:.01ms!important}.mafia-sky-star--twinkle{animation:none!important;opacity:.65}}.mafia-lobby-hero{text-align:center;max-width:34rem;margin:0 auto 1.25rem;padding:0 1rem;animation:mafia-hero-in .7s ease-out both}@keyframes mafia-hero-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mafia-lobby-kicker{display:inline-block;font-family:var(--mafia-font-display);font-size:.68rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--mafia-mist);margin-bottom:.35rem}.mafia-lobby-title{font-family:var(--mafia-font-display);font-weight:800;font-size:clamp(1.55rem,4.5vw,2.15rem);line-height:1.15;margin:0 0 .2rem;color:var(--mafia-ink);text-shadow:0 0 40px var(--mafia-glow)}.mafia-lobby-subtitle{font-family:var(--mafia-font-display);font-size:.9rem;font-weight:600;color:var(--mafia-accent);margin:0 0 .85rem;letter-spacing:.06em}.mafia-lobby-blurb{font-family:var(--mafia-font-story);font-size:1.05rem;line-height:1.55;color:#cbd5e1;margin:0 0 .65rem;font-style:italic}.mafia-lobby-foot{font-family:var(--mafia-font-display);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#64748b;margin:0}.mafia-lobby-you-line{margin:.65rem 0 .5rem;font-size:.88rem;color:#cbd5e1;line-height:1.65;overflow:visible}.mafia-lobby-you-label{font-family:var(--mafia-font-display);font-weight:600;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8;vertical-align:baseline}.mafia-lobby-you-name{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:1rem;font-weight:700;letter-spacing:.01em;line-height:1.35;color:#fbbf24;vertical-align:baseline}.mafia-lobby-you-hint{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:.75rem;color:#64748b;font-weight:500;vertical-align:baseline}.mafia-name-collision{margin:.5rem 0 .75rem;padding:.65rem .75rem;border-radius:10px;border:1px solid rgba(239,68,68,.35);background:#7f1d1d1f}.mafia-name-collision-msg{margin:0 0 .5rem;font-size:.8rem;color:#fecaca;line-height:1.4}.mafia-name-collision-row{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}.mafia-name-collision-input{flex:1 1 140px;min-width:0;padding:.45rem .55rem;border-radius:8px;border:1px solid #334155;background:#0f172a;color:#e2e8f0;font-size:.88rem}.mafia-name-collision-btn{padding:.45rem .75rem!important;font-size:.82rem!important;flex-shrink:0}.mafia-story-header{text-align:center;max-width:40rem;margin:0 auto .85rem;padding:.9rem 1.15rem 1rem;border-radius:14px;background:linear-gradient(165deg,#060a16e0,#0a0f1ec7 45%,#080c18b8);border:1px solid rgba(255,255,255,.1);box-shadow:0 12px 36px #00000073,inset 0 1px #ffffff0f;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:mafia-phase-in .45s ease-out both}@keyframes mafia-phase-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.mafia-phase-pill{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mafia-font-display);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.35rem .85rem;border-radius:999px;border:1px solid var(--mafia-card-edge);background:var(--mafia-card);color:var(--mafia-accent);margin-bottom:.5rem;box-shadow:0 0 24px var(--mafia-glow)}.mafia-story-title{font-family:var(--mafia-font-phase-title);font-weight:700;font-size:clamp(1.55rem,4.2vw,2.05rem);margin:0 0 .4rem;letter-spacing:.04em;line-height:1.15;color:#fefce8;text-transform:none;text-shadow:0 2px 0 rgba(15,23,42,.85),0 0 1px rgba(15,23,42,.95),0 4px 18px rgba(0,0,0,.55)}.mafia-story-lead{font-family:var(--mafia-font-story);font-size:clamp(1rem,2.4vw,1.12rem);font-style:italic;line-height:1.55;color:#e2e8f0;margin:0 0 .45rem;text-shadow:0 1px 3px rgba(15,23,42,.9)}.mafia-story-hint{font-family:var(--mafia-font-display);font-size:.78rem;font-weight:600;color:#e2e8f0eb;line-height:1.45;max-width:36rem;margin:0 auto;text-shadow:0 1px 2px rgba(15,23,42,.85)}@media (min-width: 900px){.mafia-chronicle-root .mafia-phase-pill{font-size:.8rem;letter-spacing:.15em;padding:.42rem 1rem;margin-bottom:.55rem}.mafia-chronicle-root .mafia-story-title{font-size:clamp(1.85rem,2.4vw,2.4rem);line-height:1.18;margin-bottom:.45rem}.mafia-chronicle-root .mafia-story-lead{font-size:1.18rem;line-height:1.58;margin-bottom:.45rem}.mafia-chronicle-root .mafia-story-hint{font-size:.92rem;line-height:1.5;max-width:42rem}.mafia-chronicle-root--lobby .mafia-lobby-title{font-size:clamp(1.85rem,2.5vw,2.35rem)}.mafia-chronicle-root--lobby .mafia-lobby-subtitle{font-size:.98rem}.mafia-chronicle-root--lobby .mafia-lobby-blurb{font-size:1.12rem;line-height:1.58}.mafia-chronicle-root--lobby .mafia-lobby-kicker,.mafia-chronicle-root--lobby .mafia-lobby-foot{font-size:.74rem}.mafia-chronicle-root .mafia-panel-heading{font-size:1.08rem}.mafia-chronicle-root .mafia-chronicle-entry{font-size:1.02rem;line-height:1.55}.mafia-chronicle-root .mafia-chronicle-panel>.coup-hint{font-size:.88rem;line-height:1.45}.mafia-chronicle-root .mafia-role-badge{font-size:.88rem;padding:.28rem .8rem}.mafia-chronicle-root .mafia-player-row-main{font-size:1.02rem}.mafia-chronicle-root .mafia-side--players button{font-size:.84rem!important;padding:.3rem .7rem!important}.mafia-chronicle-root .mafia-coord-head{font-size:.84rem}.mafia-chronicle-root .csp-peer-leave-banner .csp-peer-leave-text,.mafia-chronicle-root .csp-draw-bar-text{font-size:.9rem}}@media (min-width: 1200px){.mafia-chronicle-root .mafia-story-title{font-size:2.45rem}.mafia-chronicle-root .mafia-story-lead{font-size:1.22rem}}.mafia-panel-heading{font-family:var(--mafia-font-display);font-size:.95rem;font-weight:700;letter-spacing:.04em;margin:0;color:var(--mafia-ink)}.mafia-narrator-card{margin:0 1rem .75rem;padding:.85rem 1.1rem;border-radius:14px;border:1px solid var(--mafia-card-edge);background:linear-gradient(135deg,#0f172ad9,#1e1b2e8c);box-shadow:0 12px 40px #00000059}.mafia-narrator-card-label{font-family:var(--mafia-font-display);font-size:.62rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--mafia-accent);opacity:.85;margin-bottom:.35rem}.mafia-narrator-card-text{font-family:var(--mafia-font-story);font-size:.98rem;font-style:italic;line-height:1.5;color:#e2e8f0;margin:0}.mafia-chronicle-scroll{flex:1;min-height:0;overflow-y:auto;padding-right:.25rem;-webkit-overflow-scrolling:touch}.mafia-chronicle-entry{position:relative;padding:.55rem 0 .55rem .85rem;margin:0;border-bottom:1px solid rgba(30,41,59,.9);font-family:var(--mafia-font-story);font-size:.88rem;line-height:1.5;color:#cbd5e1}.mafia-chronicle-entry:before{content:"";position:absolute;left:0;top:.65rem;bottom:.65rem;width:3px;border-radius:2px;background:linear-gradient(180deg,var(--mafia-accent),transparent);opacity:.45}.mafia-chronicle-entry:first-child{padding-top:.35rem}.mafia-chronicle-entry:first-child:before{top:.45rem}.mafia-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#02060eeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;animation:mafia-modal-bg .35s ease-out both}.mafia-modal-backdrop.mafia-modal--portal{z-index:1850;align-items:flex-start;justify-content:center;padding:max(6px,env(safe-area-inset-top,0px)) max(10px,env(safe-area-inset-right,0px)) max(6px,env(safe-area-inset-bottom,0px)) max(10px,env(safe-area-inset-left,0px));overflow-y:auto;-webkit-overflow-scrolling:touch;box-sizing:border-box}.mafia-modal-backdrop.mafia-modal--portal .mafia-modal-panel{--mafia-font-display: "Syne", system-ui, sans-serif;--mafia-font-phase-title: "Cormorant", "Crimson Pro", Georgia, "Times New Roman", serif;--mafia-font-story: "Crimson Pro", Georgia, "Times New Roman", serif;--mafia-modal-ui: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--mafia-accent: #fbbf24;--mafia-card-edge: rgba(251, 191, 36, .22);width:min(28rem,calc(100vw - 20px));max-width:none;margin:max(.5rem,env(safe-area-inset-top,0px)) auto max(.75rem,env(safe-area-inset-bottom,0px));max-height:min(85dvh,calc(100vh - 32px));overflow-y:auto;overscroll-behavior:contain;flex-shrink:0}.mafia-modal-panel--wide{max-width:26.25rem}.mafia-modal-panel--finale{max-width:25rem}.mafia-modal-primary-btn{margin-top:.65rem;width:100%;box-sizing:border-box}.mafia-dawn-backdrop{background:radial-gradient(ellipse 85% 55% at 50% 18%,rgba(251,191,36,.14),transparent 52%),#02060ef0}.mafia-dawn-modal{position:relative;text-align:center;padding-top:2rem;--dawn-accent: #fbbf24;--dawn-accent-soft: rgba(251, 191, 36, .18);--dawn-track: rgba(30, 41, 59, .85);--mafia-dawn-ui: var(--mafia-modal-ui, ui-sans-serif, system-ui, sans-serif)}.mafia-dawn-modal--blood{--dawn-accent: #f87171;--dawn-accent-soft: rgba(248, 113, 113, .2)}.mafia-dawn-modal--mercy{--dawn-accent: #34d399;--dawn-accent-soft: rgba(52, 211, 153, .18)}.mafia-dawn-modal--calm{--dawn-accent: #fcd34d;--dawn-accent-soft: rgba(252, 211, 77, .16)}.mafia-dawn-modal__accent{position:absolute;top:0;left:0;right:0;height:4px;border-radius:18px 18px 0 0;background:linear-gradient(90deg,transparent,var(--dawn-accent),transparent);opacity:.95}.mafia-dawn-eyebrow{font-family:var(--mafia-dawn-ui);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#e2e8f0;margin:0 0 .5rem}.mafia-dawn-modal__title{font-family:var(--mafia-font-phase-title);font-weight:700;font-size:clamp(1.35rem,4vw,1.65rem);letter-spacing:.03em;color:#fefce8!important;text-shadow:0 2px 14px rgba(0,0,0,.45);margin-bottom:.65rem!important}.mafia-dawn-modal__lede{font-size:1.05rem!important;line-height:1.65!important;font-style:normal!important}.mafia-dawn-flavor{margin:.5rem auto 0!important;max-width:24rem;font-family:var(--mafia-font-story)!important;font-size:.95rem!important;line-height:1.55!important;font-style:normal!important;color:#e2e8f0!important}.mafia-dawn-modal__rumor{margin-top:1.1rem!important}.mafia-dawn-ack{margin-top:1.35rem;padding:1rem .85rem;border-radius:12px;background:linear-gradient(165deg,#0f172ae6,#080c18d1);border:1px solid rgba(255,255,255,.08);text-align:left}.mafia-dawn-ack__track{height:8px;border-radius:999px;background:var(--dawn-track);overflow:hidden;box-shadow:inset 0 1px 3px #00000059}.mafia-dawn-ack__fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--dawn-accent-soft),var(--dawn-accent));box-shadow:0 0 12px #fbbf2459;transition:width .45s cubic-bezier(.34,1.1,.64,1)}.mafia-dawn-ack__label{font-family:var(--mafia-dawn-ui);font-size:.84rem;font-weight:500;color:#e2e8f0;margin:.65rem 0 0;line-height:1.5}.mafia-dawn-ack__label strong{color:#f8fafc;font-weight:700}.mafia-dawn-seal-btn{margin-top:1.15rem!important;width:100%;box-sizing:border-box;min-height:3.15rem;padding:.65rem 1.15rem!important;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.12rem;font-family:var(--mafia-dawn-ui)!important;font-weight:700!important;font-size:1.02rem!important;letter-spacing:.01em;border:none!important;border-radius:12px!important;cursor:pointer;color:#0f172a!important;background:linear-gradient(180deg,#fde68a,#fbbf24 48%,#d97706)!important;box-shadow:0 4px #92400e,0 8px 24px #00000059,inset 0 1px #ffffff59;transition:transform .12s ease,filter .12s ease,box-shadow .12s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.mafia-dawn-seal-btn:hover:not(:disabled){filter:brightness(1.04)}.mafia-dawn-seal-btn:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #92400e,0 4px 16px #0000004d,inset 0 1px #ffffff4d}.mafia-dawn-seal-btn:disabled{cursor:not-allowed;opacity:.88;background:linear-gradient(180deg,#475569f2,#334155f2)!important;color:#e2e8f0!important;box-shadow:0 2px #334155,inset 0 1px #ffffff0f}.mafia-dawn-seal-btn__sub{display:block;font-size:.72rem;font-weight:600;letter-spacing:.02em;text-transform:none;opacity:.88;color:inherit}.mafia-dawn-seal-btn:disabled .mafia-dawn-seal-btn__sub{font-size:.72rem;text-transform:none;letter-spacing:.03em;opacity:.9}.mafia-dawn-footnote{font-family:var(--mafia-dawn-ui);font-size:.78rem;line-height:1.5;color:#94a3b8;margin:.75rem 0 0}.mafia-dawn-modal .mafia-rumor-label{font-family:var(--mafia-dawn-ui);font-size:.72rem;font-weight:700;letter-spacing:.06em;color:#cbd5e1}.mafia-dawn-modal .mafia-rumor-body{font-style:normal;font-size:.92rem;line-height:1.55}@keyframes mafia-modal-bg{0%{opacity:0}to{opacity:1}}.mafia-modal-panel{max-width:28rem;width:90vw;text-align:center;padding:1.75rem 1.5rem 1.5rem;border-radius:18px;border:1px solid var(--mafia-card-edge);background:linear-gradient(160deg,#0f172af2,#080c16fa);box-shadow:0 24px 80px #000000a6,0 0 0 1px #ffffff0a inset;animation:mafia-modal-pop .4s cubic-bezier(.34,1.2,.64,1) both}@keyframes mafia-modal-pop{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.mafia-modal-panel h2{font-family:var(--mafia-font-phase-title);font-weight:700;margin-top:0;margin-bottom:.5rem;color:var(--mafia-accent);font-size:1.35rem}.mafia-modal-panel .mafia-modal-prose{font-family:var(--mafia-font-story);font-size:1.08rem;line-height:1.55;color:#e2e8f0;margin:.35rem 0}.mafia-modal-panel .mafia-modal-muted{font-family:var(--mafia-font-display);font-size:.75rem;color:#64748b;margin:.75rem 0 .35rem}.mafia-rumor-block{margin-top:1.25rem;padding:.85rem;border-radius:12px;background:#1e293ba6;border:1px solid rgba(100,116,139,.45);font-size:.88rem;text-align:left}.mafia-rumor-label{display:block;font-family:var(--mafia-modal-ui, ui-sans-serif, system-ui, sans-serif);font-size:.7rem;letter-spacing:.06em;font-weight:700;color:#a8b4c8;margin-bottom:.35rem}.mafia-rumor-body{margin:0;font-family:var(--mafia-font-story);font-style:normal;line-height:1.55;color:#e2e8f0}.mafia-role-reveal{margin:1rem 0 0;font-size:.85rem;text-align:left;font-family:var(--mafia-font-display)}.mafia-finale-actions{display:flex;flex-direction:column;gap:.65rem;margin-top:1.15rem}.mafia-finale-play-again{width:100%;box-sizing:border-box;display:flex!important;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.75rem 1rem!important;min-height:3.1rem;font-family:var(--mafia-modal-ui, ui-sans-serif, system-ui, sans-serif)!important;font-weight:700!important;font-size:1.02rem!important;letter-spacing:.02em;border:none!important;border-radius:12px!important;color:#0f172a!important;background:linear-gradient(180deg,#fde68a,#fbbf24 52%,#d97706)!important;box-shadow:0 3px #92400e,0 8px 22px #00000059,inset 0 1px #ffffff59;touch-action:manipulation}.mafia-finale-play-again:hover{filter:brightness(1.04)}.mafia-finale-play-again:active{transform:translateY(2px);box-shadow:0 1px #92400e,0 4px 14px #00000047}.mafia-finale-play-again__sub{display:block;font-size:.7rem;font-weight:600;opacity:.88;letter-spacing:.01em}.mafia-finale-leave-hub{width:100%;box-sizing:border-box;background:transparent!important;border:1px solid rgba(148,163,184,.45)!important;color:#cbd5e1!important;font-family:var(--mafia-modal-ui, ui-sans-serif, system-ui, sans-serif)!important;font-size:.88rem!important;padding:.55rem .85rem!important;border-radius:10px!important}.mafia-finale-leave-hub:hover{border-color:#e2e8f08c!important;color:#e2e8f0!important}.mafia-finale-exit-btn{width:100%;box-sizing:border-box;background:transparent!important;border:1px solid rgba(100,116,139,.22)!important;color:#475569!important;font-family:var(--mafia-modal-ui, ui-sans-serif, system-ui, sans-serif)!important;font-size:.8rem!important;padding:.45rem .85rem!important;border-radius:10px!important;letter-spacing:.01em}.mafia-finale-exit-btn:hover{border-color:#ef444459!important;color:#ef4444!important;background:#ef44440d!important}.mafia-layout{display:flex;gap:1.25rem;max-width:980px;margin:0 auto;padding:0 clamp(.45rem,2.5vw,1rem);width:100%;box-sizing:border-box;align-items:stretch}.mafia-side--players{flex:2 1 280px;min-width:0;padding:1rem}.mafia-chronicle-panel{flex:1 1 240px;min-width:0;min-height:0;padding:1rem;display:flex;flex-direction:column;max-height:min(52vh,520px)}.mafia-chronicle-panel .mafia-panel-heading{margin:0 0 .5rem}.mafia-chronicle-panel>.coup-hint{margin:0 0 .5rem}.mafia-panel-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem .75rem;margin-bottom:.75rem}.mafia-panel-head-tools{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.45rem .6rem;margin-left:auto}.mafia-role-labels-toggle{flex-shrink:0;font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:.4rem .7rem;border-radius:8px;border:1px solid rgba(148,163,184,.4);background:#0f172abf;color:#cbd5e1;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.mafia-role-labels-toggle:hover{border-color:#fbbf2473;color:#f1f5f9}.mafia-role-labels-toggle[aria-pressed=false]{border-color:#fbbf2459;color:#fbbf24}.mafia-role-labels-toggle--compact{font-size:.68rem;padding:.32rem .55rem}.mafia-role-badge{padding:.25rem .75rem;border-radius:8px;font-size:clamp(.72rem,2.8vw,.85rem);font-weight:700;line-height:1.25;text-align:center;flex-shrink:0;max-width:100%;word-break:break-word}.mafia-player-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.45rem;flex-wrap:wrap}.mafia-player-row-main{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem .6rem;min-width:0;flex:1 1 120px}.mafia-player-row-main>span:last-of-type{word-break:break-word;overflow-wrap:anywhere}.mafia-player-row-actions{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end;flex:0 1 auto}.mafia-coord-head{background:#1e293b;padding:.5rem .8rem;font-size:clamp(.72rem,2.5vw,.8rem);font-weight:700;color:#94a3b8;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.35rem .75rem}.mafia-inline-actions{display:flex;justify-content:center;gap:.5rem;padding:.5rem 1rem 1rem;flex-wrap:wrap;box-sizing:border-box}.coup-root--room .mafia-inline-actions{padding-bottom:max(.85rem,calc(env(safe-area-inset-bottom,0px) + 6px))}@media (max-width: 900px){.mafia-layout{flex-direction:column!important;gap:.85rem!important}.mafia-layout .mafia-side--players,.mafia-layout .mafia-chronicle-panel{flex:none!important;width:100%!important;max-width:100%!important}.mafia-chronicle-panel{max-height:min(38vh,360px)!important}.mafia-player-row-actions{width:100%;justify-content:flex-start}}@media (max-width: 480px){.mafia-story-header{padding:.75rem .65rem .85rem;margin-left:.35rem;margin-right:.35rem;max-width:calc(100% - .7rem)}.mafia-phase-pill{font-size:.58rem;letter-spacing:.1em;padding:.3rem .65rem}.mafia-story-title{font-size:clamp(1.05rem,5.5vw,1.45rem)}.mafia-modal-panel h2{font-size:clamp(1.05rem,4.5vw,1.3rem);line-height:1.2;overflow-wrap:break-word}.mafia-modal-backdrop.mafia-modal--portal .mafia-modal-panel{max-height:min(88dvh,calc(100svh - 20px));padding:1.25rem 1rem 1.1rem}}.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--overlay{max-height:none;overflow:visible}.coup-log-trigger{width:100%;margin-top:.85rem}.coup-log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:flex;align-items:flex-end;justify-content:center;pointer-events:auto}.coup-log-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.coup-log-sheet{position:relative;width:min(520px,calc(100vw - 24px));max-height:76vh;margin:0 12px 12px;border-radius:18px;border:1px solid rgba(255,255,255,.06);background:#030b18f0;box-shadow:0 30px 90px #000000b3;display:flex;flex-direction:column;overflow:hidden}.coup-log-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:.9rem 1rem;border-bottom:1px solid rgba(255,255,255,.06)}.coup-log-sheet-header h2{margin:0;font-size:1.15rem}.coup-log-close{padding:.35rem .55rem;border-radius:10px;border:1px solid rgba(148,163,184,.28);background:#0f172aa6;color:#e2e8f0;font-weight:800;cursor:pointer}.coup-log-sheet-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.85rem 1rem 1rem}@media (min-width: 901px){.coup-log-overlay{align-items:flex-start;justify-content:flex-end}.coup-log-sheet{width:420px;height:calc(100vh - 24px);max-height:none;margin:12px 12px 12px 0;border-radius:18px 0 0 18px}}.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,#0f172aeb,#020617f7);z-index:12000;isolation:isolate;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.coup-rules-card{width:min(640px,94vw);max-height:80vh;background:linear-gradient(145deg,rgba(51,65,85,.35) 0%,transparent 45%),radial-gradient(ellipse 120% 80% at 20% 0%,rgba(59,130,246,.22),transparent 55%),linear-gradient(180deg,#0f172afc,#020617fc);border-radius:20px;border:1px solid rgba(148,163,184,.38);box-shadow:0 0 0 1px #0f172ae6,0 32px 90px #0000008c,inset 0 1px #ffffff0f;padding:1.15rem 1.35rem 1.25rem;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:.35rem;background:linear-gradient(180deg,#0f172a8c,#020617bf);border-radius:14px;border:1px solid rgba(59,130,246,.35);box-shadow:inset 0 0 0 1px #0f172ad9,inset 0 1px #ffffff0a;overflow-y:auto;overflow-x:hidden}@media (max-width: 600px){.coup-rules-overlay{align-items:flex-end;padding-bottom:env(safe-area-inset-bottom,0px)}.coup-rules-card{width:min(94vw,520px);max-height:92dvh;padding:.9rem .9rem .85rem;border-radius:18px 18px 0 0;box-shadow:0 25px 70px #0f172ae6}.coup-rules-header h2{font-size:1.05rem}.coup-rules-close{padding:.2rem .55rem;font-size:1rem}.coup-rules-sub{font-size:.88rem;margin-bottom:.45rem}.coup-rules-table{overflow-y:auto;max-height:56vh}.coup-rules-row{grid-template-columns:1fr;gap:.15rem;padding:.5rem .75rem;font-size:.9rem}.coup-rules-row.head{font-size:.85rem}.coup-rules-row:before{display:none}.coup-rules-note{font-size:.78rem;line-height:1.35;margin-top:.45rem}}.coup-rules-row{display:grid;grid-template-columns:1.15fr 1.45fr 1.7fr;gap:.5rem .55rem;padding:.42rem 1rem;font-size:.82rem;line-height:1.38;align-items:center;position:relative;border-bottom:1px solid rgba(30,41,59,.65)}.coup-rules-row:nth-child(2n):not(.head){background:#0f172a73}.coup-rules-row:nth-child(odd):not(.head){background:#02061740}.coup-rules-row.head{text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:#cbd5e1;background:linear-gradient(90deg,#2563eb73,#0f172af2);border-bottom:1px solid rgba(59,130,246,.45);padding-top:.5rem;padding-bottom:.5rem}.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-root--room .ab-build-overlay{top:calc(env(safe-area-inset-top,0px) + 62px)}.ab-root--room .ab-wind-bar{top:calc(env(safe-area-inset-top,0px) + 112px)}.ab-root--room .ab-reconnect-banner{top:calc(env(safe-area-inset-top,0px) + 64px)}.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);box-sizing:border-box;padding-left:max(8px,env(safe-area-inset-left,0px));padding-right:max(8px,env(safe-area-inset-right,0px))}.ab-waiting-box{background:#0f172ad9;border:1px solid rgba(59,130,246,.4);border-radius:28px;padding:3rem 3.5rem;text-align:center;color:#e2e8f0;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:0 25px 50px #0009,inset 0 0 20px #3b82f626;pointer-events:auto}.ab-lobby-box{min-width:360px}.ab-lobby-players{margin:2rem 0;display:flex;flex-direction:column;gap:1rem}.ab-lobby-p-row{display:flex;align-items:center;gap:1rem;background:#ffffff0f;padding:.8rem 1.2rem;border-radius:16px;border:1px solid rgba(255,255,255,.05);transition:all .2s}.ab-lobby-p-row:hover{background:#ffffff1a}.ab-p-dot{width:12px;height:12px;border-radius:50%}.ab-p-dot.team-0{background:#3b82f6;box-shadow:0 0 12px #3b82f6}.ab-p-dot.team-1{background:#ef4444;box-shadow:0 0 12px #ef4444}.ab-p-name{flex:1;text-align:left;font-weight:600;font-size:1.05rem}.ab-p-status{font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.ab-p-status.ready{color:#4ade80;text-shadow:0 0 8px rgba(74,222,128,.4)}.ab-p-status.not-ready{color:#94a3b8}.ab-ready-btn{width:100%;padding:1rem;border-radius:16px;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-weight:800;font-size:1.1rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 20px #2563eb66}.ab-ready-btn.is-ready{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 8px 20px #16a34a66}.ab-ready-btn:hover{transform:translateY(-3px);filter:brightness(1.15);box-shadow:0 12px 24px #2563eb99}.ab-ready-btn.is-ready:hover{box-shadow:0 12px 24px #16a34a99}.ab-lobby-hint{margin-top:1.25rem;color:#94a3b8;font-size:.85rem}.ab-waiting-box h2{margin:.5rem 0;font-size:1.8rem;font-weight:900;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:1rem}.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:280px;background:#0f172abf;border:1px solid rgba(59,130,246,.3);border-radius:24px;padding:1.5rem;z-index:20;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 16px 40px #0009,inset 0 0 0 1px #ffffff0d;display:flex;flex-direction:column;gap:.8rem;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.15rem;letter-spacing:.05em;text-transform:uppercase;color:#f8fafc;font-weight:900;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.ab-build-hint{font-size:.82rem;color:#94a3b8;margin:0;line-height:1.4}.ab-inventory{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}.ab-inv-btn{background:#1e293bcc;border:1.5px solid rgba(148,163,184,.2);border-radius:10px;color:#cbd5e1;font-size:.85rem;padding:.6rem .8rem;cursor:pointer;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;justify-content:space-between;align-items:center}.ab-inv-btn:hover:not(:disabled){border-color:#3b82f699;background:#1e3a8a66;color:#f1f5f9;transform:translate(-2px)}.ab-inv-btn.sel{border-color:#3b82f6;background:#2563eb40;color:#bfdbfe;font-weight:700;box-shadow:0 0 16px #3b82f64d;transform:translate(-4px)}.ab-inv-btn.empty{opacity:.4;cursor:not-allowed}.ab-build-actions{display:flex;gap:.6rem;margin-top:.5rem}.ab-undo-btn{flex:1;background:#334155cc;border:1px solid rgba(148,163,184,.3);border-radius:10px;color:#cbd5e1;font-size:.82rem;font-weight:600;padding:.6rem;cursor:pointer;transition:all .2s}.ab-undo-btn:hover:not(:disabled){color:#f8fafc;border-color:#94a3b8;background:#475569e6}.ab-undo-btn:disabled{opacity:.4;cursor:not-allowed}.ab-ready-btn{flex:2;background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:10px;color:#fff;font-size:.88rem;font-weight:800;padding:.6rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #16a34a4d}.ab-ready-btn.done{background:linear-gradient(135deg,#1e3a8a,#1d4ed8);cursor:default;box-shadow:none}.ab-ready-btn:hover:not(:disabled):not(.done){filter:brightness(1.15);transform:translateY(-1px)}.ab-ready-btn:disabled{opacity:.55;cursor:not-allowed;filter:grayscale(.15);transform:none!important}.ab-build-block-msg{margin:0;font-size:.76rem;color:#f59e0b;text-align:center;font-weight:700}.ab-placed-count{font-size:.78rem;color:#94a3b8;margin:0;font-weight:600;white-space:nowrap}.ab-placed-row{display:flex;align-items:center;gap:.5rem;margin-top:.2rem}.ab-placed-bar-wrap{flex:1;height:5px;background:#ffffff12;border-radius:4px;overflow:hidden}.ab-placed-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#22c55e);border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1)}.ab-inv-count{background:#ffffff14;border-radius:6px;padding:0 6px;font-size:.8rem;color:#94a3b8}.ab-inv-btn.sel .ab-inv-count{background:#3b82f640;color:#bfdbfe}@keyframes ab-bounce-y{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.anim-bounce{animation:ab-bounce-y .9s ease-in-out infinite;display:inline-block}.ab-inventory.ab-guide-highlight{outline:2px dashed rgba(250,204,21,.6);border-radius:12px;position:relative}.ab-guide-label{font-size:.72rem;font-weight:700;color:#fbbf24;text-align:center;letter-spacing:.03em}.ab-guide-arrow{font-size:1.2rem;display:inline-block;color:#fbbf24;margin-right:4px}.ab-guide-grid-hint{display:flex;align-items:center;gap:.35rem;background:#facc151a;border:1px dashed rgba(250,204,21,.4);border-radius:10px;padding:.55rem .75rem;font-size:.78rem;font-weight:600;color:#fde68a;line-height:1.3}.ab-guide-done-hint{display:flex;align-items:center;gap:.35rem;background:#22c55e1a;border:1px dashed rgba(34,197,94,.5);border-radius:10px;padding:.5rem .75rem;font-size:.78rem;font-weight:600;color:#bbf7d0}.ab-guide-highlight-btn{animation:ab-btn-pulse 1.2s ease-in-out infinite}@keyframes ab-btn-pulse{0%,to{box-shadow:0 4px 12px #16a34a4d}50%{box-shadow:0 0 0 6px #16a34a40,0 4px 12px #16a34a80}}.ab-multi-gameover{max-width:460px}.ab-multi-stats{flex-direction:row;align-items:stretch}.ab-go2-divider--v{width:1px;background:#ffffff14;align-self:stretch;flex-shrink:0}.ab-multi-side{flex:1;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.85rem .6rem}.ab-multi-side-label{font-size:.78rem;font-weight:800;color:#f1f5f9;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.ab-multi-side-team{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.ab-multi-side-row{display:flex;flex-direction:column;align-items:center;gap:.05rem}.ab-multi-side-row span{font-size:.6rem;text-transform:uppercase;letter-spacing:.07em;color:#64748b;font-weight:700}.ab-multi-side-row strong{font-size:1.3rem;font-weight:900;color:#f8fafc;font-variant-numeric:tabular-nums}.ab-multi-result-badge{display:inline-block;margin:.4rem auto 1rem;padding:.4rem 1.4rem;border-radius:40px;font-size:.88rem;font-weight:900;letter-spacing:.07em;text-transform:uppercase}.ab-multi-result-badge.win{background:linear-gradient(135deg,#16a34a,#15803d);color:#dcfce7;box-shadow:0 4px 20px #16a34a66}.ab-multi-result-badge.lose{background:#7f1d1d99;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.ab-play-hud{position:absolute;bottom:calc(env(safe-area-inset-bottom,0px) + 20px);left:0;right:0;margin-inline:auto;display:flex;align-items:center;gap:2rem;background:#0f172ad9;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.15);border-radius:28px;padding:.85rem 1.5rem;z-index:20;box-shadow:0 16px 40px #0009,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:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800}.ab-hud-count{font-size:1.8rem;font-weight:900;color:#f8fafc;font-variant-numeric:tabular-nums;text-shadow:0 2px 8px rgba(0,0,0,.5)}.ab-hud-turn{font-size:1.05rem;color:#f8fafc;font-weight:800;text-align:center;min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#ffffff0d;padding:.6rem 1.2rem;border-radius:16px;border:1px solid rgba(255,255,255,.05)}.ab-settling-banner{position:absolute;left:50%;bottom:5.5rem;transform:translate(-50%);z-index:25;display:flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:999px;background:#0f172af2;border:1px solid rgba(59,130,246,.5);color:#e2e8f0;font-size:.82rem;font-weight:700;box-shadow:0 8px 28px #00000080;pointer-events:none}.ab-settling-dot{width:7px;height:7px;border-radius:50%;background:#38bdf8;animation:ab-pulse 1s ease-in-out infinite}@keyframes ab-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.ab-world-map{position:relative;width:100%;height:100dvh;max-height:100dvh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;background:#070e1b}.ab-world-map-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 130% 55% at 50% -5%,rgba(56,189,248,.18) 0%,transparent 50%),radial-gradient(ellipse 80% 50% at 90% 55%,rgba(251,146,60,.1) 0%,transparent 50%),linear-gradient(180deg,#0c1a2e,#070e1b 60%,#060b18)}.ab-world-map-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Ccircle cx='30' cy='30' r='1'/%3E%3C/g%3E%3C/svg%3E")}.ab-world-map-inner{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:1.1rem 1.1rem max(2.5rem,env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:0}.ab-map-header2{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.ab-map-back{flex-shrink:0;padding:.45rem .85rem;border-radius:10px;border:1px solid rgba(148,163,184,.3);background:#0f172ab3;color:#e2e8f0;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s}.ab-map-back:hover{background:#1e293bf2;border-color:#fbbf2480;transform:translate(-2px)}.ab-map-heading2{flex:1}.ab-map-kicker{font-size:.68rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:#f59e0b;margin:0 0 .2rem}.ab-map-title2{margin:0;font-size:1.7rem;font-weight:900;line-height:1.1;background:linear-gradient(135deg,#fde68a,#f59e0b,#ea580c);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.ab-map-progress-wrap{margin-bottom:1.25rem}.ab-map-progress-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.ab-map-prog-label{font-size:.78rem;font-weight:700;color:#94a3b8}.ab-map-prog-stars{font-size:.82rem;font-weight:800;color:#e2e8f0}.ab-map-progress-bar{height:6px;border-radius:3px;background:#ffffff14;overflow:hidden}.ab-map-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#f59e0b,#fbbf24);transition:width .6s ease-out;box-shadow:0 0 8px #fbbf2466}.ab-map-scroll{display:flex;flex-direction:column;gap:1.85rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom,0px));flex:none}.ab-map-region{scroll-margin-top:.5rem}.ab-map-region-head{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:.75rem;padding-bottom:.65rem;border-bottom:1px solid rgba(148,163,184,.15)}.ab-map-region-emoji{font-size:1.65rem;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}.ab-map-region-text{min-width:0}.ab-map-region-title{margin:0 0 .2rem;font-size:1.05rem;font-weight:900;letter-spacing:.02em;color:#e2e8f0}.ab-map-region-sub{margin:0;font-size:.78rem;color:#64748b;line-height:1.35;font-weight:600}.ab-lmap-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}@media (min-width: 640px){.ab-lmap-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.ab-lcard{position:relative;border-radius:18px;overflow:hidden;background:#0f172abf;border:1.5px solid rgba(148,163,184,.18);padding:1rem;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:.55rem;transition:transform .2s,box-shadow .2s,border-color .2s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 20px #00000059}.ab-lcard.unlocked:hover{transform:translateY(-3px);border-color:#3b82f699;box-shadow:0 10px 36px #3b82f638,0 4px 14px #0006}.ab-lcard.locked{opacity:.5;cursor:not-allowed;filter:grayscale(.4)}.ab-lcard--s1{border-color:#fbbf2447}.ab-lcard--s2{border-color:#fbbf2473}.ab-lcard--s3{border-color:#fbbf24b3;box-shadow:0 0 18px #fbbf241f}.ab-lcard-lock-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.8rem;background:#070e1b80;border-radius:18px;z-index:10}.ab-lcard-badge{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#2563eb);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb80;flex-shrink:0}.ab-lcard-num{font-size:1rem;font-weight:900;color:#fff;line-height:1}.ab-lcard-body{flex:1}.ab-lcard-name{font-size:.95rem;font-weight:800;color:#f1f5f9;margin-bottom:.18rem;line-height:1.2}.ab-lcard-desc{font-size:.72rem;color:#64748b;line-height:1.4;margin-bottom:.45rem}.ab-lcard-meta{display:flex;flex-wrap:wrap;gap:.3rem .55rem}.ab-lcard-meta-item{font-size:.7rem;font-weight:700;color:#94a3b8;background:#ffffff0d;border-radius:6px;padding:.18rem .45rem}.ab-lcard-foot{display:flex;align-items:center;justify-content:space-between;padding-top:.45rem;border-top:1px solid rgba(255,255,255,.06)}.ab-lcard-score{font-size:.7rem;font-weight:800;color:#f59e0b;background:#f59e0b1a;border-radius:6px;padding:.15rem .45rem}.ab-top-bar{position:absolute;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;gap:.6rem;padding:.6rem .85rem;background:#070e1bd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.07)}.ab-top-chip{display:flex;align-items:baseline;gap:.25rem;background:#2563eb2e;border:1px solid rgba(59,130,246,.35);border-radius:8px;padding:.2rem .55rem}.ab-top-chip-lbl{font-size:.58rem;font-weight:800;letter-spacing:.1em;color:#60a5fa;text-transform:uppercase}.ab-top-chip-val{font-size:.95rem;font-weight:900;color:#e2e8f0}.ab-wind2{flex:1;min-width:0}.ab-wind2-label{font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ab-wind2-track{position:relative;height:5px;background:#ffffff1a;border-radius:3px;overflow:hidden}.ab-wind2-center{position:absolute;left:50%;top:0;width:2px;height:100%;background:#ffffff40;z-index:2}.ab-wind2-fill{position:absolute;height:100%;border-radius:2px;transition:width .4s ease-out}.ab-pause-btn{background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#e2e8f0;font-size:1rem;padding:.3rem .7rem;cursor:pointer;transition:background .15s;flex-shrink:0}.ab-pause-btn:hover{background:#ffffff24}.ab-bottom-hud{position:absolute;bottom:0;left:0;right:0;z-index:20;display:flex;align-items:center;gap:0;background:#070e1be0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.07);padding:.55rem .85rem .65rem}.ab-shots-col{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:80px}.ab-shots-label{font-size:.58rem;font-weight:800;letter-spacing:.12em;color:#3b82f6;text-transform:uppercase}.ab-shots-bubbles{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;max-width:90px}.ab-shot-bubble{width:12px;height:12px;border-radius:50%;background:#3b82f6;box-shadow:0 0 6px #3b82f6b3;transition:all .3s}.ab-shot-bubble.spent{background:#33415599;box-shadow:none}.ab-hud-center-msg{flex:1;text-align:center;font-size:.82rem;font-weight:700;color:#cbd5e1;line-height:1.3}.ab-hud-flight{display:inline-block;animation:ab-flight .6s ease-in-out infinite alternate}@keyframes ab-flight{to{transform:translate(5px)}}.ab-dest-col{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;min-width:80px}.ab-dest-label{font-size:.58rem;font-weight:800;letter-spacing:.12em;color:#ef4444;text-transform:uppercase}.ab-dest-pct{font-size:1.25rem;font-weight:900;color:#f1f5f9;line-height:1;font-variant-numeric:tabular-nums}.ab-dest-bar-wrap{position:relative;width:80px;height:6px;background:#ffffff1a;border-radius:3px;overflow:visible}.ab-dest-bar-fill{height:100%;border-radius:3px;transition:width .4s ease-out;box-shadow:0 0 6px #ef444480}.ab-dest-marker{position:absolute;top:-16px;transform:translate(-50%);font-size:.5rem;font-weight:900;color:#94a3b8;white-space:nowrap}.ab-dest-marker--right{left:100%}.ab-ingame-back{position:absolute;top:60px;left:10px;z-index:30;width:32px;height:32px;border-radius:50%;background:#0f172acc;border:1px solid rgba(148,163,184,.3);color:#e2e8f0;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ab-ingame-back:hover{background:#1e293bf2;border-color:#fbbf2480}.ab-pause-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:center;justify-content:center;background:#070e1bd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.ab-pause-panel{background:#0f172ae6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:2rem 2rem 1.75rem;max-width:340px;width:90%;box-shadow:0 30px 60px #000000b3,inset 0 0 0 1px #ffffff0d;text-align:center}.ab-pause-header{margin-bottom:1.25rem}.ab-pause-icon{font-size:2rem}.ab-pause-title{margin:.35rem 0 .2rem;font-size:1.45rem;font-weight:900;color:#f1f5f9}.ab-pause-sub{margin:0;font-size:.8rem;color:#64748b}.ab-pause-stats{display:flex;gap:.75rem;justify-content:center;margin-bottom:1.35rem}.ab-pause-stat{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.55rem .9rem;display:flex;flex-direction:column;align-items:center;gap:.1rem;font-size:.7rem;color:#94a3b8;font-weight:700;text-transform:uppercase}.ab-pause-stat strong{font-size:1.15rem;font-weight:900;color:#e2e8f0}.ab-pause-btns{display:flex;flex-direction:column;gap:.6rem}.ab-pause-btn-action{width:100%;padding:.7rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#e2e8f0;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .18s;text-align:center}.ab-pause-btn-action:hover{background:#ffffff1f;border-color:#ffffff38}.ab-pause-btn-action.primary{background:linear-gradient(135deg,#16a34a,#15803d);border-color:transparent;box-shadow:0 4px 16px #16a34a59}.ab-pause-btn-action.primary:hover{filter:brightness(1.1)}.ab-pause-btn-action.danger{color:#fca5a5;border-color:#ef44444d}.ab-pause-btn-action.danger:hover{background:#ef44441a;border-color:#ef44448c}.ab-tutorial{position:absolute;bottom:5.5rem;left:50%;z-index:35;box-sizing:border-box;width:min(92vw,360px,calc(100vw - 1rem - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px)));max-width:100%;background:#0f172af5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1.5px solid rgba(59,130,246,.55);border-radius:20px;padding:1rem 1.1rem .85rem;box-shadow:0 16px 40px #000000a6,0 0 0 1px #ffffff0a inset;display:flex;flex-direction:column;gap:.65rem}.ab-orientation-lock{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#020817f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ab-orientation-lock-card{width:min(420px,94vw);border-radius:16px;border:1px solid rgba(148,163,184,.25);background:linear-gradient(160deg,#0f172afa,#1e293bf2);box-shadow:0 20px 45px #00000073;padding:1rem 1.1rem;text-align:center}.ab-orientation-lock-title{color:#e2e8f0;font-size:1.05rem;font-weight:800;margin-bottom:.35rem}.ab-orientation-lock-text{color:#94a3b8;font-size:.88rem;line-height:1.4}.ab-tut-icon{font-size:1.8rem;text-align:center}.ab-tut-body{text-align:center;min-width:0}.ab-tut-title{font-size:.95rem;font-weight:900;color:#60a5fa;margin-bottom:.28rem;overflow-wrap:anywhere;word-break:break-word}.ab-tut-text{font-size:.8rem;color:#cbd5e1;line-height:1.55;overflow-wrap:anywhere;word-break:break-word}.ab-tut-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap;min-width:0}.ab-tut-dots{display:flex;gap:5px}.ab-tut-dot{width:6px;height:6px;border-radius:50%;background:#94a3b84d;transition:background .2s}.ab-tut-dot.on{background:#3b82f6;box-shadow:0 0 6px #3b82f680}.ab-tut-btn{background:#2563eb;border:none;border-radius:10px;color:#fff;font-size:.8rem;font-weight:700;padding:.42rem .95rem;cursor:pointer;transition:filter .15s}.ab-tut-btn:hover{filter:brightness(1.12)}.ab-tut-btn--done{background:linear-gradient(135deg,#16a34a,#15803d)}.ab-gameover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,#0f172aa6,#020617eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.ab-gameover-card2{background:#0f172ae0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1.5px solid rgba(255,255,255,.12);border-radius:28px;padding:2rem 1.75rem 1.75rem;max-width:400px;width:93%;box-shadow:0 32px 64px #000c,inset 0 0 0 1px #ffffff0d;text-align:center}.ab-go2-top{margin-bottom:.6rem}.ab-go2-title{margin:.4rem 0 .2rem;font-size:1.7rem;font-weight:900;color:#f1f5f9}.ab-go2-sub{margin:0;font-size:.85rem;font-weight:600}.ab-go2-extra-msg{margin:.4rem 0 0;font-size:.78rem;font-weight:700;color:#94a3b8;line-height:1.35}.ab-go2-stars{margin:.75rem 0 1rem}.ab-go2-stats{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:1.35rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden}.ab-go2-stat{flex:1;padding:.7rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.15rem}.ab-go2-divider{width:1px;background:#ffffff14;align-self:stretch}.ab-go2-stat-label{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#64748b}.ab-go2-stat-val{font-size:1.25rem;font-weight:900;color:#f1f5f9;line-height:1.1;font-variant-numeric:tabular-nums}.ab-go2-stat-pct{font-size:.65rem;color:#94a3b8;font-weight:600}.ab-go2-score{color:#fbbf24}.ab-go2-btns{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:center}.ab-go2-btn{border-radius:12px;padding:.65rem 1.2rem;cursor:pointer;font-weight:700;font-size:.88rem;border:none;transition:filter .18s,transform .15s}.ab-go2-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.ab-go2-btn--primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 4px 16px #2563eb66}.ab-go2-btn--secondary{background:#1e293be6;border:1px solid rgba(148,163,184,.25);color:#cbd5e1}.ab-go2-btn--ghost{background:transparent;border:1px solid rgba(148,163,184,.2);color:#94a3b8}.ab-go2-btn--ghost:hover{border-color:#94a3b873;color:#e2e8f0}.ab-opp-left-card{background:#0f172aeb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1.5px solid rgba(239,68,68,.25);border-radius:24px;padding:2rem 1.75rem 1.5rem;max-width:360px;width:93%;box-shadow:0 24px 60px #000000bf,inset 0 0 0 1px #ffffff0d;text-align:center}.ab-opp-left-icon{font-size:3rem;line-height:1;margin-bottom:.5rem}.ab-opp-left-title{margin:.35rem 0 .3rem;font-size:1.5rem;font-weight:900;color:#f1f5f9}.ab-opp-left-sub{font-size:.85rem;color:#94a3b8;margin:0 0 1rem;line-height:1.5}.ab-opp-left-sub strong{color:#f1f5f9}@keyframes ab-spin{to{transform:rotate(360deg)}}.ab-opp-left-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:ab-spin .8s linear infinite;margin:0 auto .9rem}.ab-opp-left-btns{display:flex;justify-content:center;gap:.5rem}.ab-reconnect-banner{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;background:#0f172ae6;border:1px solid rgba(239,68,68,.4);border-radius:20px;padding:.45rem 1rem;font-size:.78rem;font-weight:700;color:#fca5a5;z-index:80;white-space:nowrap;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none}.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: 640px){.ab-top-bar{gap:.45rem;padding:.5rem .55rem}.ab-top-chip{padding:.2rem .4rem}.ab-top-chip-lbl{font-size:.5rem}.ab-top-chip-val{font-size:.82rem}.ab-wind2-label{font-size:.63rem;margin-bottom:.2rem}.ab-pause-btn{padding:.28rem .52rem;font-size:.9rem}.ab-bottom-hud{padding:.42rem .5rem calc(.5rem + env(safe-area-inset-bottom,0px));gap:.35rem}.ab-shots-col,.ab-dest-col{min-width:66px}.ab-shots-label,.ab-dest-label{font-size:.5rem;letter-spacing:.08em}.ab-shots-bubbles{max-width:72px;gap:3px}.ab-shot-bubble{width:9px;height:9px}.ab-hud-center-msg{font-size:.7rem;line-height:1.2}.ab-dest-pct{font-size:1.02rem}.ab-dest-bar-wrap{width:66px;height:5px}.ab-dest-marker{display:none}.ab-ingame-back{top:54px;left:8px;width:30px;height:30px}.ab-tutorial{bottom:calc(4.35rem + env(safe-area-inset-bottom,0px));width:min(94vw,330px,calc(100vw - .75rem - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px)));padding:.75rem .85rem .68rem;border-radius:14px}.ab-tut-title{font-size:.85rem;margin-bottom:.15rem}.ab-tut-text{font-size:.74rem;line-height:1.42}.ab-tut-btn{font-size:.75rem;padding:.45rem .7rem}}@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:340px}.coup-side{max-height:68vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.coup-log{max-height:none}.coup-log ul{font-size:.95rem;gap:.12rem}.coup-log li{padding:.35rem .6rem;line-height:1.25}.coup-log h2{font-size:1.05rem;margin-bottom:.55rem}.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;max-width:100%;box-sizing:border-box;max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 40px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.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-config-stepper{display:flex;gap:.6rem;justify-content:center;margin-bottom:1rem}.ab-config-step{font-size:.72rem;font-weight:700;color:#64748b;background:#0f172aa6;border:1px solid rgba(148,163,184,.25);border-radius:999px;padding:.28rem .65rem;letter-spacing:.03em}.ab-config-step.active{color:#bfdbfe;border-color:#3b82f6b3;background:#2563eb40}.ab-config-step.done{color:#bbf7d0;border-color:#22c55e8c;background:#22c55e33}.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}.ab-config-total-row{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.8rem;font-size:.82rem;color:#94a3b8}.ab-config-total-row strong{color:#e2e8f0;font-variant-numeric:tabular-nums}.ab-config-match-msg{margin:.4rem 0 0;font-size:.78rem;color:#f59e0b;font-weight:700}.ab-config-match-msg.ok{color:#4ade80}.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;min-height:100vh;min-height:100dvh;box-sizing:border-box}.presi-root.presi-root--room{padding-top:calc(env(safe-area-inset-top,0px) + 52px)}.presi-root.game{justify-content:space-between;padding:1rem;padding-bottom:max(1rem,env(safe-area-inset-bottom,0px));overflow-y:auto;-webkit-overflow-scrolling:touch}.presi-root.game.presi-root--room{padding-top:max(1rem,calc(env(safe-area-inset-top,0px) + 52px))}.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-hint{font-size:.85rem;color:#64748b;margin:.25rem 0 0}.presi-hud-top{width:100%;display:flex;justify-content:center;flex-shrink:0;padding:0 .25rem;box-sizing:border-box}.presi-opponents{display:flex;gap:.65rem;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;max-width:100%;padding:.15rem 0;scrollbar-width:thin}.presi-opp-box{background:#1e293bcc;border:1px solid rgba(255,255,255,.1);padding:.45rem .75rem;border-radius:12px;display:flex;align-items:center;gap:.5rem;position:relative;transition:all .3s;flex:0 0 auto}.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 1 auto;width:100%;min-height:0;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1rem;position:relative;box-sizing:border-box}.presi-pile{flex:1 1 auto;min-height:clamp(160px,22vh,240px);display:flex;align-items:center;justify-content:center}.presi-played-cards{position:relative;display:flex;gap:.65rem;flex-wrap:wrap;justify-content:center;align-items:center;padding-bottom:2rem}.presi-last-actor{position:absolute;bottom:-1.85rem;left:50%;transform:translate(-50%);white-space:nowrap;color:#94a3b8;font-size:.95rem;font-weight:600}.presi-empty-pile{font-size:2rem;color:#ffffff0d;font-weight:900;text-transform:uppercase;letter-spacing:4px}.presi-log{flex:0 0 min(240px,28vw);max-width:min(260px,34vw);font-size:.88rem;color:#cbd5e1;text-align:right;line-height:1.45;align-self:center}.presi-hand-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom,0px));flex-shrink:0;box-sizing:border-box}.presi-hand{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:flex-end;margin:0;width:100%;max-width:100%;padding:.6rem .85rem;box-sizing:border-box;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;min-height:140px;scroll-padding-inline:.75rem}.presi-hand .presi-card:last-child{margin-right:0}.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.35rem}.presi-seq-hint{font-size:.9rem;color:#e2e8f0;text-align:center;max-width:min(26rem,94vw);line-height:1.45;padding:0 .65rem}.presi-seq-hint strong{color:#fbbf24;font-weight:800}.presi-seq-warn{color:#f87171;font-weight:600}.presi-card{width:86px;height:124px;padding:0;background:#fff;border-radius:11px;border:2px solid #0f172a;color:#0f172a;position:relative;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;flex-shrink:0;box-shadow:0 .4rem #0f172a24;transform-origin:50% 100%;transform:translate(var(--presi-tx, 0)) rotate(var(--presi-rot, 0deg));font:inherit;-webkit-tap-highlight-color:transparent}.presi-hand .presi-card{margin:0 -.4rem 0 0}.presi-hand .presi-card.selected{transform:translate(var(--presi-tx, 0)) rotate(var(--presi-rot, 0deg)) translateY(-20px);border-color:#2563eb;box-shadow:0 .85rem 1.35rem #2563eb61;z-index:50}.presi-card.presi-card--flat-fan{transform:none}.presi-hand .presi-card.presi-card--flat-fan.selected{transform:translateY(-16px);border-color:#2563eb;box-shadow:0 .75rem 1.15rem #2563eb59;z-index:50}.presi-hand.presi-hand--tworow{flex-wrap:wrap;justify-content:center;align-content:flex-end;align-items:flex-end;gap:.5rem .35rem;overflow-x:visible;overflow-y:visible;min-height:13.75rem;padding-top:.45rem;padding-bottom:.55rem}.presi-hand.presi-hand--tworow .presi-card{margin:0!important}.presi-hand-wrap.presi-hand-wrap--tworow{gap:.55rem}.presi-card.small{width:70px;height:100px;border-width:2px;transform:none;box-shadow:0 4px 14px #0000002e}.presi-card.small .presi-card-suit-sm{font-size:.72rem}.presi-card.small .presi-card-rank{font-size:.92rem}.presi-card.red{color:#dc2626}.presi-card.black{color:#0f172a}.presi-card-face{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;overflow:hidden;pointer-events:none}.presi-card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1;gap:1px}.presi-card-corner--tl{top:5px;left:9px}.presi-card-corner--br{bottom:5px;right:9px;transform:rotate(180deg)}.presi-card-rank{font-weight:800;font-size:1.05rem;letter-spacing:-.02em}.presi-card-suit-sm{font-size:.72rem}.presi-card-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.presi-pip-field{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2px;width:70%;height:58%}.presi-pip-field--ace{width:55%;height:55%}.presi-pip-field--face{width:58%;height:58%}.presi-pip-field--face .presi-pip--face{font-size:2.35rem;line-height:1;filter:drop-shadow(0 1px 0 rgba(15,23,42,.12))}.presi-pip-field--ace .presi-pip--xl{font-size:2.25rem}.presi-pip{font-size:.62rem;line-height:1}.presi-card.small .presi-pip-field--face{width:62%;height:62%}.presi-card.small .presi-pip-field--face .presi-pip--face{font-size:1.9rem}.presi-card.small .presi-pip-field--ace .presi-pip--xl{font-size:1.85rem}.presi-card.small .presi-pip{font-size:.52rem}.presi-toast{position:fixed;top:max(12px,env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:12000;max-width:min(420px,calc(100vw - 24px));padding:.65rem 1rem;border-radius:12px;font-size:.88rem;font-weight:600;line-height:1.35;box-shadow:0 .5rem 2rem #00000059;animation:presi-toast-in .28s ease}@keyframes presi-toast-in{0%{opacity:0;margin-top:-6px}to{opacity:1;margin-top:0}}.presi-root .presi-toast--error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.presi-root .presi-toast--tip{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.presi-root .presi-toast--info{background:#1e293b;color:#e2e8f0;border:1px solid #334155}.presi-root.presi-root--room .presi-toast{top:max(12px,calc(env(safe-area-inset-top,0px) + 56px))}.presi-tip-banner{font-size:.82rem;color:#94a3b8;line-height:1.4;margin:0 0 1rem;padding:.65rem .85rem;background:#0f172a80;border-radius:12px;border:1px solid rgba(255,255,255,.06)}.presi-learn-strip{width:100%;max-width:560px;font-size:.88rem;color:#cbd5e1;line-height:1.45;padding:.45rem .65rem;display:flex;align-items:flex-start;gap:.55rem;flex-shrink:0}.presi-learn-dot{width:6px;height:6px;border-radius:50%;background:#34d399;margin-top:.35rem;flex-shrink:0}.presi-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.presi-my-actions{display:flex;gap:1rem}.presi-btn{padding:.7rem 1.75rem;min-height:48px;border-radius:12px;border:none;font-weight:800;font-size:.95rem;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:max(1rem,calc(env(safe-area-inset-top,0px) + .5rem));right:max(.75rem,env(safe-area-inset-right,0px));padding:.5rem 1.25rem;border-radius:2rem;font-weight:900;letter-spacing:1px;color:#fff;z-index:2}.presi-root.presi-root--room .presi-my-rank-tag{top:max(1rem,calc(env(safe-area-inset-top,0px) + 52px))}.presi-my-rank-tag.king{background:linear-gradient(135deg,#fbbf24,#d97706);box-shadow:0 0 20px #fbbf2480}.presi-my-rank-tag.vice-king{background:linear-gradient(135deg,#94a3b8,#64748b)}.presi-my-rank-tag.middle{background:#334155}.presi-my-rank-tag.vice-beggar{background:#475569}.presi-my-rank-tag.beggar{background:#1e293b;border:1px solid #475569}@media (min-width: 1024px){.presi-card{width:94px;height:136px;border-radius:12px}.presi-card.small{width:78px;height:112px}.presi-card-rank{font-size:1.12rem}.presi-card-suit-sm{font-size:.78rem}.presi-pip-field--face .presi-pip--face{font-size:2.55rem}.presi-card.small .presi-pip-field--face .presi-pip--face{font-size:2.15rem}.presi-pile{min-height:clamp(200px,26vh,280px)}.presi-hand{min-height:156px;justify-content:flex-start}.presi-hand .presi-card{margin:0 -.36rem 0 0}.presi-log{flex-basis:260px;max-width:min(280px,30vw);font-size:.92rem}}@media (max-width: 640px){.presi-table{flex-direction:column;align-items:stretch;justify-content:center;gap:.35rem;padding:0 .35rem}.presi-log{flex:0 0 auto;max-width:100%;width:100%;text-align:center;font-size:.82rem;line-height:1.45;max-height:5.5rem;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.35rem .5rem;background:#0f172a73;border-radius:10px;border:1px solid rgba(255,255,255,.06)}.presi-pile{min-height:0}.presi-hand{min-height:118px;padding-top:.85rem;padding-left:max(.5rem,env(safe-area-inset-left,0px));padding-right:max(.5rem,env(safe-area-inset-right,0px))}.presi-card{width:66px;height:96px}.presi-card-rank{font-size:.92rem}.presi-card-suit-sm{font-size:.62rem}.presi-hand .presi-card{margin:0 -.44rem 0 0}.presi-hand .presi-card.selected{transform:translate(var(--presi-tx, 0)) rotate(var(--presi-rot, 0deg)) translateY(-16px)}.presi-card.small{width:58px;height:84px}.presi-last-actor{font-size:.88rem}.presi-empty-pile{font-size:1.15rem;letter-spacing:2px}.presi-opp-name{max-width:5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.presi-opp-box.active{transform:scale(1.02)}.presi-my-turn-label{font-size:1.12rem;letter-spacing:1px}.presi-seq-hint{font-size:.84rem}.presi-learn-strip{font-size:.82rem}.presi-hand.presi-hand--tworow{min-height:14.25rem;gap:.45rem .3rem}}@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:.65rem;margin-bottom:.65rem}.hub-rooms-title{font-size:1.05rem;margin:0 0 .1rem}.hub-rooms-subtitle{display:none}.hub-create-btn{padding:.48rem .9rem;font-size:.8rem;border-radius:10px;width:auto}.hub-create-btn.large{width:auto;padding:.5rem 1rem;font-size:.85rem}.hub-empty-state{padding:1.2rem .85rem}.hub-empty-icon{font-size:1.9rem}.hub-empty-title{font-size:.95rem}.hub-empty-sub{font-size:.78rem}.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-root .coup-layout{padding:2.25rem .9rem .9rem!important;gap:.85rem!important}.coup-root .menu-title{font-size:1.75rem!important;margin:.45rem 0 .35rem;padding:0 .25rem}.coup-root .menu-sub{margin-bottom:.75rem;font-size:.85rem;padding:0 .6rem}.coup-root .back-btn{top:.7rem;left:.7rem}.coup-root .coup-side{padding:1rem!important;border-radius:14px}.coup-side,.mafia-side,.presi-side{width:100%!important;flex:none!important}.coup-table{height:48vh!important;min-height:340px!important}.mafia-table{height:40vh!important;min-height:300px!important}.presi-table{height:auto!important;min-height:0!important;flex:1 1 auto!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}.presi-root.game .presi-my-actions .presi-btn{padding:.65rem 1.1rem!important;font-size:.92rem!important;min-height:48px}.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-comms-panel{width:auto!important;left:8px!important;right:8px!important;bottom:calc(env(safe-area-inset-bottom,0px) + 8px)!important}.room-comms-wrapper{left:8px!important;right:8px!important;bottom:calc(env(safe-area-inset-bottom,0px) + 8px)!important}.room-comms-launcher{width:48px;height:48px}.room-comms-chat-list{height:90px!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;max-height:min(56dvh,430px)!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-center-overlay{align-items:flex-start;justify-content:center;padding-top:calc(env(safe-area-inset-top,0px) + 56px);padding-bottom:calc(env(safe-area-inset-bottom,0px) + 12px);overflow-y:auto;-webkit-overflow-scrolling:touch}.ab-config-box{min-width:0!important;width:min(calc(100vw - 16px),460px)!important;max-width:calc(100vw - 16px)!important;padding:1rem .85rem 1.15rem!important;padding-bottom:max(1.15rem,env(safe-area-inset-bottom,0px))!important;border-radius:18px!important;max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 108px)!important;margin-top:4px;margin-bottom:auto}.ab-root--room .ab-config-box{max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 132px)!important}.ab-config-title{font-size:clamp(1.15rem,5.2vw,1.55rem)!important;line-height:1.2;margin-bottom:8px!important}.ab-config-p{font-size:.8rem!important;line-height:1.45;margin-bottom:.85rem!important}.ab-config-stepper{flex-wrap:wrap;row-gap:6px;margin-bottom:.75rem!important}.ab-config-step{font-size:.65rem!important;padding:.22rem .5rem!important}.ab-grid-options{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:.55rem!important;margin-bottom:1rem!important}.ab-grid-opt{padding:.55rem .4rem!important;border-radius:12px!important;gap:4px!important;font-size:.72rem!important}.ab-grid-thumb{width:40px!important;height:40px!important;font-size:.68rem!important;border-radius:6px!important}.ab-items-voter{gap:.5rem!important;margin-bottom:1rem!important}.ab-item-row{padding:.55rem .65rem!important;border-radius:12px!important;flex-wrap:wrap;gap:6px}.ab-item-label{font-size:.82rem!important;flex:1 1 auto;min-width:0;text-align:left}.ab-item-ctrl{gap:.65rem!important;margin-left:auto}.ab-counter-btn{width:38px!important;height:38px!important;min-width:38px;min-height:38px;font-size:1.1rem!important}.ab-item-val{font-size:1.05rem!important;min-width:22px!important}.ab-config-status{padding-top:.85rem!important;gap:.55rem!important;font-size:.78rem!important}.ab-v-head{grid-template-columns:minmax(0,1.4fr) minmax(0,.85fr) minmax(0,.85fr)!important;padding:.35rem .45rem!important;font-size:.65rem!important;gap:4px}.ab-v-data{grid-template-columns:minmax(0,1.4fr) minmax(0,.85fr) minmax(0,.85fr)!important;padding:.45rem!important;font-size:.78rem!important;gap:4px}.ab-v-type{font-size:.72rem!important}.ab-config-total-row{flex-wrap:wrap;justify-content:center!important;gap:.35rem 1rem!important;font-size:.75rem!important;margin-bottom:.55rem!important}.ab-config-match-msg{font-size:.72rem!important;line-height:1.35;margin-top:.35rem!important}.ab-config-box .ab-ready-btn,.ab-config-box .ab-config-next-btn{padding:.75rem .85rem!important;font-size:.92rem!important;border-radius:12px!important;margin-top:10px!important}.ab-waiting-box,.ab-lobby-box{min-width:0!important;width:min(94vw,460px)!important;padding:1.1rem!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: 480px){.presi-lobby{padding:1.5rem 1rem;border-radius:1.25rem;max-width:calc(100vw - 1rem)}.presi-lobby .menu-title{font-size:1.75rem;margin-bottom:.25rem}.presi-lobby .menu-sub{font-size:.8rem;margin-bottom:.5rem}.presi-tip-banner{font-size:.75rem;padding:.45rem .6rem;margin-bottom:.65rem}.presi-p-row{padding:.5rem 0}.presi-hint{font-size:.78rem}.presi-actions{gap:.5rem}.presi-root.game{padding:.5rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom,0px))}.presi-root.game.presi-root--room{padding-top:max(.5rem,calc(env(safe-area-inset-top,0px) + 52px))}.presi-hud-top{padding:0}.presi-opp-box{padding:.3rem .5rem;gap:.3rem}.presi-opp-rank{font-size:.68rem}.presi-opp-name{font-size:.8rem}.presi-opp-cards{font-size:.68rem}.presi-learn-strip{font-size:.7rem;padding:.2rem .3rem;gap:.35rem}.presi-learn-dot{width:5px;height:5px;margin-top:.28rem}.presi-card{width:64px;height:92px}.presi-card-rank{font-size:.9rem}.presi-card-suit-sm{font-size:.6rem}.presi-card-corner--tl{top:3px;left:6px}.presi-card-corner--br{bottom:3px;right:6px}.presi-hand{min-height:102px;padding-top:.7rem}.presi-hand .presi-card{margin:0 -.48rem 0 0}.presi-hand .presi-card.selected{transform:translate(var(--presi-tx, 0)) rotate(var(--presi-rot, 0deg)) translateY(-14px)}.presi-card.small{width:56px;height:82px}.presi-my-turn-label{font-size:1rem!important;letter-spacing:.6px!important}.presi-seq-hint{font-size:.8rem;max-width:100%}.presi-hand.presi-hand--tworow{min-height:13.25rem;gap:.4rem .25rem}.presi-my-actions{display:flex!important;flex-direction:row!important;flex-wrap:wrap!important;gap:.4rem!important;width:100%}.presi-btn{padding:.65rem .5rem!important;font-size:.82rem!important;min-height:44px;border-radius:10px}.presi-btn.play,.presi-btn.pass{flex:1 1 calc(50% - .25rem)!important;min-width:0!important}.presi-btn.ghost.exit{flex:0 0 100%!important;width:100%!important}.presi-my-rank-tag{font-size:.72rem;padding:.3rem .7rem;letter-spacing:.5px}}@media (max-width: 380px){.presi-card{width:56px;height:84px}.presi-card-rank{font-size:.82rem}.presi-card-suit-sm{font-size:.55rem}.presi-card-corner--tl{top:3px;left:5px}.presi-card-corner--br{bottom:3px;right:5px}.presi-hand{min-height:96px}.presi-hand .presi-card{margin:0 -.5rem 0 0}.presi-card.small{width:50px;height:74px}.presi-root.game{padding:.35rem;padding-bottom:max(.35rem,env(safe-area-inset-bottom,0px))}.presi-opp-name{max-width:4rem}.presi-log{font-size:.78rem;max-height:5rem}.presi-hand.presi-hand--tworow{min-height:12.5rem;gap:.35rem .2rem}.presi-hand .presi-card.presi-card--flat-fan.selected{transform:translateY(-12px)}}@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}.ab-root--room .ab-center-overlay{padding-top:calc(env(safe-area-inset-top,0px) + 72px)}.ab-root--room .ab-build-overlay{inset:auto 10px 10px 10px!important;top:auto!important}.ab-root--room .ab-wind-bar{top:calc(env(safe-area-inset-top,0px) + 96px)!important}}@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}.ab-root--room .ab-build-overlay,.ab-root--room .ab-wind-bar{top:calc(env(safe-area-inset-top,0px) + 72px)!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}}@media (max-height: 740px){.ab-tutorial{bottom:4.6rem;width:min(92vw,330px,calc(100vw - 1rem - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px)));padding:.85rem .95rem .75rem}.ab-wind-bar{width:180px;padding:6px 10px}}.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}.leaderboard-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.65rem;gap:.5rem;flex-wrap:wrap}.leaderboard-title{margin:0;font-size:1.4rem;background:linear-gradient(90deg,#f59e0b,#ef4444);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.leaderboard-close-btn{background:transparent;border:1px solid #475569;color:#94a3b8;border-radius:8px;padding:.3rem .7rem;cursor:pointer;font-size:.9rem}.leaderboard-close-btn:hover{border-color:#64748b;color:#e2e8f0}.leaderboard-tab-blurb{margin:0 0 1rem;font-size:.82rem;line-height:1.45;color:#94a3b8}.leaderboard-tabs{display:flex;gap:6px;margin-bottom:1.25rem;flex-wrap:wrap}.leaderboard-tab{padding:.4rem .8rem;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid #334155;background:transparent;color:#94a3b8;transition:border-color .15s,background .15s,color .15s}.leaderboard-tab:hover{color:#cbd5e1}.leaderboard-state{text-align:center;padding:2rem 1rem;font-size:.95rem}.leaderboard-state--muted{color:#64748b}.leaderboard-state--error{color:#ef4444;padding:1.5rem;font-size:.9rem}.leaderboard-state--empty{color:#475569}.leaderboard-state-icon{font-size:2rem;margin-bottom:.5rem}.leaderboard-empty-hint{font-size:.85rem;color:#334155;margin:.5rem 0 0}.leaderboard-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.leaderboard-row{border:1px solid #1e293b;border-radius:12px;padding:.75rem 1rem;transition:transform .1s}.leaderboard-row-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:6px;flex-wrap:wrap}.leaderboard-row-name-block{display:flex;align-items:center;gap:8px;min-width:0}.leaderboard-rank{font-size:1.1rem;min-width:28px;flex-shrink:0}.leaderboard-name{font-weight:500;color:#e2e8f0;overflow:hidden;text-overflow:ellipsis}.leaderboard-name--me{font-weight:700;color:var(--row-accent, #f59e0b)}.leaderboard-row-score-block{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.leaderboard-mini-badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end;max-width:140px}.lb-badge{font-size:.65rem;border-radius:6px;padding:1px 4px}.lb-badge--slingshot{background:#ef444422;border:1px solid #ef4444;color:#fca5a5}.lb-badge--cards{background:#3b82f622;border:1px solid #3b82f6;color:#93c5fd}.lb-badge--mafia{background:#8b5cf622;border:1px solid #8b5cf6;color:#c4b5fd}.lb-badge--presi{background:#fbbf2422;border:1px solid #fbbf24;color:#fcd34d}.lb-badge--fps{background:#22c55e22;border:1px solid #22c55e;color:#86efac}.lb-badge--fpsmp{background:#f9731626;border:1px solid #f97316;color:#fdba74}.leaderboard-score-num{font-weight:800;font-size:1.1rem;min-width:32px;text-align:right;color:var(--row-accent, #f59e0b)}.leaderboard-score-unit{color:#64748b;font-size:.8rem}.leaderboard-fps-split{font-size:.72rem;color:#64748b;margin:-2px 0 8px 36px;display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.leaderboard-fps-split-sep{opacity:.5}.leaderboard-bar-track{height:4px;background:#1e293b;border-radius:4px;overflow:hidden}.leaderboard-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}@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-icon{width:1.05rem!important;height:1.05rem!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:1fr auto!important;position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;min-height:0}.hub-sidebar{display:block!important;max-height:none!important;min-height:0;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:.65rem .75rem calc(.65rem + env(safe-area-inset-bottom,0px))!important;overflow-y:auto!important;overflow-x:hidden;min-height:0;max-height:min(42vh,420px);border-top:1px solid rgba(30,41,59,.9);background:#070e1b;align-self:stretch}.hub-main.hub-main--modal{max-height:none;overflow:visible}.hub-rooms-header{flex-direction:row!important;flex-wrap:wrap!important;align-items:center!important;justify-content:space-between!important;gap:.5rem .65rem!important;margin-bottom:.55rem!important}.hub-rooms-header>div:first-child{min-width:0;flex:1 1 140px}.hub-rooms-title{font-size:1.05rem!important;margin:0!important}.hub-rooms-subtitle{display:none!important}.hub-create-btn{width:auto!important;font-size:.78rem!important;padding:.42rem .75rem!important;border-radius:10px!important;flex-shrink:0}.hub-empty-state{padding:1rem .75rem!important;border-radius:14px;gap:.35rem!important}.hub-empty-icon{font-size:1.75rem}.hub-empty-title{font-size:.92rem}.hub-empty-sub{max-width:100%;font-size:.74rem;line-height:1.35}.hub-rooms-grid{grid-template-columns:1fr!important;gap:.75rem!important}}.csp-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:radial-gradient(ellipse at 15% 0%,rgba(124,58,237,.13) 0%,transparent 55%),radial-gradient(ellipse at 85% 100%,rgba(6,78,59,.14) 0%,transparent 55%),linear-gradient(160deg,#030b18,#020617,#040c1a);color:#e5e7eb;overflow:hidden;font-family:inherit}.csp-topbar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;padding-top:max(.6rem,env(safe-area-inset-top,0px));background:#030b18bf;border-bottom:1px solid rgba(255,255,255,.05);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);gap:.5rem;z-index:2}.csp-back{padding:.32rem .65rem;border:1px solid rgba(100,116,139,.45);border-radius:8px;background:#0f172a99;color:#94a3b8;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.csp-back:hover{background:#1e293b;color:#e2e8f0}.csp-title-badge{font-size:.85rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;background:linear-gradient(90deg,#f59e0b,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.csp-title-badge--mp{font-size:clamp(.62rem,2.8vw,.85rem);letter-spacing:.1em;text-align:center;line-height:1.25;max-width:min(52vw,220px);white-space:normal}.csp-topbar--mp-lobby,.csp-topbar--mp-game{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:.35rem}.csp-topbar-slot{display:flex;align-items:center;min-width:0;min-height:40px}.csp-topbar-slot--end{justify-content:flex-end}.csp-topbar--in-room .csp-topbar-slot:first-child{min-height:36px}.csp-root.csp-root--hub-room{padding-top:calc(env(safe-area-inset-top,0px) + 56px);padding-bottom:calc(env(safe-area-inset-bottom,0px) + 76px);box-sizing:border-box}.csp-root.csp-root--hub-room .csp-topbar{padding-top:.45rem}@media (max-width: 540px){.csp-root.csp-root--hub-room{padding-top:calc(env(safe-area-inset-top,0px) + 58px)}}@media (min-width: 701px){.csp-root.csp-root--hub-room{padding-top:calc(env(safe-area-inset-top,0px) + 72px)}.csp-root.csp-root--hub-room .csp-topbar{padding-top:.7rem;padding-bottom:.65rem}.csp-root.csp-root--hub-room .csp-title-badge--mp{max-width:min(36vw,320px)}}.csp-rules-btn{padding:.32rem .6rem;border:1px solid rgba(99,102,241,.38);border-radius:8px;background:#6366f11a;color:#a5b4fc;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.csp-rules-btn:hover{background:#6366f138}.csp-hud{flex-shrink:0;display:flex;align-items:center;gap:.45rem;padding:.45rem .85rem;background:#050f1eb3;border-bottom:1px solid rgba(255,255,255,.04)}.csp-hud-player{flex:1;display:flex;align-items:center;gap:.5rem;padding:.38rem .6rem;border-radius:11px;border:1px solid transparent;min-width:0}.csp-hud-player.you{background:#f59e0b12;border-color:#f59e0b33;flex-direction:row}.csp-hud-player.ai{background:#818cf812;border-color:#818cf833;flex-direction:row-reverse}.csp-hud-info{display:flex;flex-direction:column;gap:0;flex-shrink:0}.csp-hud-name{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#64748b}.csp-hud-player.you .csp-hud-name{color:#fbbf24}.csp-hud-player.ai .csp-hud-name{color:#a5b4fc}.csp-hud-coins{font-size:1.05rem;font-weight:800;color:#e2e8f0;display:flex;align-items:center;gap:2px}.csp-coin-icon{font-size:.85rem}.csp-hud-cards{flex:1;display:flex;gap:4px;justify-content:flex-end;overflow:hidden}.csp-hud-player.ai .csp-hud-cards{justify-content:flex-start}.csp-hud-card{width:32px;height:22px;border-radius:5px;border:1.5px solid rgba(255,255,255,.1);background:#0f172acc;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.csp-hud-card.alive{box-shadow:0 0 5px #ffffff14}.csp-hud-card.alive.unknown{background:#6366f12e;color:#818cf8;border-color:#6366f152}.csp-hud-card.dead{background:#141e3266;color:#374151;border-color:#1e293b;opacity:.5}.csp-hud-vs{flex-shrink:0;font-size:1rem;color:#334155;-webkit-user-select:none;user-select:none}.csp-scene{flex:0 0 auto;height:clamp(180px,36vh,300px);position:relative;overflow:hidden;background:radial-gradient(ellipse at 50% 60%,rgba(30,58,138,.18) 0%,transparent 70%);border-bottom:1px solid rgba(255,255,255,.04)}.csp-last-action{flex-shrink:0;display:flex;align-items:center;gap:.5rem;padding:.35rem .85rem;background:#f59e0b0e;border-bottom:1px solid rgba(245,158,11,.1);font-size:.8rem;color:#b45309;font-weight:500;line-height:1.35;min-height:2rem}.csp-last-action-dot{width:6px;height:6px;border-radius:50%;background:#f59e0b;flex-shrink:0;animation:csp-pulse-dot 2s ease-in-out infinite}@keyframes csp-pulse-dot{0%,to{opacity:1}50%{opacity:.25}}.csp-last-action-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.csp-action-zone{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.75rem max(.85rem,env(safe-area-inset-right,0px)) .75rem max(.85rem,env(safe-area-inset-left,0px));scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.3) transparent}.csp-phase-block{display:flex;flex-direction:column;gap:.6rem}.csp-phase-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .8rem;border-radius:999px;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;align-self:flex-start;border:1.5px solid rgba(99,102,241,.3);background:#6366f11a;color:#a5b4fc}.csp-phase-chip.yours{background:#22c55e1a;border-color:#22c55e59;color:#4ade80}.csp-phase-chip.urgent{background:#ef44441a;border-color:#ef444466;color:#f87171;animation:csp-urgent-pulse 1.1s ease-in-out infinite}.csp-phase-chip.challenge{background:#fbbf241a;border-color:#fbbf2461;color:#fbbf24}.csp-phase-chip.block{background:#3b82f61a;border-color:#3b82f661;color:#60a5fa}.csp-phase-chip.exchange{background:#0596691a;border-color:#05966961;color:#34d399}@keyframes csp-urgent-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 5px #ef444421}}.csp-phase-action-label{margin:0;font-size:.95rem;font-weight:700;color:#e2e8f0;padding:.4rem .65rem;background:#0f172a99;border-left:3px solid #6366f1;border-radius:0 8px 8px 0}.csp-phase-hint{margin:0;font-size:.85rem;color:#64748b;line-height:1.45}.csp-btn-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.csp-btn-grid--2{grid-template-columns:repeat(2,1fr)}.csp-btn{padding:.72rem .65rem;border-radius:12px;border:1.5px solid rgba(255,255,255,.07);background:#0f172ae0;color:#e5e7eb;font-size:.9rem;font-weight:700;cursor:pointer;transition:transform .13s,filter .13s,box-shadow .13s;display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;line-height:1.2;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}.csp-btn span{font-size:.73rem;font-weight:500;opacity:.65}.csp-btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.15);box-shadow:0 6px 20px #0006}.csp-btn:active:not(:disabled){transform:scale(.96)}.csp-btn:disabled{opacity:.3;cursor:not-allowed;filter:grayscale(.4)}.csp-btn--income{background:linear-gradient(135deg,#064e3b,#047857);border-color:#059669;color:#a7f3d0}.csp-btn--foreign-aid{background:linear-gradient(135deg,#78350f,#92400e);border-color:#d97706;color:#fde68a}.csp-btn--tax{background:linear-gradient(135deg,#3b0764,#4c1d95);border-color:#7c3aed;color:#c4b5fd}.csp-btn--steal{background:linear-gradient(135deg,#1e3a8a,#1d4ed8);border-color:#3b82f6;color:#bfdbfe}.csp-btn--assassinate{background:linear-gradient(135deg,#7f1d1d,#991b1b);border-color:#dc2626;color:#fca5a5}.csp-btn--exchange{background:linear-gradient(135deg,#064e3b,#065f46);border-color:#059669;color:#6ee7b7}.csp-btn--coup{background:linear-gradient(135deg,#7c2d12,#9a3412);border-color:#ea580c;color:#fed7aa;grid-column:1 / -1}.csp-btn--lose{background:linear-gradient(135deg,#7f1d1d,#991b1b);border-color:#dc2626;color:#fca5a5}.csp-btn--challenge{background:linear-gradient(135deg,#78350f,#92400e);border-color:#d97706;color:#fde68a}.csp-btn--pass{background:#0f172ad9;border-color:#334155;color:#94a3b8}.csp-btn--block{background:linear-gradient(135deg,#1e3a8a,#1d4ed8);border-color:#3b82f6;color:#bfdbfe}.csp-btn--exchange-pick{background:linear-gradient(135deg,#1e3a5f,#1e4d7a);border-color:#3b82f6;color:#bfdbfe}.csp-btn--exchange-pick.selected{background:linear-gradient(135deg,#14532d,#166534);border-color:#22c55e;color:#86efac;box-shadow:0 0 14px #22c55e47}.csp-ai-thinking{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:1.5rem 1rem;min-height:7rem}.csp-ai-avatar{font-size:2.2rem;animation:csp-ai-float 2.4s ease-in-out infinite}@keyframes csp-ai-float{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.csp-ai-dots-wrap{display:flex;gap:6px;align-items:center}.csp-ai-dot{width:8px;height:8px;border-radius:50%;background:#818cf8;animation:csp-dot-bounce 1.3s ease-in-out infinite}.csp-ai-dot:nth-child(2){animation-delay:.22s}.csp-ai-dot:nth-child(3){animation-delay:.44s}@keyframes csp-dot-bounce{0%,80%,to{transform:scale(.55);opacity:.35}40%{transform:scale(1);opacity:1}}.csp-ai-label{margin:0;font-size:.85rem;color:#6366f1;font-weight:700}.csp-your-turn{display:flex;flex-direction:column;gap:.6rem}.csp-status-box{display:flex;align-items:center;justify-content:center;padding:1rem;border-radius:12px;font-size:1rem;font-weight:700;color:#94a3b8;background:#0f172a80;border:1px solid rgba(255,255,255,.06)}.csp-mycards-strip{flex-shrink:0;display:flex;flex-direction:column;gap:0;padding:.4rem .85rem;background:#030b1899;border-top:1px solid rgba(255,255,255,.04)}.csp-mycards-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.csp-mycards-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#475569}.csp-hide-btn{display:flex;align-items:center;gap:.3rem;padding:.22rem .6rem;border-radius:999px;border:1.5px solid rgba(99,102,241,.35);background:#6366f11a;color:#a5b4fc;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.csp-hide-btn:hover{background:#6366f138}.csp-hide-btn.hidden{border-color:#f59e0b66;background:#f59e0b1a;color:#fbbf24}.csp-hide-btn.hidden:hover{background:#f59e0b33}.csp-mycards-row{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none}.csp-mycards-row::-webkit-scrollbar{display:none}.csp-mycard{flex-shrink:0;display:flex;flex-direction:column;gap:1px;padding:.3rem .55rem;border-radius:8px;border:1px solid rgba(255,255,255,.07);border-left:3px solid #6366f1;background:#0f172abf;min-width:72px;transition:border-left-color .25s,opacity .25s}.csp-mycard.dead{opacity:.4;border-left-color:#374151!important}.csp-mycard.hidden-card{background:#0f172a80;border-color:#4b55634d}.csp-hud-card.hidden-card{background:#1e293bb3!important;color:#4b5563!important;border-color:#334155!important;box-shadow:none!important;letter-spacing:.15em}.csp-mycard-role{font-size:.78rem;font-weight:800;letter-spacing:.04em;line-height:1;transition:color .2s}.csp-mycard-status{font-size:.65rem;color:#475569;font-weight:600}.csp-mycard-status.alive{color:#22c55e}.csp-toolbar{flex-shrink:0;display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;padding:.5rem max(.85rem,env(safe-area-inset-right,0px)) max(.5rem,env(safe-area-inset-bottom,0px)) max(.85rem,env(safe-area-inset-left,0px));background:#030b18d1;border-top:1px solid rgba(255,255,255,.05);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.csp-tool-btn{flex:1;padding:.48rem .4rem;border:1px solid rgba(255,255,255,.07);border-radius:9px;background:#0f172ab3;color:#94a3b8;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s;text-align:center;-webkit-tap-highlight-color:transparent}.csp-tool-btn:hover{background:#1e293b;color:#e2e8f0}.csp-tool-btn:active{transform:scale(.95)}.csp-toolbar--mp-log{justify-content:center;padding-top:.38rem;padding-bottom:max(.38rem,env(safe-area-inset-bottom,0px));gap:0}.csp-toolbar--mp-log .csp-tool-btn{flex:0 1 auto;min-width:6.5rem;max-width:12rem}@media (max-width: 699px){.csp-action-zone{padding-top:.45rem;padding-bottom:.45rem}.csp-phase-block{gap:.45rem}.csp-your-turn{gap:.35rem}.csp-phase-chip{padding:.2rem .55rem;font-size:.66rem;letter-spacing:.05em}.csp-btn-grid:not(.csp-btn-grid--2){grid-template-columns:repeat(3,minmax(0,1fr));gap:.3rem}.csp-btn{flex-direction:row;align-items:center;justify-content:flex-start;flex-wrap:nowrap;gap:.15rem;padding:.4rem .35rem;min-height:2.65rem;border-radius:9px;font-size:clamp(.62rem,2.8vw,.74rem);line-height:1.12;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.csp-btn span{font-size:clamp(.52rem,2.3vw,.62rem);font-weight:600;opacity:.75;margin-left:auto;text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:48%}.csp-btn--coup{grid-column:1 / -1;min-height:2.85rem;padding-top:.48rem;padding-bottom:.48rem}.csp-btn--coup span{max-width:55%}}@media (min-width: 700px){.csp-root{flex-direction:column}.csp-scene{height:clamp(200px,40vh,360px)}.csp-btn-grid{grid-template-columns:repeat(3,1fr)}.csp-btn-grid--2{grid-template-columns:repeat(2,1fr)}.csp-btn--coup{grid-column:auto}.csp-btn{font-size:.95rem;padding:.8rem .75rem}.csp-last-action-text{white-space:normal}}@media (min-width: 1000px){.csp-root{flex-direction:row;flex-wrap:wrap}.csp-topbar{width:100%;flex-shrink:0}.csp-hud{width:100%}.csp-scene{flex:1 1 55%;height:auto;min-height:340px;border-bottom:none;border-right:1px solid rgba(255,255,255,.04)}.csp-last-action{width:100%;order:10}.csp-action-zone{flex:0 0 380px;max-width:420px;border-left:1px solid rgba(255,255,255,.04)}.csp-mycards-strip,.csp-toolbar{width:100%}.csp-mp-hud-scroll{width:100%;flex-basis:100%}.csp-mp-waiting{min-height:0;justify-content:flex-start;padding-top:.35rem;padding-bottom:1rem}}.csp-lobby-wrap{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.5rem max(.75rem,env(safe-area-inset-right,0px)) max(.75rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));display:flex;flex-direction:column;align-items:center}.csp-mp-lobby-root{width:100%;max-width:440px;margin:0 auto}.csp-mp-lobby-card{border-radius:16px;border:1px solid rgba(148,163,184,.18);background:linear-gradient(165deg,#0f172ae0,#0f172aa6);box-shadow:0 12px 40px #00000059;padding:1rem 1.05rem 1.1rem}.csp-mp-lobby-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.65rem .75rem;padding-bottom:.85rem;margin-bottom:.85rem;border-bottom:1px solid rgba(51,65,85,.65)}.csp-mp-lobby-head-text{flex:1 1 200px;min-width:0}.csp-mp-lobby-title{margin:0 0 .3rem;font-size:1.15rem;font-weight:800;color:#f1f5f9;letter-spacing:-.02em}.csp-mp-lobby-sub{margin:0;font-size:.78rem;line-height:1.45;color:#94a3b8}.csp-mp-lobby-live{flex-shrink:0;display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.csp-mp-lobby-live.is-on{color:#86efac;background:#16a34a1f;border-color:#22c55e59}.csp-mp-lobby-live.is-off{color:#94a3b8;background:#33415559;border-color:#47556980}.csp-mp-lobby-live-dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.9}.csp-mp-lobby-live.is-on .csp-mp-lobby-live-dot{box-shadow:0 0 8px #22c55e;animation:csp-pulse-dot 2s ease-in-out infinite}.csp-mp-lobby-field{margin-bottom:1rem}.csp-mp-lobby-label{display:block;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#64748b;margin-bottom:.35rem}.csp-mp-lobby-input{width:100%;box-sizing:border-box;padding:.62rem .75rem;border-radius:10px;border:1px solid rgba(71,85,105,.85);background:#020617a6;color:#e2e8f0;font-size:.95rem;font-weight:600;transition:border-color .15s,box-shadow .15s}.csp-mp-lobby-input::placeholder{color:#475569;font-weight:500}.csp-mp-lobby-input:focus{outline:none;border-color:#f59e0b8c;box-shadow:0 0 0 3px #f59e0b1f}.csp-mp-lobby-section{margin-bottom:.65rem}.csp-mp-lobby-section-title{margin:0 0 .45rem;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:#64748b}.csp-mp-lobby-players{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.csp-mp-lobby-player{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .7rem;border-radius:11px;border:1px solid rgba(51,65,85,.75);background:#0f172ab8;min-height:44px;box-sizing:border-box}.csp-mp-lobby-player.is-me{border-color:#f59e0b59;background:#f59e0b0f}.csp-mp-lobby-player-name{font-size:.9rem;font-weight:700;color:#e2e8f0;min-width:0;display:flex;align-items:center;flex-wrap:wrap;gap:.35rem}.csp-mp-lobby-you{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#fbbf24;padding:.12rem .38rem;border-radius:6px;background:#f59e0b1f;border:1px solid rgba(251,191,36,.25)}.csp-mp-lobby-player-badges{display:flex;flex-wrap:wrap;gap:.3rem;justify-content:flex-end;flex-shrink:0}.csp-mp-lobby-badge{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:.15rem .45rem;border-radius:6px;border:1px solid transparent}.csp-mp-lobby-badge--host{color:#fde68a;background:#78350f59;border-color:#fbbf2459}.csp-mp-lobby-badge--ready{color:#86efac;background:#16653447;border-color:#22c55e59}.csp-mp-lobby-badge--away{color:#fbbf24;background:#78350f59;border-color:#f59e0b66;font-size:.65rem}.csp-mp-lobby-meta{margin:0 0 .15rem;font-size:.74rem;color:#64748b;line-height:1.4}.csp-mp-lobby-actions{display:grid;gap:.65rem;margin-top:.85rem}.csp-mp-lobby-actions--host{grid-template-columns:1fr 1fr}.csp-mp-lobby-btn{min-height:48px;padding:.55rem .85rem;border-radius:12px;font-size:.88rem;font-weight:800;cursor:pointer;transition:filter .15s,transform .1s,opacity .15s;border:1px solid transparent;-webkit-tap-highlight-color:transparent}.csp-mp-lobby-btn:disabled{opacity:.42;cursor:not-allowed;transform:none}.csp-mp-lobby-btn--ghost{background:#1e293be6;border-color:#64748b73;color:#e2e8f0}.csp-mp-lobby-btn--ghost:hover:not(:disabled){filter:brightness(1.08);border-color:#94a3b88c}.csp-mp-lobby-btn--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f680;color:#fff;box-shadow:0 4px 18px #2563eb59}.csp-mp-lobby-btn--primary:hover:not(:disabled){filter:brightness(1.06)}@media (max-width: 380px){.csp-mp-lobby-actions--host{grid-template-columns:1fr}.csp-mp-lobby-card{padding:.85rem .75rem 1rem}}@media (min-width: 900px){.csp-mp-lobby-root{max-width:460px}.csp-mp-lobby-actions--host .csp-mp-lobby-btn{max-width:none}}@media (min-width: 1000px){.csp-root.csp-root--mp-lobby-screen{flex-direction:column;flex-wrap:nowrap}}.csp-mp-reset-banner{flex-shrink:0;padding:.5rem .85rem;background:#22c55e1a;border-bottom:1px solid rgba(34,197,94,.2);color:#4ade80;font-size:.85rem;font-weight:600;text-align:center}.csp-mp-reset-banner--draw{background:#93c5fd1f;border-bottom-color:#3b82f647;color:#93c5fd}.csp-draw-bar{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;padding:.5rem .85rem;font-size:.8rem;line-height:1.35;border-bottom:1px solid rgba(255,255,255,.06)}.csp-draw-bar--pending{background:#6366f11f;color:#c7d2fe}.csp-draw-bar--incoming{background:#10b9811a;color:#6ee7b7}.csp-draw-bar-text{flex:1 1 200px;min-width:0;font-weight:600}.csp-draw-bar-actions{display:flex;flex-wrap:wrap;gap:.35rem}.csp-draw-bar-btn{padding:.35rem .75rem;border-radius:8px;font-size:.78rem;font-weight:700;cursor:pointer;border:1px solid rgba(255,255,255,.12);transition:filter .12s}.csp-draw-bar-btn--primary{background:linear-gradient(135deg,#047857,#059669);border-color:#34d399;color:#ecfdf5}.csp-draw-bar-btn--primary:hover{filter:brightness(1.08)}.csp-draw-bar-btn--ghost{background:#0f172abf;color:#e2e8f0}.csp-draw-bar-btn--ghost:hover{filter:brightness(1.15)}.room-draw-badge{background:#3b82f633!important;color:#93c5fd!important}.csp-leave-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) 1rem max(1rem,env(safe-area-inset-bottom,0px));box-sizing:border-box;pointer-events:auto}.csp-leave-overlay--portal{z-index:4500}.csp-leave-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:#02060fb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.csp-leave-dialog{position:relative;z-index:1;width:min(400px,100%);max-height:min(85vh,520px);overflow:auto;background:linear-gradient(165deg,#0f172afa,#080f1efc);border:1px solid rgba(251,191,36,.25);border-radius:16px;padding:1.15rem 1.25rem 1rem;box-shadow:0 24px 48px #0000008c,0 0 0 1px #ffffff0a}.csp-leave-dialog-title{margin:0 0 .65rem;font-size:1.05rem;font-weight:800;color:#f8fafc;letter-spacing:.02em}.csp-leave-dialog-body{font-size:.88rem;line-height:1.5;color:#cbd5e1}.csp-leave-dialog-body p{margin:0 0 .65rem}.csp-leave-dialog-body p:last-child{margin-bottom:0}.csp-leave-dialog-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;margin-top:1.1rem;padding-top:.85rem;border-top:1px solid rgba(255,255,255,.06)}.csp-leave-btn{padding:.5rem 1rem;border-radius:10px;font-size:.88rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:filter .15s,transform .1s}.csp-leave-btn:disabled{opacity:.55;cursor:not-allowed}.csp-leave-btn--ghost{background:#1e293be6;border-color:#94a3b859;color:#e2e8f0}.csp-leave-btn--ghost:hover:not(:disabled){filter:brightness(1.12)}.csp-leave-btn--danger{background:linear-gradient(135deg,#9a3412,#c2410c);border-color:#ea580c;color:#ffedd5}.csp-leave-btn--danger:hover:not(:disabled){filter:brightness(1.08)}.csp-peer-leave-banner{flex-shrink:0;position:relative;padding:.55rem 2.25rem .55rem .85rem;background:#f59e0b1f;border-bottom:1px solid rgba(245,158,11,.28);color:#fcd34d;font-size:.84rem;font-weight:600;line-height:1.4}.csp-peer-leave-text{margin:0}.csp-peer-leave-dismiss{position:absolute;top:.35rem;right:.35rem;width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:8px;background:#00000040;color:#fde68a;font-size:1rem;line-height:1;cursor:pointer}.csp-peer-leave-dismiss:hover{background:#0006}.csp-mp-presence-bar{flex-shrink:0;display:flex;align-items:center;gap:.5rem;padding:.35rem .85rem;background:#3b82f614;border-bottom:1px solid rgba(59,130,246,.2);font-size:.78rem;color:#93c5fd}.csp-mp-presence-label{font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-size:.65rem}.csp-mp-presence-msg{font-weight:600;color:#bfdbfe;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.csp-mp-presence-bar--lobby{margin:0 auto .65rem;max-width:min(520px,100%);border-radius:10px}.csp-mp-hud-scroll{flex-shrink:0;display:flex;gap:.45rem;padding:.45rem max(.85rem,env(safe-area-inset-right,0px)) .45rem max(.85rem,env(safe-area-inset-left,0px));overflow-x:auto;scrollbar-width:none;background:#050f1eb3;border-bottom:1px solid rgba(255,255,255,.04);-webkit-overflow-scrolling:touch}.csp-mp-hud-scroll::-webkit-scrollbar{display:none}.csp-mp-chip{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:3px;padding:.35rem .55rem;border-radius:10px;border:1.5px solid rgba(255,255,255,.07);background:#0f172ab3;min-width:64px;transition:border-color .2s,background .2s,box-shadow .2s;cursor:default}.csp-mp-chip.me{background:#f59e0b14;border-color:#f59e0b47}.csp-mp-chip.active{border-color:#22c55e;box-shadow:0 0 10px #22c55e40}.csp-mp-chip.elim{opacity:.38;filter:grayscale(.6)}.csp-mp-chip.offline{opacity:.55;border-style:dashed;border-color:#f59e0b73}.csp-mp-chip.offline .csp-mp-chip-name:after{content:" · away";font-size:.58rem;font-weight:700;color:#fbbf24;letter-spacing:.02em}.csp-mp-chip-name{font-size:.7rem;font-weight:800;color:#94a3b8;text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.csp-mp-chip.me .csp-mp-chip-name{color:#fbbf24}.csp-mp-chip.active .csp-mp-chip-name{color:#4ade80}.csp-mp-chip-coins{font-size:.82rem;font-weight:800;color:#e2e8f0;display:flex;align-items:center;gap:1px}.csp-mp-chip-dots{display:flex;gap:3px}.csp-mp-dot{width:7px;height:7px;border-radius:50%}.csp-mp-dot.alive{background:#22c55e}.csp-mp-dot.dead{background:#374151}.csp-mp-waiting{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.65rem;padding:1.4rem 1rem;min-height:7rem}.csp-mp-wait-dots{display:flex;gap:6px;align-items:center}.csp-mp-wait-dots span{display:block;width:8px;height:8px;border-radius:50%;background:#334155;animation:csp-dot-bounce 1.4s ease-in-out infinite}.csp-mp-wait-dots span:nth-child(2){animation-delay:.22s}.csp-mp-wait-dots span:nth-child(3){animation-delay:.44s}.csp-mp-wait-msg{margin:0;font-size:.9rem;color:#475569;font-weight:600;text-align:center}.csp-target-list{display:flex;flex-direction:column;gap:.45rem}.csp-target-btn{display:flex;align-items:center;justify-content:space-between;padding:.7rem .85rem;border-radius:12px;border:1.5px solid rgba(251,191,36,.3);background:#78350f40;color:#fde68a;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.csp-target-btn:hover:not(:disabled){border-color:#d97706;background:#78350f73;transform:translate(4px)}.csp-target-btn:disabled{opacity:.3;cursor:not-allowed}.csp-target-name{font-weight:800}.csp-target-detail{font-size:.78rem;font-weight:500;opacity:.7;white-space:nowrap}.csp-spectator-list{display:flex;flex-direction:column;gap:.35rem;margin-top:.25rem}.csp-spectator-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;border-radius:8px;background:#0f172a80;border:1px solid rgba(255,255,255,.05)}.csp-spectator-row.active{border-color:#22c55e4d;background:#22c55e0f}.csp-spec-name{font-size:.85rem;font-weight:700;color:#94a3b8}.csp-spectator-row.active .csp-spec-name{color:#4ade80}.csp-spec-detail{font-size:.78rem;color:#475569}@media (max-width: 360px){.csp-scene{height:clamp(140px,28vh,190px)}.csp-btn-grid:not(.csp-btn-grid--2){gap:.24rem}.csp-btn{min-height:2.5rem;padding:.34rem .28rem;font-size:.6rem}.csp-btn span{font-size:.52rem;max-width:50%}}.fps-mp-root{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e12;font-family:Segoe UI,system-ui,sans-serif;z-index:50}.fps-mp-root--touch{touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.fps-mp-orientation-lock{position:fixed;top:0;right:0;bottom:0;left:0;z-index:12000;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));box-sizing:border-box;background:#020817f7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.fps-mp-orientation-card{padding:1.4rem 1.3rem 1.35rem}.fps-mp-orientation-icon{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:clamp(2rem,8vw,2.5rem);margin-bottom:.85rem;line-height:1}.fps-mp-orientation-arrow{display:inline-block;font-weight:900;color:#60a5fa;animation:fps-mp-orient-tilt 2.5s ease-in-out infinite}@keyframes fps-mp-orient-tilt{0%,to{transform:rotate(0)}35%,65%{transform:rotate(90deg)}}.fps-mp-root--hub-room .fps-mp-lobby{padding-top:calc(env(safe-area-inset-top,0px) + 56px);padding-bottom:max(.75rem,env(safe-area-inset-bottom,0px));padding-left:max(.5rem,env(safe-area-inset-left,0px));padding-right:max(.5rem,env(safe-area-inset-right,0px));box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch;align-items:flex-start;justify-content:center}.fps-mp-root--hub-room .fps-mp-lobby-card{margin-top:auto;margin-bottom:auto}@media (min-height: 640px){.fps-mp-root--hub-room .fps-mp-lobby{align-items:center}}.fps-mp-root--hub-room .fps-mp-leave{top:calc(env(safe-area-inset-top,0px) + 52px)}.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-leave{left:auto;right:max(.65rem,env(safe-area-inset-right,0px));top:calc(max(.45rem,env(safe-area-inset-top,0px)) + 3.15rem)}.fps-mp-lobby{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#e2e8f0}.fps-mp-lobby-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 20%,rgba(59,130,246,.12) 0%,transparent 55%),linear-gradient(180deg,#0c1220,#050810);pointer-events:none}.fps-mp-exit{position:absolute;top:1rem;left:1rem;z-index:2;padding:.45rem 1rem;border-radius:8px;border:1px solid #334155;background:#0f172acc;color:#94a3b8;cursor:pointer}.fps-mp-lobby-card{position:relative;z-index:1;width:min(460px,calc(100vw - 1.25rem));max-width:100%;max-height:min(92dvh,880px);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:2rem;padding-bottom:max(1.75rem,env(safe-area-inset-bottom,0px));border-radius:16px;background:#0f172aeb;border:1px solid rgba(59,130,246,.25);box-shadow:0 20px 50px #00000080;box-sizing:border-box}.fps-mp-lobby-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:1rem;gap:.35rem}.fps-mp-lobby-headline{min-width:0;width:100%}.fps-mp-lobby-hero{font-size:2.5rem;line-height:1;margin:0;text-align:center}.fps-mp-title{text-align:center;margin:0;font-size:clamp(1.2rem,5vw,1.65rem);font-weight:900;letter-spacing:.04em;line-height:1.2;background:linear-gradient(90deg,#60a5fa,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fps-mp-sub{text-align:center;color:#64748b;font-size:clamp(.78rem,3.2vw,.88rem);margin:.4rem 0 0;line-height:1.35}.fps-mp-lobby-columns{display:flex;flex-direction:column;gap:1rem;min-width:0}.fps-mp-lobby-pane{display:flex;flex-direction:column;gap:.85rem;min-width:0}.fps-mp-host-opts{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.fps-mp-host-field{display:flex;flex-direction:column;gap:.25rem;min-width:0}.fps-mp-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#475569}.fps-mp-select{padding:.55rem .65rem;border-radius:8px;border:1px solid #334155;background:#0f172a;color:#e2e8f0;font-size:.95rem;min-height:48px;touch-action:manipulation}.fps-mp-loadout{margin-bottom:1.1rem;display:flex;flex-direction:column;gap:.55rem}.fps-mp-loadout>.fps-mp-label{margin-bottom:.1rem}.fps-mp-class-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.fps-mp-class-btn{padding:.55rem .4rem;border-radius:8px;border:1px solid #334155;background:#0f172a;color:#cbd5e1;font-size:clamp(.72rem,3.2vw,.82rem);font-weight:800;cursor:pointer;min-height:44px;touch-action:manipulation;line-height:1.2}.fps-mp-class-btn--on{border-color:#60a5fa;background:#2563eb40;color:#e0f2fe}.fps-mp-row-class{font-size:.78rem;color:#64748b;font-weight:600}@media (max-width: 640px) and (orientation: portrait){.fps-mp-lobby-card{padding:1.35rem 1.2rem!important;padding-bottom:max(1.5rem,env(safe-area-inset-bottom,0px))!important}.fps-mp-lobby-hero{font-size:2rem}.fps-mp-btn{min-height:52px;font-size:1rem}.fps-mp-actions{flex-direction:column}.fps-mp-select{font-size:.88rem}}@media (max-width: 400px) and (orientation: portrait){.fps-mp-class-grid{grid-template-columns:1fr 1fr;gap:.4rem}.fps-mp-row{flex-direction:column;align-items:flex-start;gap:.35rem}}@media (max-width: 1024px) and (orientation: landscape){.fps-mp-lobby{align-items:flex-start;justify-content:center;padding:max(.35rem,env(safe-area-inset-top,0px)) max(.5rem,env(safe-area-inset-right,0px)) max(.35rem,env(safe-area-inset-bottom,0px)) max(.5rem,env(safe-area-inset-left,0px));overflow-y:auto;-webkit-overflow-scrolling:touch}.fps-mp-lobby-card{width:min(96vw,840px);max-width:100%;max-height:min(94dvh,92vh);margin-inline:auto;padding:1rem 1.2rem;padding-bottom:max(.85rem,env(safe-area-inset-bottom,0px))}.fps-mp-root--hub-room .fps-mp-lobby-card{max-height:min(calc(100dvh - 108px),94dvh)}.fps-mp-lobby-header{flex-direction:row;align-items:center;text-align:left;margin-bottom:.65rem;gap:.65rem 1rem}.fps-mp-lobby-headline{flex:1;min-width:0;text-align:left}.fps-mp-title{text-align:left;font-size:clamp(1rem,3.2vw,1.35rem)}.fps-mp-sub{text-align:left;font-size:clamp(.68rem,2.2vw,.8rem);margin-top:.2rem}.fps-mp-lobby-hero{font-size:2rem;flex-shrink:0}.fps-mp-lobby-columns{flex-direction:row;align-items:stretch;gap:.85rem 1.1rem;min-height:0}.fps-mp-lobby-pane--left,.fps-mp-lobby-pane--right{flex:1 1 0;min-width:0;min-height:0;gap:.55rem}.fps-mp-host-opts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.3rem .45rem;margin-bottom:0}.fps-mp-host-field .fps-mp-label{font-size:.62rem}.fps-mp-host-field .fps-mp-select{font-size:clamp(.68rem,1.8vw,.8rem);min-height:40px;padding:.32rem .4rem}.fps-mp-loadout{margin-bottom:0;gap:.4rem}.fps-mp-loadout>.fps-mp-label{font-size:.62rem}.fps-mp-class-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.3rem}.fps-mp-class-btn{min-height:38px;padding:.3rem .2rem;font-size:clamp(.62rem,1.9vw,.74rem)}.fps-mp-player-list{flex:1 1 auto;min-height:0;max-height:min(38vh,240px);margin-bottom:0}.fps-mp-row{padding:.38rem .55rem;min-height:38px;font-size:clamp(.72rem,2.2vw,.82rem)}.fps-mp-actions{flex-direction:row;flex-wrap:nowrap;margin-top:0;padding-top:0;gap:.45rem}.fps-mp-btn{min-height:44px;padding:.55rem .65rem;font-size:clamp(.78rem,2vw,.88rem)}.fps-mp-hint{margin:.35rem 0 0;font-size:.72rem;text-align:left}}@media (max-width: 1024px) and (orientation: landscape) and (max-height: 430px){.fps-mp-lobby-card{padding:.55rem .75rem .65rem;max-height:min(96dvh,96vh)}.fps-mp-lobby-header{margin-bottom:.45rem}.fps-mp-lobby-hero{font-size:1.55rem}.fps-mp-title{font-size:clamp(.92rem,2.8vw,1.15rem)}.fps-mp-lobby-columns{gap:.55rem .75rem}.fps-mp-host-opts{gap:.22rem .35rem}.fps-mp-host-field .fps-mp-select{min-height:36px;font-size:.65rem}.fps-mp-class-btn{min-height:34px;font-size:.58rem}.fps-mp-player-list{max-height:min(32vh,160px)}}@media (max-width: 1024px) and (orientation: landscape) and (max-width: 640px){.fps-mp-class-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.fps-mp-player-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem;max-height:min(200px,32vh);overflow-y:auto;-webkit-overflow-scrolling:touch}.fps-mp-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.55rem .8rem;min-height:44px;border-radius:8px;background:#1e293b99;border:1px solid rgba(255,255,255,.05);font-size:clamp(.82rem,3vw,.9rem)}.fps-mp-row>span:first-child{min-width:0;overflow-wrap:anywhere;word-break:break-word;padding-right:.35rem}.fps-mp-row>span:last-child{flex-shrink:0}.fps-mp-row .ready{color:#4ade80;font-weight:800}.fps-mp-actions{display:flex;gap:.65rem;margin-top:.35rem;padding-top:.5rem}.fps-mp-btn{flex:1;padding:.85rem;border:none;border-radius:10px;font-weight:800;cursor:pointer;font-size:.95rem}.fps-mp-btn-ready{background:#166534;color:#fff}.fps-mp-btn-start{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.fps-mp-btn-start:disabled{opacity:.45;cursor:not-allowed}.fps-mp-hint{text-align:center;font-size:.8rem;color:#64748b;margin:.75rem 0 0}.fps-mp-hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10}.fps-mp-damage-flash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:44;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(220,38,38,.42) 100%),linear-gradient(180deg,rgba(127,29,29,.22),transparent 50%);opacity:0;transition:opacity .08s ease-out}.fps-mp-damage-flash--on{opacity:1;transition:opacity .05s ease-in}.fps-mp-reload-prompt-btn{pointer-events:auto;margin-top:.4rem;align-self:flex-start;padding:.42rem .95rem;border-radius:8px;border:2px solid rgba(96,165,250,.85);background:linear-gradient(180deg,#2563eb80,#1e40af94);color:#e0f2fe;font-weight:800;font-size:.78rem;letter-spacing:.06em;cursor:pointer;touch-action:manipulation;box-shadow:0 4px 14px #2563eb59}.fps-mp-reload-prompt-btn:active{transform:scale(.98)}.fps-mp-no-ammo-tag{margin-top:.38rem;align-self:flex-start;padding:.35rem .65rem;border-radius:6px;background:#7f1d1d73;border:1px solid rgba(248,113,113,.4);color:#fecaca;font-size:.72rem;font-weight:800;pointer-events:none}.fps-mp-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:22px;height:22px}.fps-mp-ch-h{position:absolute;top:50%;left:0;right:0;height:2px;background:#ffffffbf;transform:translateY(-50%)}.fps-mp-ch-v{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#ffffffbf;transform:translate(-50%)}.fps-mp-ch-dot{position:absolute;top:50%;left:50%;width:4px;height:4px;border-radius:50%;background:#4ade80;transform:translate(-50%,-50%)}.fps-mp-scope{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:6}.fps-mp-scope-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 72% 68% at 50% 50%,transparent 0%,transparent 42%,rgba(0,0,0,.35) 100%)}.fps-mp-scope--sniper .fps-mp-scope-vignette{background:radial-gradient(circle at 50% 50%,transparent 0%,transparent 28%,rgba(0,8,12,.5) 52%,rgba(0,0,0,.92) 100%)}.fps-mp-scope-frame{position:relative;width:min(78vmin,420px);height:min(78vmin,420px);display:flex;align-items:center;justify-content:center}.fps-mp-scope--smg .fps-mp-scope-frame{width:min(62vmin,320px);height:min(62vmin,320px)}.fps-mp-scope--rifle .fps-mp-scope-frame{width:min(70vmin,380px);height:min(70vmin,380px)}.fps-mp-scope--sniper .fps-mp-scope-frame{width:min(88vmin,520px);height:min(88vmin,520px)}.fps-mp-scope--shotgun .fps-mp-scope-frame{width:min(68vmin,360px);height:min(68vmin,360px)}.fps-mp-scope-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid rgba(255,255,255,.22);box-shadow:inset 0 0 0 1px #00000073,0 0 40px #00000059}.fps-mp-scope--smg .fps-mp-scope-ring{border-color:#2dd4bf8c;border-width:2px}.fps-mp-scope--rifle .fps-mp-scope-ring{border-color:#4ade8080;border-width:3px}.fps-mp-scope--sniper .fps-mp-scope-ring{border-color:#94a3b8a6;border-width:4px;box-shadow:inset 0 0 0 2px #0000008c,0 0 0 2px #0f172ae6,0 0 60px #000000a6}.fps-mp-scope--shotgun .fps-mp-scope-ring{border-color:#fbbf2473;border-width:2px}.fps-mp-scope-reticle{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.fps-mp-scope-line{position:absolute;background:#ffffffd1;box-shadow:0 0 4px #0009}.fps-mp-scope-line--h{width:18%;height:2px;left:50%;top:50%;transform:translate(-50%,-50%)}.fps-mp-scope-line--v{width:2px;height:18%;left:50%;top:50%;transform:translate(-50%,-50%)}.fps-mp-scope--sniper .fps-mp-scope-line--h{width:12%}.fps-mp-scope--sniper .fps-mp-scope-line--v{height:12%}.fps-mp-scope-dot{position:absolute;left:50%;top:50%;width:5px;height:5px;border-radius:50%;background:#f87171;transform:translate(-50%,-50%);box-shadow:0 0 6px #f87171bf}.fps-mp-scope--sniper .fps-mp-scope-dot{width:4px;height:4px;background:#fbbf24;box-shadow:0 0 8px #fbbf24e6}.fps-mp-scope--shotgun .fps-mp-scope-dot{background:#fbbf24}.fps-mp-scope-pellet-marks{position:absolute;top:18%;right:18%;bottom:18%;left:18%;pointer-events:none}.fps-mp-scope-pellet-marks span{position:absolute;width:5px;height:5px;border-radius:50%;background:#fbbf2459;border:1px solid rgba(251,191,36,.5)}.fps-mp-scope-pellet-marks span:nth-child(1){top:50%;left:50%;transform:translate(-50%,-50%)}.fps-mp-scope-pellet-marks span:nth-child(2){top:42%;left:48%;transform:translate(-50%,-50%)}.fps-mp-scope-pellet-marks span:nth-child(3){top:42%;left:52%;transform:translate(-50%,-50%)}.fps-mp-scope-pellet-marks span:nth-child(4){top:56%;left:48%;transform:translate(-50%,-50%)}.fps-mp-scope-pellet-marks span:nth-child(5){top:56%;left:52%;transform:translate(-50%,-50%)}.fps-mp-scope-pellet-marks span:nth-child(6){top:50%;left:44%;transform:translate(-50%,-50%)}.fps-mp-desktop-ads-hint{position:absolute;bottom:max(5.25rem,calc(env(safe-area-inset-bottom,0px) + 4.25rem));left:50%;transform:translate(-50%);padding:.28rem .75rem;border-radius:8px;background:#0000006b;border:1px solid rgba(255,255,255,.1);font-size:.68rem;font-weight:700;color:#94a3b8;pointer-events:none;white-space:nowrap;z-index:8}.fps-mp-feed{position:absolute;top:3.5rem;right:1rem;display:flex;flex-direction:column;gap:4px;align-items:flex-end;max-width:min(42vw,200px);pointer-events:none}.fps-mp-root--touch .fps-mp-feed{bottom:calc(max(1rem,env(safe-area-inset-bottom,0px)) + clamp(178px,42vw,275px));max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.fps-mp-root--touch .fps-mp-feed::-webkit-scrollbar{display:none}.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-feed{top:calc(max(.35rem,env(safe-area-inset-top,0px)) + 6.2rem);right:max(.5rem,env(safe-area-inset-right,0px))}@media (max-width: 540px){.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-feed{top:calc(env(safe-area-inset-top,0px) + 7.05rem)}}@media (max-width: 400px){.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-feed{top:calc(env(safe-area-inset-top,0px) + 9.5rem)}}.fps-mp-root--touch:not(.fps-mp-root--hub-room) .fps-mp-feed{top:calc(max(.35rem,env(safe-area-inset-top,0px)) + 5.35rem)}.fps-mp-kill-line{background:#0000008c;padding:4px 12px;border-radius:4px;font-size:.82rem;color:#fbbf24;font-weight:600}.fps-mp-top{position:absolute;top:1rem;left:50%;transform:translate(-50%);text-align:center;max-width:calc(100vw - 2rem);padding:0 .5rem;box-sizing:border-box}.fps-mp-top-cluster{position:absolute;top:calc(env(safe-area-inset-top,0px) + .45rem);left:50%;transform:translate(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:.32rem;width:min(96vw,520px);max-width:calc(100vw - 1.25rem);pointer-events:none;box-sizing:border-box;text-align:center}.fps-mp-root--hub-room .fps-mp-top-cluster{top:calc(env(safe-area-inset-top,0px) + 3.35rem)}@media (max-width: 540px){.fps-mp-root--hub-room .fps-mp-top-cluster{top:calc(env(safe-area-inset-top,0px) + 3.95rem)}}@media (max-width: 400px){.fps-mp-root--hub-room .fps-mp-top-cluster{top:calc(env(safe-area-inset-top,0px) + 6.2rem)}}.fps-mp-top-cluster .fps-mp-top{position:static;transform:none;left:auto;padding:0;margin:0;max-width:100%}.fps-mp-top-cluster .fps-mp-mobile-hint{position:static;transform:none;left:auto;margin:0;max-width:100%}.fps-mp-scores{display:flex;align-items:center;gap:1rem;padding:.4rem 1.2rem;border-radius:10px;background:#0000008c;border:1px solid rgba(255,255,255,.08);font-weight:900;font-size:1rem}.fps-mp-scores .team-a{color:#60a5fa}.fps-mp-scores .team-b{color:#f87171}.fps-mp-vs{color:#475569}.fps-mp-ffa-title{color:#cbd5e1;font-weight:800;letter-spacing:.06em;font-size:.9rem;background:#00000080;padding:.35rem 1rem;border-radius:8px}.fps-mp-map-name{margin-top:.35rem;font-size:.72rem;color:#64748b;text-transform:uppercase;letter-spacing:.12em}.fps-mp-bottom{position:absolute;bottom:1.25rem;left:1.25rem;right:1.25rem;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}.fps-mp-root--touch .fps-mp-bottom{right:auto;max-width:min(52vw,220px);flex-direction:column;align-items:flex-start;gap:.3rem;bottom:calc(max(.85rem,env(safe-area-inset-bottom,0px)) + clamp(132px,32vw,178px));left:max(.65rem,env(safe-area-inset-left,0px))}.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-bottom{bottom:auto;top:calc(env(safe-area-inset-top,0px) + 3.45rem);left:max(.6rem,env(safe-area-inset-left,0px));max-width:min(54vw,232px);z-index:15}@media (max-width: 540px){.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-bottom{top:calc(env(safe-area-inset-top,0px) + 6.1rem)}}@media (max-width: 400px){.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-bottom{top:calc(env(safe-area-inset-top,0px) + 7.4rem)}}.fps-mp-root--touch .fps-mp-hp-val{font-size:1.35rem}.fps-mp-root--touch .fps-mp-hp-bar{width:min(130px,42vw);margin-top:4px}.fps-mp-root--touch .fps-mp-stat{font-size:.72rem;gap:.4rem .55rem;padding:.38rem .55rem;max-width:100%}.fps-mp-hp-val{font-size:1.75rem;font-weight:900;color:#4ade80;line-height:1}.fps-mp-hp-bar{width:140px;height:8px;background:#1e293b;border-radius:4px;margin-top:6px;overflow:hidden;border:1px solid #334155}.fps-mp-hp-fill{height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:3px;transition:width .2s}.fps-mp-stat{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;font-size:.9rem;font-weight:700;color:#94a3b8;background:#00000073;padding:.5rem 1rem;border-radius:8px}.fps-mp-weapon-pill{font-size:.72rem;font-weight:800;letter-spacing:.06em;color:#fcd34d;border:1px solid rgba(252,211,77,.35);padding:.2rem .5rem;border-radius:6px;background:#00000059}.fps-mp-ammo{font-size:.85rem;color:#e2e8f0;font-weight:800;letter-spacing:.04em}.fps-mp-ammo-sep{margin:0 .25rem;color:#64748b;font-weight:600}.fps-mp-ammo--empty{color:#f87171}.fps-mp-reload-timer{color:#93c5fd;font-weight:700;font-size:.78rem}.fps-mp-ads-touch{position:absolute;bottom:calc(max(1.25rem,env(safe-area-inset-bottom,0px)) + clamp(88px,22vw,118px) + .65rem);right:calc(max(.75rem,env(safe-area-inset-right,0px)) + (clamp(88px,22vw,118px) - clamp(52px,15vw,74px))/2 + clamp(52px,15vw,74px) + .55rem);width:clamp(52px,15vw,74px);height:clamp(52px,15vw,74px);border-radius:50%;pointer-events:auto;touch-action:none;-webkit-tap-highlight-color:transparent;border:3px solid rgba(125,211,252,.55);background:radial-gradient(circle at 35% 35%,#7dd3fc47,#0c4a6e8c);color:#e0f2fe;font-weight:900;font-size:clamp(.58rem,2.6vw,.78rem);letter-spacing:.04em;box-shadow:0 0 16px #38bdf847;z-index:30}.fps-mp-ads-touch--on{border-color:#38bdf8f2;background:radial-gradient(circle at 35% 35%,#38bdf873,#0c4a6eb8);box-shadow:0 0 22px #38bdf873}.fps-mp-root--touch .fps-mp-ads-touch{bottom:calc(max(1.25rem,env(safe-area-inset-bottom,0px)) + clamp(88px,22vw,118px) + 1rem)}.fps-mp-reload-touch{position:absolute;bottom:calc(max(1.25rem,env(safe-area-inset-bottom,0px)) + clamp(88px,22vw,118px) + .65rem);right:calc(max(.75rem,env(safe-area-inset-right,0px)) + (clamp(88px,22vw,118px) - clamp(52px,15vw,74px))/2);width:clamp(52px,15vw,74px);height:clamp(52px,15vw,74px);border-radius:50%;pointer-events:auto;touch-action:none;-webkit-tap-highlight-color:transparent;border:3px solid rgba(59,130,246,.75);background:radial-gradient(circle at 35% 35%,#60a5fa66,#1e3a8a8c);color:#e0f2fe;font-weight:900;font-size:clamp(.65rem,3vw,.85rem);box-shadow:0 0 18px #3b82f659;z-index:30}.fps-mp-root--touch .fps-mp-reload-touch{bottom:calc(max(1.25rem,env(safe-area-inset-bottom,0px)) + clamp(88px,22vw,118px) + 1rem)}.fps-mp-spec-tag{position:absolute;top:3.5rem;left:50%;transform:translate(-50%);background:#8b5cf659;border:1px solid #a78bfa;color:#e9d5ff;padding:.35rem 1rem;border-radius:999px;font-weight:800;font-size:.8rem}.fps-mp-root--hub-room.fps-mp-root--touch .fps-mp-spec-tag{top:calc(max(.45rem,env(safe-area-inset-top,0px)) + 5.35rem)}.fps-mp-mobile{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:90}.fps-mp-mobile-hint{position:absolute;top:max(.4rem,env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);pointer-events:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.25rem .35rem;row-gap:.2rem;padding:.32rem .75rem;border-radius:999px;background:#00000073;border:1px solid rgba(255,255,255,.08);font-size:clamp(.55rem,1.9vw,.62rem);font-weight:800;letter-spacing:.05em;color:#94a3b8;max-width:min(96vw,520px);text-align:center;line-height:1.35;z-index:1}.fps-mp-hint-move{color:#4ade80}.fps-mp-hint-fire{color:#f87171}.fps-mp-hint-ads{color:#7dd3fc;font-weight:900}.fps-mp-hint-mid{color:#64748b}.fps-mp-look-drag{position:absolute;top:0;right:0;width:min(72vw,320px);height:min(42vh,220px);pointer-events:auto;touch-action:none;z-index:8}.fps-mp-zone{position:absolute;pointer-events:auto;touch-action:none;z-index:25;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:0}.fps-mp-zone-label{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);font-size:.55rem;font-weight:900;letter-spacing:.12em;color:#ffffff6b;pointer-events:none;white-space:nowrap}.fps-mp-zone--move{bottom:max(1rem,env(safe-area-inset-bottom,0px));left:max(.75rem,env(safe-area-inset-left,0px))}.fps-mp-zone--look{bottom:max(1rem,env(safe-area-inset-bottom,0px));right:max(10.5rem,calc(env(safe-area-inset-right,0px) + clamp(9.5rem,28vw,11.5rem)))}.fps-mp-look-level{pointer-events:auto;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:36px;min-width:clamp(72px,20vw,108px);padding:0 10px;margin-bottom:2px;border-radius:8px;border:1px solid rgba(96,165,250,.55);background:#0f172aeb;color:#93c5fd;font-weight:800;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;box-shadow:0 0 12px #3b82f633}.fps-mp-fire{position:absolute;bottom:max(1.25rem,env(safe-area-inset-bottom,0px));right:max(.75rem,env(safe-area-inset-right,0px));width:clamp(88px,22vw,118px);height:clamp(88px,22vw,118px);border-radius:50%;pointer-events:auto;touch-action:none;-webkit-tap-highlight-color:transparent;border:4px solid rgba(239,68,68,.75);background:radial-gradient(circle at 35% 35%,#f8717173,#7f1d1d8c);color:#fff;font-weight:900;font-size:clamp(.85rem,3.5vw,1.05rem);box-shadow:0 0 24px #ef444459;z-index:30}.fps-mp-click-capture{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;cursor:crosshair;background:transparent;border:none;padding:0}.fps-mp-end{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#05080ee0;color:#e2e8f0;pointer-events:auto}.fps-mp-end h2{margin:0 0 .5rem;font-size:2rem}.fps-mp-end-btns{display:flex;gap:1rem;margin-top:1.5rem}.fps-mp-end-btns button{padding:.75rem 1.5rem;border-radius:10px;border:none;font-weight:800;cursor:pointer;background:#2563eb;color:#fff}.fps-mp-dead{position:absolute;top:0;right:0;bottom:0;left:0;z-index:25;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#7f1d1d40;color:#fecaca;pointer-events:none;font-weight:900;font-size:1.5rem}.fps-mp-dead span{font-size:.95rem;opacity:.85;margin-top:.5rem}.fps-mp-leave{position:absolute;top:max(.65rem,env(safe-area-inset-top,0px));left:max(.65rem,env(safe-area-inset-left,0px));z-index:95;pointer-events:auto;padding:.55rem 1rem;min-height:44px;border-radius:10px;border:1px solid #475569;background:#0f172ae0;color:#e2e8f0;cursor:pointer;font-weight:700;touch-action:manipulation}.fps-mp-connecting{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);color:#94a3b8;font-size:.85rem;z-index:35}@media (max-width: 1024px) and (orientation: landscape){.room-comms-wrapper.room-comms-wrapper--fps-mp-touch:not(.compact){top:calc(env(safe-area-inset-top,0px) + 9.5rem);bottom:auto!important;left:max(8px,env(safe-area-inset-left,0px))!important;right:auto!important}.room-comms-wrapper.room-comms-wrapper--fps-mp-touch:not(.compact) .room-comms-panel:not(.compact){top:calc(env(safe-area-inset-top,0px) + 13.25rem);bottom:auto!important;left:max(8px,env(safe-area-inset-left,0px))!important;right:auto!important;width:min(360px,calc(100vw - 20px))!important;max-height:min(42vh,300px);overflow-y:auto}}@media (max-width: 1024px) and (orientation: landscape) and (max-width: 540px){.room-comms-wrapper.room-comms-wrapper--fps-mp-touch:not(.compact){top:calc(env(safe-area-inset-top,0px) + 12.35rem)}.room-comms-wrapper.room-comms-wrapper--fps-mp-touch:not(.compact) .room-comms-panel:not(.compact){top:calc(env(safe-area-inset-top,0px) + 16.1rem)}}@media (max-width: 1024px) and (orientation: landscape) and (max-width: 400px){.room-comms-wrapper.room-comms-wrapper--fps-mp-touch:not(.compact){top:calc(env(safe-area-inset-top,0px) + 13.65rem)}.room-comms-wrapper.room-comms-wrapper--fps-mp-touch:not(.compact) .room-comms-panel:not(.compact){top:calc(env(safe-area-inset-top,0px) + 17.4rem)}}.fps-zombie-root--touch{touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.fps-zombie-mobile{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:100}.fps-zombie-mobile-hint{position:absolute;top:calc(max(.35rem,env(safe-area-inset-top,0px)) + 46px);left:50%;transform:translate(-50%);display:flex;flex-wrap:wrap;justify-content:center;gap:.2rem;padding:.2rem .55rem;border-radius:999px;background:#00000073;border:1px solid rgba(200,160,32,.2);font-size:.58rem;font-weight:800;letter-spacing:.05em;color:#94a3b8;max-width:min(92vw,340px);text-align:center;z-index:1;pointer-events:none}.fps-zombie-hint-move{color:#4ade80}.fps-zombie-hint-fire{color:#f87171}.fps-zombie-hint-mid{color:#78716c}.fps-zombie-look-drag{position:absolute;top:0;right:0;width:min(72vw,320px);height:min(42vh,220px);pointer-events:auto;touch-action:none;z-index:8}.fps-zombie-pause-open{position:absolute;top:max(.65rem,env(safe-area-inset-top,0px));left:max(.65rem,env(safe-area-inset-left,0px));z-index:110;pointer-events:auto;padding:.45rem .75rem;min-height:44px;min-width:44px;border-radius:10px;border:1px solid rgba(200,160,32,.65);background:#19160ce0;color:#e8c84a;font-weight:800;font-size:.78rem;letter-spacing:.04em;touch-action:manipulation;cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 0 14px #c8a02033}.fps-zombie-reload-touch{position:absolute;bottom:calc(max(1rem,env(safe-area-inset-bottom,0px)) + clamp(5.5rem,24vw,7.25rem));right:max(.65rem,env(safe-area-inset-right,0px));width:clamp(48px,13vw,68px);height:clamp(48px,13vw,68px);border-radius:50%;pointer-events:auto;touch-action:none;-webkit-tap-highlight-color:transparent;border:3px solid rgba(59,130,246,.75);background:radial-gradient(circle at 35% 35%,#60a5fa66,#1e3a8a8c);color:#e0f2fe;font-weight:900;font-size:clamp(.6rem,2.8vw,.78rem);box-shadow:0 0 16px #3b82f659;z-index:32}.fps-zombie-fire{position:absolute;bottom:max(.85rem,env(safe-area-inset-bottom,0px));right:max(.65rem,env(safe-area-inset-right,0px));width:clamp(76px,19vw,104px);height:clamp(76px,19vw,104px);border-radius:50%;pointer-events:auto;touch-action:none;-webkit-tap-highlight-color:transparent;border:4px solid rgba(220,38,38,.75);background:radial-gradient(circle at 35% 35%,#f8717173,#7f1d1d8c);color:#fff;font-weight:900;font-size:clamp(.72rem,3.2vw,.95rem);box-shadow:0 0 20px #dc262659;z-index:31}.fps-zombie-zone{position:absolute;pointer-events:auto;touch-action:none;z-index:28;display:flex;flex-direction:column;align-items:center;gap:4px}.fps-zombie-zone-label{font-size:.58rem;font-weight:900;letter-spacing:.12em;color:#ffffff59}.fps-zombie-look-level{pointer-events:auto;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:36px;min-width:clamp(72px,20vw,100px);padding:0 10px;border-radius:8px;border:1px solid rgba(200,160,32,.55);background:#231e12e6;color:#d4b85c;font-weight:800;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;box-shadow:0 0 12px #c8a02026}.fps-zombie-zone--move{bottom:max(.85rem,env(safe-area-inset-bottom,0px));left:max(.65rem,env(safe-area-inset-left,0px))}.fps-zombie-zone--look{bottom:max(.85rem,env(safe-area-inset-bottom,0px));right:calc(max(.65rem,env(safe-area-inset-right,0px)) + clamp(5.5rem,24vw,7.25rem) + clamp(3.5rem,16vw,5rem))}.fps-hud-layer--touch .fps-hud-top-center{top:max(6px,env(safe-area-inset-top,0px))!important;padding:5px 14px!important;font-size:12px!important;letter-spacing:.12em!important;max-width:min(calc(100vw - 7rem),280px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fps-hud-layer--touch .fps-hud-killfeed{top:max(6px,env(safe-area-inset-top,0px))!important;right:max(8px,env(safe-area-inset-right,0px))!important;max-width:38vw}.fps-hud-layer--touch .fps-hud-killfeed>div{font-size:11px!important;padding:2px 6px!important}.fps-hud-layer--touch .fps-hud-bottom-center{top:max(42px,calc(env(safe-area-inset-top,0px) + 34px))!important;bottom:auto!important;left:auto!important;right:max(8px,env(safe-area-inset-right,0px))!important;transform:none!important;font-size:12px!important}.fps-hud-layer--touch .fps-hud-bottom-left{bottom:max(.75rem,env(safe-area-inset-bottom,0px))!important;left:max(.5rem,env(safe-area-inset-left,0px))!important;transform:scale(.82);transform-origin:bottom left}.fps-hud-layer--touch .fps-hud-bottom-right{bottom:calc(max(.85rem,env(safe-area-inset-bottom,0px)) + clamp(10.5rem,46vw,13.5rem))!important;right:max(.55rem,env(safe-area-inset-right,0px))!important;transform:none!important;padding:6px 12px!important;min-width:0}.fps-hud-layer--touch .fps-hud-ammo-label{font-size:9px!important;margin-bottom:2px!important}.fps-hud-layer--touch .fps-hud-ammo-mag{font-size:26px!important}.fps-hud-layer--touch .fps-hud-ammo-res{font-size:13px!important}.fps-hud-layer--touch .fps-hud-ammo-reload{font-size:9px!important}@media (max-width: 480px){.fps-zombie-zone--look{right:calc(max(.55rem,env(safe-area-inset-right,0px)) + clamp(5rem,22vw,6.5rem) + clamp(3.25rem,15vw,4.5rem))}.fps-hud-layer--touch .fps-hud-bottom-right{bottom:calc(max(.85rem,env(safe-area-inset-bottom,0px)) + clamp(9.5rem,44vw,12.5rem))!important}}.fps-zombie-gameover{padding:max(.5rem,env(safe-area-inset-top,0px)) max(.65rem,env(safe-area-inset-right,0px)) max(.75rem,env(safe-area-inset-bottom,0px)) max(.65rem,env(safe-area-inset-left,0px));box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;padding-top:max(1rem,env(safe-area-inset-top,0px))}.fps-zombie-gameover-actions{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:center;width:100%;max-width:440px;padding:0 .5rem;margin-top:.25rem;margin-bottom:env(safe-area-inset-bottom,0px)}.fps-zombie-gameover-actions button{flex:1 1 min(160px,42vw);min-height:48px}@media (max-height: 520px){.fps-zombie-gameover-skull{font-size:36px!important;margin-bottom:2px!important}.fps-zombie-gameover-title{font-size:1.65rem!important;margin-bottom:4px!important}.fps-zombie-gameover-sub{font-size:14px!important;margin-bottom:2px!important}.fps-zombie-gameover-scorebox{margin-bottom:12px!important;padding:10px 16px!important;width:min(300px,90vw)!important}.fps-zombie-gameover-scoreval{font-size:34px!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}
