.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}.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-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;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:2;touch-action:manipulation}.modal-close:hover,.modal-close:active{background:#fff3}.modal.htp .modal-label{text-align:center}.help-link{display:block;width:100%;background:transparent;border:none;color:#8a8fb5;font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-top:12px;padding:6px;cursor:pointer;transition:color .15s ease}.help-link:hover{color:#fff}.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{width:70px;height:70px;border-radius:50%;margin:0 auto 14px;box-shadow:0 0 40px currentColor;animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.1);filter:brightness(1.3)}}.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: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))}.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:15;-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:15;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%}}.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}}: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}
