*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0e1116;--panel: rgba(20, 26, 36, .92);--accent: #6ea8fe;--accent-2: #8b5cf6;--text: #e6edf3;--muted: #9aa7b4;--border: rgba(255, 255, 255, .1)}html,body,#root{width:100%;height:100%}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.app{position:relative;width:100vw;height:100vh}.lobby{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 50% -10%,#1b2230 0%,var(--bg) 70%)}.lobby-card{width:min(440px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:36px 32px;box-shadow:0 30px 80px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.offline-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 50% -10%,#1b2230 0%,var(--bg) 70%);z-index:100}.offline-card{width:min(500px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:0 30px 90px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:center}.offline-brand{background:#fff;padding:16px 24px;border-bottom:1px solid rgba(0,0,0,.08);display:flex;justify-content:center}.offline-logo{height:44px}.offline-title{font-size:26px;font-weight:700;padding:22px 32px 6px;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent;margin:0}.offline-badge{display:inline-block;margin:10px 0 18px;padding:5px 16px;background:#ff505026;border:1px solid rgba(255,80,80,.4);border-radius:20px;color:#ff9b9b;font-size:13px;font-weight:600;letter-spacing:.3px}.offline-msg{color:var(--text);font-size:14.5px;line-height:1.7;padding:0 32px;margin:0 0 12px}.offline-tagline{margin:18px 0;padding:16px 32px;font-size:15px;font-weight:700;color:var(--accent);border-top:1px solid var(--border);border-bottom:1px solid var(--border);letter-spacing:.4px}.offline-time{padding:14px 32px;color:var(--muted);font-size:13px}.name-field{margin-bottom:16px}.name-label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.name-input{letter-spacing:0;text-transform:none;font-size:15px;font-weight:500;text-align:left}.spectator-badge{display:inline-block;margin-top:8px;padding:4px 10px;background:#8b5cf633;border:1px solid rgba(139,92,246,.5);border-radius:20px;color:#c4b5fd;font-size:12px;font-weight:600}.spectator-count{margin-top:10px;font-size:11px;color:var(--muted);opacity:.7}.lobby-brand{background:#fff;border-radius:12px 12px 0 0;margin:-36px -32px 22px;padding:16px 24px;display:flex;justify-content:center;align-items:center;border-bottom:1px solid rgba(0,0,0,.08)}.lobby-logo{height:48px;display:block}.lobby-footer{margin-top:22px;font-size:11px;color:var(--muted);text-align:center;opacity:.6}.hud-logo{display:block;width:100%;max-width:140px;height:auto;background:#fff;border-radius:8px;padding:5px 8px}.lobby-title{font-size:30px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.lobby-sub{color:var(--muted);font-size:14px;margin-bottom:26px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 16px;border:none;border-radius:11px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .08s ease,filter .15s ease;color:#fff;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.btn:hover{filter:brightness(1.08)}.btn:active{transform:translateY(1px)}.btn.secondary{background:#ffffff12;border:1px solid var(--border)}.btn:disabled{opacity:.5;cursor:not-allowed}.divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px;margin:20px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.join-row{display:flex;gap:10px}.input{flex:1;padding:13px 14px;border-radius:11px;border:1px solid var(--border);background:#00000040;color:var(--text);font-size:18px;letter-spacing:4px;text-transform:uppercase;font-weight:700;text-align:center}.input:focus{outline:none;border-color:var(--accent)}.join-row .btn{width:auto;padding-left:22px;padding-right:22px}.error{margin-top:14px;color:#ff8585;font-size:13px;text-align:center}.code-box{margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:14px}.code-value{font-size:44px;font-weight:800;letter-spacing:10px;padding:12px 8px 12px 18px;border:1px dashed var(--border);border-radius:12px;background:#00000040}.spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.waiting-text{display:flex;align-items:center;gap:10px;color:var(--muted)}.hud{position:absolute;top:0;left:0;right:0;padding:16px 20px;display:flex;justify-content:space-between;align-items:flex-start;pointer-events:none;z-index:5}.hud .panel{pointer-events:auto;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.turn-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:8px;vertical-align:middle}.dot-white{background:#f0f0f0}.dot-black{background:#222;border:1px solid #666}.hud .label{color:var(--muted);font-size:12px}.hud .value{font-size:15px;font-weight:600}.check-badge{color:#ffb454;font-weight:700;margin-top:4px}.btn-resign{pointer-events:auto;background:#ff505026;border:1px solid rgba(255,80,80,.4);color:#ff9b9b;padding:10px 16px;border-radius:11px;font-weight:600;cursor:pointer}.btn-resign:hover{background:#ff505040}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#05080cb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:20}.overlay-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:32px 40px;text-align:center;box-shadow:0 30px 80px #00000080}.overlay-card h2{font-size:28px;margin-bottom:8px}.overlay-card p{color:var(--muted);margin-bottom:22px}.promo{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:25}.promo-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px 24px}.promo-card h3{margin-bottom:14px;font-size:16px}.promo-row{display:flex;gap:12px}.promo-btn{width:64px;height:64px;font-size:34px;border-radius:12px;border:1px solid var(--border);background:#ffffff0f;color:var(--text);cursor:pointer}.promo-btn:hover{background:#6ea8fe33;border-color:var(--accent)}.toast{position:absolute;bottom:22px;left:50%;transform:translate(-50%);background:var(--panel);border:1px solid var(--border);padding:10px 18px;border-radius:10px;color:var(--muted);font-size:13px;z-index:30}.chat-panel{position:absolute;top:0;right:0;width:270px;height:100%;display:flex;flex-direction:column;background:var(--panel);border-left:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:5}.chat-header{padding:13px 16px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);flex-shrink:0}.chat-list{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.chat-list::-webkit-scrollbar{width:4px}.chat-list::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px}.chat-empty{color:var(--muted);font-size:13px;text-align:center;margin-top:24px;opacity:.6}.chat-msg{display:flex;flex-direction:column;gap:3px}.chat-msg--me{align-items:flex-end}.chat-msg--opponent{align-items:flex-start}.chat-meta{display:flex;align-items:center;gap:5px;padding:0 4px}.chat-who{font-size:11px;font-weight:600;color:var(--muted);opacity:.85}.chat-role-badge{font-size:9px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:#a78bfa;background:#8b5cf626;border-radius:4px;padding:1px 5px}.chat-text{max-width:200px;padding:8px 12px;border-radius:14px;font-size:13.5px;line-height:1.4;word-break:break-word}.chat-msg--me .chat-text{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-bottom-right-radius:4px}.chat-msg--opponent .chat-text{background:#ffffff17;color:var(--text);border-bottom-left-radius:4px;border:1px solid var(--border)}.chat-form{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0}.chat-input{flex:1;padding:9px 12px;background:#0000004d;border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;min-width:0}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-input::placeholder{color:var(--muted);opacity:.6}.chat-send{padding:9px 14px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0;transition:filter .1s ease}.chat-send:hover{filter:brightness(1.12)}
