.app{position:relative;width:100%;height:100%;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;background:radial-gradient(circle at 50% 50%,#0b1230,#04050e 70%);touch-action:none;overscroll-behavior:none}canvas{display:block;touch-action:none}.hud{position:absolute;top:max(18px,env(safe-area-inset-top));left:max(18px,env(safe-area-inset-left));right:max(18px,env(safe-area-inset-right));display:flex;gap:12px;align-items:center;pointer-events:none;z-index:10;flex-wrap:wrap}.hud-title{font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:13px;color:#c7cbe8;padding:8px 14px;border:1px solid rgba(255,255,255,.08);background:#0c0e208c;border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.players{display:flex;gap:8px;flex-wrap:wrap;pointer-events:auto}.player{--c: #ffffff;display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#0a0c1ab3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:13px;font-weight:500;color:#b8bcdb;transition:transform .2s ease,opacity .25s ease,border-color .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease;position:relative}.player.current{transform:translateY(-3px) scale(1.08);border-color:var(--c);color:#fff;background:color-mix(in srgb,var(--c) 18%,rgba(10,12,26,.88));box-shadow:0 0 0 1px var(--c),0 0 22px color-mix(in srgb,var(--c) 55%,transparent),0 6px 18px #00000080;animation:turn-pulse 1.8s ease-in-out infinite}@keyframes turn-pulse{0%,to{box-shadow:0 0 0 1px var(--c),0 0 14px color-mix(in srgb,var(--c) 40%,transparent),0 6px 18px #00000080}50%{box-shadow:0 0 0 2px var(--c),0 0 34px color-mix(in srgb,var(--c) 70%,transparent),0 6px 22px #0000008c}}.player .caret{color:var(--c);font-size:14px;line-height:1;animation:caret-nudge 1.4s ease-in-out infinite;text-shadow:0 0 8px currentColor}@keyframes caret-nudge{0%,to{transform:translate(0)}50%{transform:translate(3px)}}.player.out{opacity:.32;text-decoration:line-through;filter:grayscale(.8)}.player .dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 10px currentColor}.player.current .dot{box-shadow:0 0 14px var(--c)}.player .count{background:#ffffff14;padding:2px 8px;border-radius:999px;font-variant-numeric:tabular-nums;min-width:24px;text-align:center}.player.current .count{background:color-mix(in srgb,var(--c) 30%,rgba(255,255,255,.1));color:#fff}.player .you-tag{background:#ffffffe6;color:#05060f;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:4px}.player.mine .name:after{content:none}.turn-status{padding:8px 14px;border-radius:999px;background:#0a0c1abf;border:1px solid rgba(255,255,255,.1);color:#c7cbe8;font-size:12px;font-weight:500;letter-spacing:.06em;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fade-in .2s ease}.turn-status.own{background:color-mix(in srgb,var(--c) 22%,rgba(10,12,26,.85));border-color:var(--c);color:#fff;box-shadow:0 0 20px color-mix(in srgb,var(--c) 45%,transparent)}.actions{margin-left:auto;display:flex;gap:6px;pointer-events:auto}.icon-btn{background:#ffffff0a;color:#d6d9ef;border:1px solid rgba(255,255,255,.12);width:34px;height:34px;border-radius:999px;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,transform .15s ease,opacity .2s ease}.icon-btn:hover:not(:disabled){background:#ffffff1f;transform:translateY(-1px)}.icon-btn:disabled{opacity:.28;cursor:not-allowed}.reset{pointer-events:auto;background:#ffffff0a;color:#d6d9ef;border:1px solid rgba(255,255,255,.12);padding:8px 16px;border-radius:999px;transition:background .15s ease,transform .15s ease}.reset:hover{background:#ffffff1a;transform:translateY(-1px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:safe center;padding:20px;background:#03040eb8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:40;animation:fade-in .3s ease both;overflow-y:auto;overscroll-behavior:contain;touch-action:pan-y;pointer-events:auto;-webkit-overflow-scrolling:touch}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:linear-gradient(160deg,#121636,#0a0b1f);border:1px solid rgba(255,255,255,.08);padding:36px 44px 30px;border-radius:22px;text-align:center;min-width:min(320px,100%);max-width:100%;position:relative;animation:modal-pop .35s cubic-bezier(.2,.9,.3,1.3) both;box-sizing:border-box}@keyframes modal-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.modal-label{text-transform:uppercase;letter-spacing:.18em;font-size:11px;color:#8a8fb5;margin-bottom:8px}.modal-name{font-size:44px;font-weight:700;letter-spacing:.02em;margin-bottom:22px;text-shadow:0 0 30px currentColor}.match-duration{display:inline-flex;align-items:baseline;gap:8px;padding:6px 14px;margin:-8px auto 18px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.match-duration-label{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#8a8fb5}.match-duration-value{font-size:15px;font-weight:700;color:#f4f5fa;font-variant-numeric:tabular-nums}.modal button{border:none;padding:10px 22px;color:#05060f;font-weight:600;border-radius:999px;letter-spacing:.06em;text-transform:uppercase;font-size:12px;transition:transform .15s ease,box-shadow .2s ease}.modal button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0006}.modal-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.modal-actions .ghost-btn{background:transparent;border:1px solid rgba(255,255,255,.16);color:#c7cbe8;padding:10px 22px}.rematch-status{color:#c7cbe8;font-size:13px;margin-bottom:18px}.rematch-dots{display:flex;gap:6px;justify-content:center;margin-top:8px}.rematch-dot{width:10px;height:10px;border-radius:50%;background:#ffffff26;transition:background .25s ease,box-shadow .25s ease}.rematch-dot.on{background:#66e07a;box-shadow:0 0 10px #66e07a8c}.share-backdrop{z-index:25}.share-sheet{min-width:340px;max-width:calc(100% - 32px)}.share-preview{margin:12px auto 18px;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.1);max-width:260px;aspect-ratio:4 / 3;background:#0a0b1f}.share-preview img{width:100%;height:100%;object-fit:cover;display:block}.share-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.share-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.14);color:#f4f5fa;padding:12px 8px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .15s ease}.share-btn:hover:not(:disabled){background:#ffffff24;transform:translateY(-2px)}.share-btn:disabled{opacity:.45;cursor:not-allowed}.share-ico{width:34px;height:34px;border-radius:10px;background:#ffffff14;display:inline-flex;align-items:center;justify-content:center;font-size:18px}.share-ico.share-x{background:#0f1320;color:#fff;font-family:serif}.share-ico.share-fb{background:#1877f2;color:#fff;font-weight:800;font-family:Georgia,serif}.share-ico.share-wa{background:#25d366;color:#fff;font-size:20px}.share-hint{color:#8a8fb5;font-size:11px;line-height:1.4;text-align:center;margin-bottom:8px}.landing{position:relative;width:100%;height:100%;overflow-y:auto;overflow-x:hidden;color:#e9ecf7;-webkit-overflow-scrolling:touch}.landing-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(1px 1px at 12% 18%,rgba(255,255,255,.5),transparent 60%),radial-gradient(1px 1px at 28% 72%,rgba(255,255,255,.35),transparent 60%),radial-gradient(1px 1px at 48% 22%,rgba(255,255,255,.4),transparent 60%),radial-gradient(1px 1px at 62% 58%,rgba(255,255,255,.3),transparent 60%),radial-gradient(1px 1px at 78% 16%,rgba(255,255,255,.5),transparent 60%),radial-gradient(1px 1px at 88% 82%,rgba(255,255,255,.4),transparent 60%),radial-gradient(1.5px 1.5px at 35% 90%,rgba(255,255,255,.45),transparent 60%),radial-gradient(1.5px 1.5px at 72% 36%,rgba(255,255,255,.5),transparent 60%),#05060f;z-index:-1}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:22px clamp(16px,4vw,56px);position:sticky;top:0;background:linear-gradient(180deg,rgba(5,6,15,.85),transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:5}.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:#fff}.brand-dot{width:12px;height:12px;border-radius:50%;background:#ff3b6b;box-shadow:0 0 14px #ff3b6b}.nav-link{color:#c7cbe8;text-decoration:none;font-size:13px;letter-spacing:.08em;transition:color .15s ease}.nav-link:hover{color:#fff}.hero{display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:center;padding:clamp(32px,6vw,72px) clamp(16px,4vw,56px) clamp(48px,8vw,96px);max-width:1200px;margin:0 auto}.kicker{font-size:11px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#8a8fb5;margin-bottom:18px}.hero h1{margin:0 0 18px;font-size:clamp(36px,6vw,64px);font-weight:800;letter-spacing:-.025em;line-height:1.02;background:linear-gradient(180deg,#fff,#b9beda);-webkit-background-clip:text;background-clip:text;color:transparent}.lede{color:#b8bcdb;font-size:clamp(15px,1.6vw,17px);line-height:1.55;max-width:540px;margin:0 0 28px}.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}.primary-cta{position:relative;background:#fff;color:#05060f;border:none;padding:18px 38px;border-radius:999px;font-size:16px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:transform .2s cubic-bezier(.2,.9,.3,1.4),box-shadow .25s ease,background .2s ease;box-shadow:0 12px 30px #ffffff2e,0 0 0 1px #ffffff40 inset;animation:cta-pulse 2.8s ease-in-out infinite}.primary-cta:after{content:"→";margin-left:10px;display:inline-block;transition:transform .2s ease}.primary-cta:hover{transform:translateY(-3px) scale(1.03);background:#f2f4ff;box-shadow:0 18px 44px #ffffff47,0 0 0 1px #ffffff4d inset}.primary-cta:hover:after{transform:translate(4px)}@keyframes cta-pulse{0%,to{box-shadow:0 12px 30px #ffffff2e,0 0 0 1px #ffffff40 inset,0 0 #fff0}50%{box-shadow:0 14px 36px #ffffff52,0 0 0 1px #fff6 inset,0 0 0 12px #fff0}}.secondary-cta{background:transparent;color:#e9ecf7;border:1px solid rgba(255,255,255,.22);padding:13px 22px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .15s ease,border-color .15s ease}.secondary-cta:hover{background:#ffffff0f;border-color:#fff6}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);padding:5px 12px;border-radius:999px;font-size:12px;color:#c7cbe8;letter-spacing:.04em}.hero-art{position:relative;aspect-ratio:1 / 1;max-width:460px;justify-self:end}.hero-svg{width:100%;height:100%;filter:drop-shadow(0 20px 40px rgba(0,0,0,.5))}.hero-spin{transform-box:fill-box;transform-origin:center;animation:hero-spin 12s linear infinite}.hero-spin.spin-a{animation-duration:10s}.hero-spin.spin-b{animation-duration:14s;animation-direction:reverse}.hero-spin.spin-c{animation-duration:16s}@keyframes hero-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-atom{animation:hero-breathe 3.2s ease-in-out infinite}.hero-atom:nth-child(2){animation-delay:.7s}.hero-atom:nth-child(3){animation-delay:1.4s}@keyframes hero-breathe{0%,to{filter:brightness(1)}50%{filter:brightness(1.25)}}.hero-halo{animation:hero-halo 4s ease-in-out infinite;transform-box:fill-box;transform-origin:center}.hero-halo.halo-slow{animation-duration:6s;animation-delay:1s}@keyframes hero-halo{0%,to{opacity:.35;transform:scale(1)}50%{opacity:.6;transform:scale(1.12)}}.hero-bob{animation:hero-bob 3s ease-in-out infinite}@keyframes hero-bob{0%,to{transform:translateY(-2px)}50%{transform:translateY(2px)}}:root{--hero-cycle: 6s}.hero-core{transform-box:fill-box;transform-origin:center;animation:hero-core var(--hero-cycle) cubic-bezier(.35,.1,.5,1.2) infinite}@keyframes hero-core{0%,50%{opacity:1;transform:scale(1);filter:brightness(1)}53%{opacity:1;transform:scale(1.4);filter:brightness(1.8)}60%,92%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.hero-blast-ring{fill:none;stroke-width:3;opacity:0;transform-box:fill-box;transform-origin:center;animation:hero-blast-ring var(--hero-cycle) ease-out infinite}@keyframes hero-blast-ring{0%,50%,to{transform:scale(.3);opacity:0;stroke-width:3}52%{opacity:.9;stroke-width:3}68%{transform:scale(3.4);opacity:0;stroke-width:.5}}.hero-shrapnel{animation:hero-shrapnel var(--hero-cycle) cubic-bezier(.25,.9,.3,1) infinite;transform-box:fill-box;transform-origin:center;opacity:0}@keyframes hero-shrapnel{0%,50%{opacity:0;transform:translate(0) scale(.8)}52%{opacity:1;transform:translate(0) scale(1)}65%{opacity:1;transform:translate(var(--dx),var(--dy)) scale(1)}94%{opacity:1;transform:translate(var(--dx),var(--dy)) scale(1)}to{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.9)}}.hero-enemy{animation:hero-enemy var(--hero-cycle) ease-in-out infinite}@keyframes hero-enemy{0%,55%{opacity:1;transform:scale(1)}62%{opacity:.2;transform:scale(.4)}68%,95%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}.hero-enemy{transform-box:fill-box;transform-origin:center}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;padding:0 clamp(16px,4vw,56px);max-width:1200px;margin:0 auto 80px}.feature{background:#ffffff08;border:1px solid rgba(255,255,255,.08);padding:24px;border-radius:18px;transition:transform .2s ease,background .2s ease}.feature:hover{transform:translateY(-3px);background:#ffffff0f}.feature-icon{font-size:28px;margin-bottom:12px}.feature-title{font-size:17px;font-weight:700;margin-bottom:6px;color:#fff}.feature-desc{font-size:13px;line-height:1.55;color:#b8bcdb}.howto{padding:0 clamp(16px,4vw,56px);max-width:900px;margin:0 auto 96px}.howto-title{text-align:center;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:#8a8fb5;margin-bottom:24px}.howto-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.step{display:flex;gap:14px;align-items:flex-start;background:#ffffff06;border:1px solid rgba(255,255,255,.06);padding:18px;border-radius:14px}.step-n{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#ff3b6b,#c477ff);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.step-title{font-weight:700;color:#fff;margin-bottom:4px;font-size:14px}.step-desc{color:#b8bcdb;font-size:13px;line-height:1.5}.closing{text-align:center;padding:48px clamp(16px,4vw,56px) 64px;max-width:700px;margin:0 auto}.closing h2{font-size:clamp(26px,4vw,40px);font-weight:800;letter-spacing:-.02em;margin:0 0 10px;color:#fff}.closing p{color:#b8bcdb;margin:0 0 24px;font-size:15px}.landing-footer{display:flex;justify-content:space-between;align-items:center;padding:18px clamp(16px,4vw,56px);border-top:1px solid rgba(255,255,255,.05);color:#6a6f92;font-size:12px}@media (max-width: 820px){.hero{grid-template-columns:1fr;gap:32px;text-align:left}.hero-art{max-width:320px;justify-self:center}}.modal.htp{width:100%;max-width:480px;text-align:left;padding:28px 32px 64px;position:relative;touch-action:pan-y;overflow-x:hidden}.modal button.modal-close{position:absolute;top:10px;right:10px;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#fff;font-size:22px;font-weight:400;text-transform:none;letter-spacing:0;padding:0;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:2;touch-action:manipulation}.modal button.modal-close:hover,.modal button.modal-close:active{background:#fff3;transform:none;box-shadow:none}.modal.htp .modal-label{text-align:center}.kicked-backdrop{z-index:1000}.kicked-modal{text-align:center;max-width:360px}.kicked-modal .sub{margin:8px 0 20px}.modal button.help-link{display:inline-block;align-self:center;background:transparent;border:none;border-radius:0;color:#fff;font-size:13px;font-weight:500;letter-spacing:.02em;text-transform:none;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#fff9;margin:14px auto 0;padding:4px 8px;cursor:pointer;transition:color .15s ease,text-decoration-color .15s ease;box-shadow:none}.modal button.help-link:hover{color:#fff;text-decoration-color:#fff;transform:none;box-shadow:none}.htp-section{display:flex;gap:14px;margin-bottom:20px}.htp-step{width:30px;height:30px;border-radius:50%;background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.htp-body{flex:1;min-width:0}.htp-body h3{margin:3px 0 4px;font-size:15px;font-weight:600;color:#fff}.htp-body p{margin:0 0 8px;font-size:13px;color:#b8bcdb;line-height:1.5}.htp-body .dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle;margin:0 2px 2px 0;box-shadow:0 0 6px currentColor}.htp-diagram{margin-top:8px;display:flex;justify-content:center}.htp-svg{width:160px;max-width:100%;height:auto}.htp-svg-wide{height:44px;width:auto;max-width:100%;flex-shrink:1;min-width:0}.htp-seq{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:6px}.htp-arrow{color:#8a8fb5;font-size:18px;font-weight:300}.admin-page{width:100%;height:100%;overflow-y:auto;padding:32px clamp(16px,4vw,48px);background:radial-gradient(circle at 20% 20%,#0c1236,#04050e 70%);color:#e3e6f3}.admin-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:28px;gap:16px;flex-wrap:wrap}.admin-kicker{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#8a8fb5}.admin-header h1{margin:4px 0 0;font-size:26px;letter-spacing:-.01em}.admin-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:28px}.admin-stat{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 16px}.admin-stat-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#8a8fb5;margin-bottom:6px}.admin-stat-value{font-size:24px;font-weight:700;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.admin-section{margin-bottom:32px}.admin-section h2{font-size:14px;text-transform:uppercase;letter-spacing:.18em;color:#8a8fb5;margin:0 0 12px;font-weight:600}.admin-wins{display:flex;flex-wrap:wrap;gap:8px}.admin-win{display:flex;align-items:center;gap:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);padding:6px 12px;border-radius:999px;font-size:13px}.admin-win .count{background:#ffffff14;padding:1px 8px;border-radius:999px;font-weight:700;font-size:12px}.admin-empty{color:#6a6f92;font-size:14px;padding:24px 0}.admin-table{background:#ffffff06;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;font-size:13px}.admin-tr{display:grid;grid-template-columns:90px 120px 90px 70px minmax(160px,2fr) 70px 70px 60px minmax(100px,1fr);gap:8px;padding:10px 14px;align-items:center;border-bottom:1px solid rgba(255,255,255,.05)}.admin-tr:last-child{border-bottom:none}.admin-tr.head{background:#ffffff0a;color:#8a8fb5;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}.admin-tr .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.08em;color:#fff}.admin-tr .status{padding:2px 8px;border-radius:999px;background:#ffffff0f;font-size:11px;text-align:center;text-transform:uppercase;letter-spacing:.08em;justify-self:start}.admin-tr .status.lobby{color:#ffd0a0;background:#ffb84d26}.admin-tr .status.playing{color:#a8e9ff;background:#4dd0ff26}.admin-tr .status.ended{color:#b6f7c0;background:#66e07a2e}@media (max-width: 900px){.admin-tr{grid-template-columns:1fr 1fr;row-gap:6px}.admin-tr.head{display:none}.admin-tr span:before{content:attr(data-label)}}.inline-toast{margin-top:14px;background:#66e07a2e;border:1px solid rgba(102,224,122,.5);color:#b6f7c0;padding:8px 14px;border-radius:999px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;animation:fade-in .2s ease}.winner-ring{--c: #fff;width:72px;height:72px;border-radius:50%;margin:0 auto 14px;position:relative;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 28%,color-mix(in srgb,var(--c) 45%,#fff) 0%,var(--c) 58%,color-mix(in srgb,var(--c) 65%,#000) 100%);box-shadow:0 0 0 3px #ffffff38,0 0 0 5px var(--c),0 8px 24px #00000073,0 0 36px color-mix(in srgb,var(--c) 55%,transparent);animation:winner-pulse 2s ease-in-out infinite}.winner-trophy{font-size:34px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.55));animation:trophy-float 2.4s ease-in-out infinite}@keyframes winner-pulse{0%,to{box-shadow:0 0 0 3px #ffffff38,0 0 0 5px var(--c),0 8px 24px #00000073,0 0 28px color-mix(in srgb,var(--c) 50%,transparent)}50%{box-shadow:0 0 0 3px #ffffff52,0 0 0 5px var(--c),0 8px 24px #00000080,0 0 54px color-mix(in srgb,var(--c) 75%,transparent)}}@keyframes trophy-float{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-3px) rotate(3deg)}}.modal.start{padding:36px 40px 32px;width:420px;max-width:calc(100vw - 32px)}.modal.start .sub{color:#9aa0c4;font-size:13px;line-height:1.55;margin-bottom:22px;max-width:320px;margin-left:auto;margin-right:auto}.field{margin-bottom:18px;text-align:left}.field label{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#8a8fb5;margin-bottom:8px}.pill-row{display:flex;gap:6px;flex-wrap:wrap}.pill{background:#ffffff14;border:1.5px solid rgba(255,255,255,.55);color:#fff!important;padding:7px 14px;border-radius:999px;font-size:13px;font-weight:600;transition:all .15s ease}.pill.active{color:#05060f!important}.pill:hover{background:#ffffff2e;border-color:#fff}.pill.active{background:#fff;border-color:#fff;font-weight:700}.start-btn{background:#fff!important;color:#05060f!important;width:100%;padding:13px!important;margin-top:8px;font-weight:700!important;letter-spacing:.14em!important;box-shadow:0 8px 22px #0006;transition:transform .15s ease,box-shadow .2s ease,background .2s ease!important}.start-btn:hover:not(:disabled){transform:translateY(-2px);background:#f2f4ff!important;box-shadow:0 12px 30px #00000080}.start-btn.danger{background:#ff3b6b!important;color:#fff!important;box-shadow:0 8px 22px #ff3b6b73}.start-btn.danger:hover:not(:disabled){background:#ff547d!important;box-shadow:0 12px 30px #ff3b6b8c}.confirm-backdrop{z-index:900}.confirm-modal{max-width:380px;min-width:min(300px,100%);padding:28px 32px 24px}.confirm-modal .sub{margin:10px 0 22px;color:#c7cbe8;font-size:14px;line-height:1.5}.confirm-modal .modal-actions{gap:12px}.confirm-modal .modal-actions .ghost-btn,.confirm-modal .modal-actions .start-btn{flex:1;width:auto;margin-top:0}.start-btn:disabled{opacity:.45;cursor:not-allowed}.segmented{display:flex;background:#ffffff0d;border:1.5px solid rgba(255,255,255,.45);border-radius:12px;padding:3px;gap:2px}.seg{flex:1;background:transparent;border:none;color:#fff!important;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:600;letter-spacing:.04em;transition:all .2s ease}.seg.active{color:#05060f!important}.seg:hover:not(.active){color:#fff;background:#ffffff14}.seg.active{background:#fff;font-weight:600;box-shadow:0 2px 8px #00000059}.text-input{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.12);color:#f4f5fa;padding:9px 14px;border-radius:12px;font:inherit;font-size:14px;outline:none;transition:border-color .15s ease,background .15s ease}.text-input:focus{border-color:#fff6;background:#ffffff14}.code-input{text-align:center;letter-spacing:.4em;font-weight:600;text-transform:uppercase}.room-code{font-size:38px;font-weight:700;letter-spacing:.22em;text-align:center;margin:4px 0 22px;color:#fff;text-shadow:0 0 24px rgba(120,160,255,.4)}.seats{display:flex;flex-direction:column;gap:8px}.seat{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0a0c1a99;font-size:13px;transition:all .2s ease}.seat .dot{width:12px;height:12px;border-radius:50%;box-shadow:0 0 10px currentColor}.seat.taken{background:#ffffff0a}.seat.empty{opacity:.5;border-style:dashed}.seat.me{background:color-mix(in srgb,currentColor 8%,rgba(10,12,26,.7))}.seat .name{flex:1}.rename-btn{width:20px;height:20px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:#ffffff0f;color:#c7cbe8;font-size:11px;line-height:1;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:0 0 20px;transition:all .15s ease}.rename-btn:hover{background:#ffffff2e;color:#fff;border-color:#fff}.presence-dot{width:7px;height:7px;border-radius:50%;flex:0 0 7px;box-shadow:0 0 0 1.5px #0a0c1ae6;transition:background .2s ease}.presence-dot.on{background:#3ddc84;box-shadow:0 0 6px #3ddc8499,0 0 0 1.5px #0a0c1ae6}.presence-dot.off{background:#6b708f;opacity:.7}.kick-btn{margin-left:auto;flex:0 0 24px;width:24px;height:24px;aspect-ratio:1;border-radius:50%;border:1px solid rgba(255,59,107,.6);background:#fff;color:#ff3b6b;font-size:18px;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .15s ease}.kick-btn:hover{background:#ff3b6b;color:#fff;border-color:#ff3b6b;box-shadow:0 0 12px #ff3b6b99}.player .kick-btn{margin-left:2px;width:20px;height:20px;flex-basis:20px;font-size:15px}.bot-add{margin-left:auto;display:inline-flex;gap:4px}.bot-add-btn{width:22px;height:22px;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:#ffffff0f;color:#c8ccf0;font-size:11px;font-weight:700;cursor:pointer;padding:0;line-height:1;transition:all .15s ease}.bot-add-btn:hover{background:#ffffff2e;color:#fff;border-color:#fff}.share-row{display:flex;gap:8px;margin-bottom:16px}.share-input{flex:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#c7cbe8;padding:8px 12px;border-radius:10px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;min-width:0}.copy-btn{background:#c7cbe8;color:#05060f;border:none;padding:0 16px;border-radius:10px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;transition:background .15s ease,transform .15s ease}.copy-btn:hover{background:#fff;transform:translateY(-1px)}.copy-btn.success{background:#66e07a;color:#05060f}.ghost-btn{background:transparent;border:1px solid rgba(255,255,255,.16);color:#b8bcdb;padding:10px 18px;border-radius:999px;font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;transition:all .15s ease}.ghost-btn:hover{background:#ffffff0f;color:#fff}.ghost-btn.danger{border-color:#ff5a6e66;color:#ffa5b2}.ghost-btn.danger:hover{background:#ff50641f;border-color:#ff5a6eb3;color:#ffd1d8}.lobby-actions{display:flex;gap:10px;align-items:center}.lobby-actions .start-btn{flex:1;margin-top:0}.waiting{flex:1;color:#8a8fb5;font-size:13px;text-align:center}.chat-fab{position:absolute;right:max(18px,env(safe-area-inset-right));bottom:max(18px,env(safe-area-inset-bottom));width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:#0a0c1ae6;color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:25;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 10px 28px #0006;transition:transform .15s ease,box-shadow .2s ease}.chat-fab:hover{transform:translateY(-2px);box-shadow:0 14px 34px #00000080}.chat-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#ff3b6b;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 0 12px #ff3b6b99}.chat-panel{position:absolute;right:max(18px,env(safe-area-inset-right));bottom:max(18px,env(safe-area-inset-bottom));width:320px;height:440px;background:linear-gradient(180deg,#0f1330,#08091a);border:1px solid rgba(255,255,255,.08);border-radius:18px;display:flex;flex-direction:column;z-index:30;box-shadow:0 20px 50px #0000008c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:chat-in .22s ease;overflow:hidden}@keyframes chat-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.chat-title{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#8a8fb5;font-weight:600}.chat-close{background:none;border:none;color:#8a8fb5;font-size:22px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:6px;transition:background .15s ease,color .15s ease}.chat-close:hover{background:#ffffff0f;color:#fff}.chat-list{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.chat-list::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.chat-empty{color:#6a6f92;font-size:13px;text-align:center;margin-top:20px}.chat-msg{display:flex;flex-direction:column;gap:3px;max-width:86%;align-self:flex-start}.chat-msg.mine{align-self:flex-end;align-items:flex-end}.chat-author{font-size:11px;font-weight:600;letter-spacing:.06em;display:flex;align-items:center;gap:6px;padding-left:2px}.chat-dot{width:7px;height:7px;border-radius:50%;box-shadow:0 0 6px currentColor}.chat-bubble{background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#f4f5fa;padding:8px 12px;border-radius:14px;font-size:13px;line-height:1.45;word-wrap:break-word;white-space:pre-wrap}.chat-msg.mine .chat-bubble{border-radius:14px 14px 2px}.chat-msg:not(.mine) .chat-bubble{border-radius:2px 14px 14px}.chat-emoji{display:flex;gap:3px;padding:6px 10px;border-top:1px solid rgba(255,255,255,.06);overflow-x:auto}.chat-emoji-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.06);padding:5px 8px;border-radius:8px;font-size:15px;cursor:pointer;transition:transform .12s ease,background .15s ease;flex:0 0 auto}.chat-emoji-btn:hover{transform:translateY(-2px) scale(1.1);background:#ffffff1a}.chat-input-row{display:flex;gap:6px;padding:10px 12px 12px;border-top:1px solid rgba(255,255,255,.06)}.chat-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#f4f5fa;padding:9px 12px;border-radius:10px;font:inherit;font-size:13px;outline:none;transition:border-color .15s ease,background .15s ease;min-width:0}.chat-input:focus{border-color:#ffffff4d;background:#ffffff14}.chat-send{background:#c7cbe8;color:#05060f;border:none;padding:0 14px;border-radius:10px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:background .15s ease,opacity .15s ease}.chat-send:hover:not(:disabled){background:#fff}.chat-send:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 640px){.chat-panel{left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));width:auto;height:55vh;bottom:max(10px,env(safe-area-inset-bottom))}.chat-fab{width:46px;height:46px;font-size:19px;bottom:max(10px,env(safe-area-inset-bottom));right:max(10px,env(safe-area-inset-right))}}.chat-toasts{position:absolute;right:max(18px,env(safe-area-inset-right));bottom:calc(max(18px,env(safe-area-inset-bottom)) + 64px);display:flex;flex-direction:column-reverse;gap:8px;z-index:14;pointer-events:none;max-width:280px}.chat-toast{pointer-events:auto;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:#0a0c1aeb;border:1px solid rgba(255,255,255,.08);border-left:3px solid var(--c);color:#f4f5fa;padding:8px 12px;border-radius:12px;font-size:13px;text-align:left;box-shadow:0 10px 28px #00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;max-width:100%;animation:toast-in .25s cubic-bezier(.2,.9,.3,1.3) both,toast-out .4s ease 3.8s both}.chat-toast-name{font-size:11px;font-weight:700;letter-spacing:.04em}.chat-toast-text{line-height:1.35;word-wrap:break-word;white-space:pre-wrap;overflow-wrap:anywhere;max-width:100%;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@keyframes toast-in{0%{opacity:0;transform:translate(16px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toast-out{to{opacity:0;transform:translate(12px)}}@media (max-width: 640px){.chat-toasts{right:max(10px,env(safe-area-inset-right));bottom:calc(max(10px,env(safe-area-inset-bottom)) + 58px);max-width:70%}}.turn-row{display:inline-flex;align-items:center;gap:8px;pointer-events:none}.turn-timer{--c: #fff;--pct: 1;position:relative;width:30px;height:30px;border-radius:50%;background:#0a0c1abf;border:1px solid rgba(255,255,255,.1);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:transform .2s ease}.turn-timer-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;padding:3px;background:conic-gradient(var(--c) calc(var(--pct) * 360deg),rgba(255,255,255,.1) 0);-webkit-mask:radial-gradient(circle,transparent 60%,#000 61%);mask:radial-gradient(circle,transparent 60%,#000 61%)}.turn-timer-num{position:relative;font-size:11px;font-weight:700;color:#f4f5fa;font-variant-numeric:tabular-nums}.turn-timer.own{transform:scale(1.08)}.turn-timer.own .turn-timer-num{color:var(--c);text-shadow:0 0 10px color-mix(in srgb,var(--c) 60%,transparent)}.turn-timer.critical{animation:timer-pulse .7s ease-in-out infinite}.turn-timer.critical .turn-timer-num{color:#ff6b87}@keyframes timer-pulse{0%,to{box-shadow:0 0 #ff3b6b73}50%{box-shadow:0 0 0 6px #ff3b6b00}}.cortisol-card{margin:6px 0 20px;padding:12px 14px 10px;border-radius:14px;background:#080a1899;border:1px solid rgba(255,255,255,.08);text-align:left}.cortisol-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.cortisol-title{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#c7cbe8}.cortisol-unit{font-size:10px;letter-spacing:.08em;color:#c8cdeb80;font-style:italic}.cortisol-svg{display:block;width:100%;height:auto;max-height:180px}.cortisol-legend{display:flex;flex-wrap:wrap;gap:8px 12px;margin-top:8px;font-size:11px;color:#b8bcdb}.cortisol-legend-item{display:inline-flex;align-items:center;gap:6px}.cortisol-swatch{width:10px;height:10px;border-radius:50%;box-shadow:0 0 8px currentColor}.cortisol-disclaimer{margin-top:4px;font-size:10px;color:#c8cdeb66;font-style:italic;letter-spacing:.02em}.reaction-bar{position:fixed;left:50%;bottom:max(18px,env(safe-area-inset-bottom));transform:translate(-50%);display:flex;gap:6px;padding:6px 8px;background:#0a0c1ab3;border:1px solid rgba(255,255,255,.1);border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:20;pointer-events:auto}.reaction-btn{width:38px;height:38px;border-radius:50%;border:none;background:transparent;cursor:pointer;font-size:20px;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:transform .12s ease,background .15s ease}.reaction-btn:hover{background:#ffffff14;transform:scale(1.12)}.reaction-btn:active{transform:scale(.95)}.reaction-btn:disabled{opacity:.4;cursor:not-allowed}.reaction-toasts{position:absolute;right:max(18px,env(safe-area-inset-right));bottom:calc(max(18px,env(safe-area-inset-bottom)) + 128px);display:flex;flex-direction:column-reverse;gap:6px;z-index:15;pointer-events:none}.reaction-toast{--c: #fff;display:inline-flex;align-items:center;gap:8px;background:#0a0c1ae6;border:1px solid rgba(255,255,255,.08);border-left:3px solid var(--c);color:#f4f5fa;padding:6px 12px 6px 10px;border-radius:999px;font-size:13px;box-shadow:0 8px 22px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:reaction-toast-in .22s cubic-bezier(.2,.9,.3,1.3) both,reaction-toast-out .35s ease 2.85s both}.reaction-toast-emoji{font-size:18px;line-height:1}.reaction-toast-name{font-weight:600;letter-spacing:.02em;color:var(--c)}.elim-toasts{position:fixed;left:50%;bottom:calc(max(18px,env(safe-area-inset-bottom)) + 70px);transform:translate(-50%);display:flex;flex-direction:column-reverse;gap:6px;z-index:16;pointer-events:none;align-items:center}.elim-toast{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:#0a0c1aeb;border:1px solid rgba(255,255,255,.1);border-radius:999px;font-size:13px;font-weight:600;color:#f4f5fa;box-shadow:0 10px 26px #0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:elim-toast-in .28s cubic-bezier(.2,.9,.3,1.3) both,elim-toast-out .4s ease 3.1s both}.elim-attacker,.elim-victim{font-weight:700;text-shadow:0 0 10px color-mix(in srgb,currentColor 55%,transparent)}.elim-arrow{font-size:15px;color:#c7cbe8;opacity:.9}@keyframes elim-toast-in{0%{opacity:0;transform:translateY(12px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes elim-toast-out{to{opacity:0;transform:translateY(6px)}}@keyframes reaction-toast-in{0%{opacity:0;transform:translate(16px) scale(.92)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes reaction-toast-out{to{opacity:0;transform:translate(12px)}}@media (max-width: 640px){.reaction-toasts{right:max(10px,env(safe-area-inset-right));bottom:calc(max(10px,env(safe-area-inset-bottom)) + 118px)}}@media (max-width: 640px){.turn-timer{width:26px;height:26px}.turn-timer-num{font-size:10px}.reaction-bar{gap:2px;padding:4px 6px}.reaction-btn{width:34px;height:34px;font-size:18px}}.error-toast{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#ff506426;border:1px solid rgba(255,80,100,.4);color:#ffc4cc;padding:10px 18px;border-radius:999px;font-size:13px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:30;animation:fade-in .25s ease}@media (max-width: 640px){.modal{padding:24px 20px 20px}.modal.htp{padding:24px 18px 56px}.htp-section{gap:10px}.hud{top:max(10px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));gap:8px}.hud-title{display:none}.players{flex:1 1 auto;gap:6px}.player{padding:5px 10px;font-size:12px;gap:6px}.player .count{padding:1px 7px;min-width:20px;font-size:11px}.reset{padding:6px 12px;font-size:12px}.icon-btn{width:30px;height:30px;font-size:14px}.actions{gap:4px}.modal{min-width:auto;width:calc(100% - 32px);padding:28px 24px 24px}.modal.start{min-width:auto}.modal-name{font-size:32px}.pill{padding:6px 10px;font-size:12px}.field{margin-bottom:14px}}@media (max-height: 520px) and (orientation: landscape){.hud{top:8px;left:8px;right:8px}.modal{padding:20px 28px 18px}.field{margin-bottom:10px}}.player.speaking{box-shadow:0 0 0 1px var(--c, #4ade80),0 0 12px color-mix(in srgb,var(--c, #4ade80) 70%,transparent)}.player.speaking .dot{animation:speaking-pulse .9s ease-in-out infinite}@keyframes speaking-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--c, #4ade80) 60%,transparent)}50%{box-shadow:0 0 0 5px color-mix(in srgb,var(--c, #4ade80) 0%,transparent)}}.voice-chip-btn{position:relative;margin-left:4px;width:22px;height:22px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#d6d9ef;font-size:12px;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease,color .15s ease}.voice-chip-btn:hover:not(:disabled){background:#ffffff29;border-color:#fff6}.voice-chip-btn:disabled{cursor:not-allowed}.voice-chip-btn.mic:not(.muted){background:#22c55e38;border-color:#4ade80b3;color:#ecfdf5;box-shadow:0 0 8px #4ade8066}.voice-chip-btn.muted{background:#ff585824;border-color:#ff585880;color:#ffffff8c}.voice-chip-btn.muted:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(to bottom right,transparent calc(50% - 1px),rgba(255,110,110,.95) calc(50% - 1px),rgba(255,110,110,.95) calc(50% + 1px),transparent calc(50% + 1px));border-radius:inherit}.voice-chip-btn.busy{opacity:.6;animation:mic-pulse 1.1s ease-in-out infinite}@keyframes mic-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Helvetica Neue,Arial,sans-serif;background:#05060f;color:#f4f5fa}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;overflow:hidden}button{font:inherit;cursor:pointer}
