@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700;900&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;vertical-align:middle;text-transform:none}:root{--bg-primary:#04170d;--surface:#04170d;--surface-dim:#04170d;--surface-low:#0b1f15;--surface-mid:#102418;--surface-high:#1a2e22;--surface-highest:#25392d;--surface-bright:#293e31;--surface-lowest:#011208;--primary:#7ddc7a;--primary-container:#46a34a;--primary-fixed:#98f994;--primary-fixed-dim:#7ddc7a;--on-primary:#00390a;--on-primary-container:#003208;--secondary:#ffb4ac;--secondary-container:#a90111;--on-secondary:#690006;--on-secondary-container:#ffb3ab;--tertiary:#e8c41d;--tertiary-container:#c9a900;--on-tertiary:#3a3000;--on-tertiary-container:#4c3f00;--on-surface:#d0e8d7;--on-surface-variant:#bfcab9;--on-background:#d0e8d7;--inverse-on-surface:#213529;--outline:#899484;--outline-variant:#3f4a3d;--uno-red:#e53935;--uno-green:#43a047;--uno-blue:#1e88e5;--uno-yellow:#fdd835;--uno-wild:#212121;--shadow-card:0 4px 12px #0000004d;--shadow-panel:0 8px 32px #00220499;--shadow-glow-green:0 0 20px #7ddc7a66;--shadow-glow-red:0 0 20px #a9011166;--font-headline:"Space Grotesk", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-med:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--on-surface);min-height:100dvh;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-headline);letter-spacing:-.02em;color:var(--on-surface);font-weight:700}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{font-family:var(--font-body)}.felt-bg{background-image:radial-gradient(circle,#1a472a 0%,#04170d 100%);position:relative}.felt-bg:before{content:"";opacity:.05;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.glass-panel{-webkit-backdrop-filter:blur(20px);background:#10241899;border:1px solid #7ddc7a14}.btn-primary{background:var(--secondary-container);color:var(--on-surface);font-family:var(--font-headline);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-md);transition:all var(--transition-fast);border-bottom:3px solid #0003;justify-content:center;align-items:center;gap:8px;padding:14px 28px;font-size:14px;font-weight:700;display:inline-flex;box-shadow:0 8px 32px #a901114d}.btn-primary:hover{background:#a90111d9;box-shadow:0 0 24px #a9011180}.btn-primary:active{transform:scale(.96)}.btn-secondary{background:var(--primary-container);color:var(--on-primary-container);font-family:var(--font-headline);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-md);transition:all var(--transition-fast);border-bottom:3px solid #0003;justify-content:center;align-items:center;gap:8px;padding:14px 28px;font-size:14px;font-weight:700;display:inline-flex;box-shadow:0 8px 32px #46a34a33}.btn-secondary:hover{box-shadow:var(--shadow-glow-green)}.btn-secondary:active{transform:scale(.96)}.btn-ghost{color:var(--on-surface-variant);font-family:var(--font-headline);letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:12px;font-weight:600;display:inline-flex}.btn-ghost:hover{color:var(--on-surface);background:#ffffff0d}.input-field{background:var(--surface-lowest);width:100%;color:var(--on-surface);font-family:var(--font-body);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:none;outline:none;padding:14px 18px;font-size:15px}.input-field::placeholder{color:var(--outline);opacity:.6}.input-field:focus{background:var(--surface-high);box-shadow:0 0 0 2px #7ddc7a4d}.input-field.mono-input{font-family:var(--font-mono);letter-spacing:.4em;text-align:center;text-transform:none;font-size:20px}.input-label{letter-spacing:.18em;text-transform:uppercase;color:#7ddc7a80;margin-bottom:8px;margin-left:4px;font-size:10px;font-weight:700;display:block}.chip{background:var(--surface-highest);color:var(--on-surface-variant);font-family:var(--font-mono);border-radius:var(--radius-full);border:1px solid #ffffff0d;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:500;display:inline-flex}.chip-primary{color:var(--primary);background:#7ddc7a1a;border-color:#7ddc7a33}.status-dot{background:var(--primary);width:8px;height:8px;box-shadow:0 0 8px var(--primary);border-radius:50%;animation:2s ease-in-out infinite pulse-dot;display:inline-block}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.bounce-dot{background:#46a34a;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite bounce-up;display:inline-block}.bounce-dot:nth-child(2){animation-delay:.2s}.bounce-dot:nth-child(3){animation-delay:.4s}@keyframes bounce-up{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.shimmer{background:linear-gradient(90deg,#0000,#7ddc7a14,#0000) 0 0/200% 100%;animation:3s linear infinite shimmer-move}@keyframes shimmer-move{0%{background-position:-200% 0}to{background-position:200% 0}}.card-shadow{box-shadow:0 10px 20px #00000080,inset 0 0 0 1px #ffffff1a}.uno-card{border-radius:var(--radius-md);cursor:pointer;transition:transform var(--transition-med);box-shadow:var(--card-shadow);border:1px solid #fff3;flex-direction:column;padding:8px;display:flex;position:relative}.uno-card:hover{transform:translateY(-12px)scale(1.04)}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin-slow{animation:8s linear infinite spin-slow}@media (width<=768px) and (orientation:portrait){:root{--card-w-mobile:80px;--card-h-mobile:120px;--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}}body{overscroll-behavior:none;-webkit-overflow-scrolling:touch}.game-page{overscroll-behavior:none}@media (pointer:coarse){button,[role=button],.uno-card,.draw-pile,.discard-pile{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.uno-card,.draw-pile,.discard-pile,.card-root{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}}@supports (padding:env(safe-area-inset-left)){@media (width<=768px) and (orientation:portrait){.safe-area-pad{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}}}.auth-page{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#7ddc7a14 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:6s ease-in-out infinite auth-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes auth-pulse{0%,to{opacity:.6;transform:translate(-50%,-50%)scale(1)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.15)}}.auth-card{z-index:1;border-radius:var(--radius-xl);width:100%;max-width:420px;padding:40px 32px 32px;animation:.5s ease-out auth-fade-in;position:relative}@keyframes auth-fade-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-brand{text-align:center;margin-bottom:32px}.auth-brand-icon{border-radius:var(--radius-lg);background:#7ddc7a1a;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;display:inline-flex}.auth-brand-icon .material-symbols-outlined{color:var(--primary);font-size:28px}.auth-brand h1{font-family:var(--font-headline);letter-spacing:-.02em;color:var(--on-surface);margin-bottom:4px;font-size:24px;font-weight:700}.auth-brand p{color:var(--on-surface-variant);font-size:13px}.auth-tabs{background:var(--surface-lowest);border-radius:var(--radius-sm);gap:4px;margin-bottom:28px;padding:4px;display:flex}.auth-tab{font-family:var(--font-headline);letter-spacing:.04em;text-transform:uppercase;color:var(--on-surface-variant);transition:all var(--transition-fast);text-align:center;border-radius:6px;flex:1;padding:10px 16px;font-size:13px;font-weight:600}.auth-tab:hover{color:var(--on-surface)}.auth-tab.active{background:var(--surface-high);color:var(--primary);box-shadow:0 2px 8px #0000004d}.auth-form{flex-direction:column;gap:20px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{letter-spacing:.18em;text-transform:uppercase;color:#7ddc7a80;margin-left:4px;font-size:10px;font-weight:700}.auth-field input{background:var(--surface-lowest);width:100%;color:var(--on-surface);font-family:var(--font-body);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid #0000;outline:none;padding:14px 18px;font-size:15px}.auth-field input::placeholder{color:var(--outline);opacity:.5}.auth-field input:focus{background:var(--surface-high);border-color:#7ddc7a4d;box-shadow:0 0 0 3px #7ddc7a14}.auth-submit{background:var(--primary-container);color:var(--on-primary-container);font-family:var(--font-headline);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;border-bottom:3px solid #0003;margin-top:4px;padding:16px 28px;font-size:14px;font-weight:700;position:relative;overflow:hidden;box-shadow:0 8px 32px #46a34a33}.auth-submit:hover:not(:disabled){box-shadow:var(--shadow-glow-green);transform:translateY(-1px)}.auth-submit:active:not(:disabled){transform:scale(.97)translateY(0)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-error{border-radius:var(--radius-sm);color:var(--secondary);background:#a9011126;border:1px solid #a901114d;align-items:center;gap:8px;padding:12px 16px;font-size:13px;animation:.4s auth-shake;display:flex}@keyframes auth-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.auth-error .material-symbols-outlined{flex-shrink:0;font-size:18px}.auth-success{border-radius:var(--radius-sm);color:var(--primary);background:#7ddc7a1a;border:1px solid #7ddc7a40;align-items:center;gap:8px;padding:12px 16px;font-size:13px;display:flex}.auth-success .material-symbols-outlined{flex-shrink:0;font-size:18px}.auth-spinner{border:2px solid #0032084d;border-top-color:var(--on-primary-container);vertical-align:middle;border-radius:50%;width:18px;height:18px;margin-right:8px;animation:.6s linear infinite auth-spin;display:inline-block}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-footer{text-align:center;border-top:1px solid var(--outline-variant);margin-top:24px;padding-top:20px}.auth-footer p{color:var(--on-surface-variant);font-size:13px}.auth-footer button{color:var(--primary);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;font-weight:600;text-decoration:underline}.auth-footer button:hover{color:var(--primary-fixed)}.auth-hint{color:var(--on-surface-variant);opacity:.7;margin-top:-8px;margin-left:4px;font-size:11px}@media (width<=950px) and (height<=500px){.auth-page{padding:12px;padding-left:max(12px, env(safe-area-inset-left,0px));padding-right:max(12px, env(safe-area-inset-right,0px));align-items:flex-start;min-height:100dvh;overflow-y:auto}.auth-page:after{width:280px;height:280px}.auth-card{border-radius:var(--radius-lg);max-width:380px;margin:auto;padding:16px 20px}.auth-brand{margin-bottom:12px}.auth-brand-icon{border-radius:var(--radius-sm);width:36px;height:36px;margin-bottom:6px}.auth-brand-icon .material-symbols-outlined{font-size:20px}.auth-brand h1{margin-bottom:2px;font-size:18px}.auth-brand p{font-size:11px}.auth-tabs{margin-bottom:12px;padding:3px}.auth-tab{padding:6px 12px;font-size:11px}.auth-form{gap:10px}.auth-field input{padding:10px 14px;font-size:14px}.auth-field label{margin-bottom:4px;font-size:9px}.auth-submit{margin-top:0;padding:10px 20px;font-size:12px}.auth-error,.auth-success{margin-bottom:4px;padding:8px 12px;font-size:12px}.auth-footer{margin-top:12px;padding-top:10px}.auth-footer p{font-size:11px}.auth-hint{margin-top:-4px;font-size:10px}}.lobby-page{flex-direction:column;min-height:100dvh;display:flex;position:relative;overflow:hidden}.lobby-bg{z-index:0;background-image:radial-gradient(circle,#0f2318 0%,#04170d 100%);position:absolute;inset:0}.lobby-bg:before{content:"";opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3z' fill='%23ffffff' fill-opacity='1' fill-rule='evenodd'/%3E%3C/svg%3E");position:absolute;inset:0}.lobby-card-scatter{pointer-events:none;background:#ffffff05;border:1px solid #ffffff0d;border-radius:10px;width:100px;height:150px;position:absolute}.lobby-nav{z-index:10;-webkit-backdrop-filter:blur(20px);background:#011208b3;border-bottom:1px solid #7ddc7a0f;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:relative;box-shadow:0 4px 20px #00220480}.lobby-logo{align-items:center;gap:10px;display:flex}.lobby-logo h1{font-family:var(--font-headline);color:var(--primary);letter-spacing:-.04em;text-transform:uppercase;font-size:22px;font-weight:900}.lobby-logo-badge{font-family:var(--font-mono);color:var(--primary);border-radius:var(--radius-full);letter-spacing:.05em;background:#7ddc7a26;padding:2px 8px;font-size:9px;font-weight:700}.lobby-nav-links{align-items:center;gap:32px;display:flex}.lobby-nav-links a{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:.05em;color:#1b5433cc;transition:color var(--transition-fast);font-size:13px;font-weight:700}.lobby-nav-links a:hover{color:var(--on-surface)}.lobby-nav-links a.active{color:var(--primary);border-bottom:2px solid var(--primary);padding-bottom:2px}.lobby-nav-actions{align-items:center;gap:16px;display:flex}.lobby-nav-icon-btn{border-radius:var(--radius-sm);width:40px;height:40px;color:var(--primary);transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.lobby-nav-icon-btn:hover{background:#7ddc7a1a}.lobby-avatar{border-radius:var(--radius-full);cursor:pointer;border:2px solid #7ddc7a4d;width:38px;height:38px;overflow:hidden}.lobby-avatar-inner{background:var(--primary-container);width:100%;height:100%;font-family:var(--font-headline);color:var(--on-primary-container);justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.lobby-main{z-index:5;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 32px;display:flex;position:relative}.lobby-hero{text-align:center;margin-bottom:48px}.lobby-hero h2{font-family:var(--font-headline);color:var(--primary);text-transform:uppercase;letter-spacing:-.04em;text-shadow:0 0 40px #7ddc7a4d;font-size:clamp(42px,6vw,72px);font-weight:900;line-height:1}.lobby-hero p{font-family:var(--font-body);letter-spacing:.2em;text-transform:uppercase;color:#7ddc7a73;margin-top:12px;font-size:11px;font-weight:600}.lobby-panels{grid-template-columns:1fr 1fr;gap:28px;width:100%;max-width:900px;display:grid}@media (width<=640px){.lobby-panels{grid-template-columns:1fr}}.lobby-panel{text-align:center;transition:border-color var(--transition-med);border-radius:20px;flex-direction:column;align-items:center;padding:40px 36px;display:flex}.lobby-panel-icon{border-radius:var(--radius-full);background:var(--surface-high);width:64px;height:64px;color:var(--primary);border:1px solid #3f4a3d66;justify-content:center;align-items:center;margin-bottom:24px;font-size:28px;display:flex}.lobby-panel h3{font-family:var(--font-headline);color:var(--on-surface);letter-spacing:-.02em;margin-bottom:28px;font-size:22px;font-weight:700}.lobby-panel-fields{text-align:left;flex-direction:column;gap:18px;width:100%;display:flex}.lobby-panel-btn{border-radius:14px;width:100%;margin-top:8px;padding:18px;font-size:15px}.lobby-secondary-actions{align-items:center;gap:36px;margin-top:40px;display:flex}.lobby-secondary-actions button{color:#7ddc7a59;font-family:var(--font-headline);letter-spacing:.15em;text-transform:uppercase;transition:color var(--transition-fast);align-items:center;gap:8px;font-size:11px;font-weight:700;display:flex}.lobby-secondary-actions button:hover{color:var(--primary)}.lobby-footer{z-index:10;flex-direction:column;align-items:center;gap:8px;padding:16px 32px 24px;display:flex;position:relative}.lobby-footer-status{align-items:center;gap:12px;display:flex}.lobby-footer-version{font-family:var(--font-mono);color:#7ddc7a59;text-transform:uppercase;letter-spacing:.05em;font-size:10px}.lobby-footer-connected{font-family:var(--font-mono);color:#7ddc7a80;text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:8px;font-size:10px;display:flex}.lobby-footer-divider{background:#7ddc7a26;width:1px;height:12px}.lobby-footer-links{gap:24px;display:flex}.lobby-footer-links a{font-family:var(--font-mono);text-transform:uppercase;color:#1b543399;letter-spacing:.05em;transition:color var(--transition-fast);font-size:10px}.lobby-footer-links a:hover{color:var(--on-surface-variant)}.lobby-error-banner{color:#f87171;font-family:var(--font-body);background:#dc3c3c26;border:1px solid #dc3c3c59;border-radius:12px;align-items:center;gap:10px;width:100%;max-width:900px;margin-bottom:24px;padding:14px 20px;font-size:13px;font-weight:500;animation:.25s ease-out slideDown;display:flex}.lobby-error-dismiss{color:#f87171;opacity:.7;align-items:center;margin-left:auto;transition:opacity .15s;display:flex}.lobby-error-dismiss:hover{opacity:1}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.lobby-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite lobby-spin;display:inline-block}@keyframes lobby-spin{to{transform:rotate(360deg)}}.lobby-panel input:disabled{opacity:.5;cursor:not-allowed}.lobby-panel-btn:disabled{opacity:.7;cursor:not-allowed;justify-content:center;align-items:center;gap:10px;display:flex}@media (width<=768px){.lobby-nav{padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px))}.lobby-logo h1{font-size:18px}.lobby-logo-badge{padding:1px 6px;font-size:8px}.lobby-nav-links{display:none}.lobby-nav-actions{gap:8px}.lobby-nav-icon-btn,.lobby-avatar{width:36px;height:36px}.lobby-avatar-inner{font-size:13px}.lobby-main{-webkit-overflow-scrolling:touch;justify-content:flex-start;padding:24px 20px 16px;overflow-y:auto}.lobby-hero{margin-bottom:24px}.lobby-hero h2{font-size:clamp(32px,10vw,48px)}.lobby-hero p{letter-spacing:.15em;margin-top:8px;font-size:10px}.lobby-panels{grid-template-columns:1fr;gap:18px;max-width:100%}.lobby-panel{border-radius:16px;padding:28px 24px}.lobby-panel-icon{width:52px;height:52px;margin-bottom:16px;font-size:24px}.lobby-panel h3{margin-bottom:20px;font-size:18px}.lobby-panel-fields{gap:14px}.lobby-panel-btn{border-radius:12px;padding:16px;font-size:13px}.lobby-panel .input-field{padding:12px 14px;font-size:14px}.lobby-panel .input-label{margin-bottom:5px;font-size:9px}.lobby-panel .mono-input{letter-spacing:.2em;padding:12px 14px;font-size:16px}.lobby-secondary-actions{gap:20px;margin-top:24px}.lobby-secondary-actions button{letter-spacing:.1em;font-size:10px}.lobby-footer{padding:12px 16px 16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.lobby-footer-status{flex-wrap:wrap;justify-content:center;gap:8px}.lobby-footer-version{font-size:9px}.lobby-footer-connected{gap:6px;font-size:9px}.lobby-footer-links{gap:16px}.lobby-footer-links a{font-size:9px}.lobby-error-banner{border-radius:10px;max-width:100%;margin-bottom:16px;padding:12px 16px;font-size:12px}.lobby-card-scatter{display:none}}@media (width<=380px){.lobby-hero h2{font-size:28px}.lobby-panel{padding:22px 18px}.lobby-panel h3{margin-bottom:16px;font-size:16px}.lobby-panel-icon{width:44px;height:44px;margin-bottom:12px;font-size:20px}.lobby-panel-btn{padding:14px;font-size:12px}.lobby-panel .mono-input{letter-spacing:.15em;font-size:14px}}@media (width<=950px) and (height<=500px){.lobby-nav{padding:8px 16px;padding-left:max(16px, env(safe-area-inset-left,0px));padding-right:max(16px, env(safe-area-inset-right,0px))}.lobby-logo h1{font-size:16px}.lobby-logo-badge{padding:1px 6px;font-size:8px}.lobby-nav-links{display:none}.lobby-nav-actions{gap:8px}.lobby-nav-icon-btn,.lobby-avatar{width:32px;height:32px}.lobby-main{padding:12px 16px 8px;padding-left:max(16px, env(safe-area-inset-left,0px));padding-right:max(16px, env(safe-area-inset-right,0px));justify-content:flex-start}.lobby-hero{margin-bottom:12px}.lobby-hero h2{font-size:clamp(24px,5vw,36px)}.lobby-hero p{margin-top:4px;font-size:9px}.lobby-panels{grid-template-columns:1fr 1fr;gap:12px;max-width:700px}.lobby-panel{border-radius:14px;padding:16px 14px}.lobby-panel-icon{width:40px;height:40px;margin-bottom:10px;font-size:20px}.lobby-panel h3{margin-bottom:12px;font-size:15px}.lobby-panel-fields{gap:8px}.lobby-panel-btn{border-radius:10px;padding:10px;font-size:12px}.lobby-panel .input-field{padding:8px 12px;font-size:13px}.lobby-panel .input-label{margin-bottom:4px;font-size:8px}.lobby-panel .mono-input{letter-spacing:.2em;padding:8px 12px;font-size:16px}.lobby-secondary-actions{gap:16px;margin-top:12px}.lobby-secondary-actions button{font-size:9px}.lobby-footer{padding:6px 16px 8px;padding-left:max(16px, env(safe-area-inset-left,0px));padding-right:max(16px, env(safe-area-inset-right,0px));flex-direction:row;justify-content:center;align-items:center;gap:16px}.lobby-footer-status{gap:8px}.lobby-footer-version{font-size:9px}.lobby-footer-connected{gap:6px;font-size:9px}.lobby-footer-links{gap:12px}.lobby-footer-links a{font-size:9px}.lobby-error-banner{margin-bottom:8px;padding:8px 12px;font-size:12px}.lobby-card-scatter{display:none}}@keyframes wifi-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.12)}}@keyframes reconnect-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes overlay-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes dot-blink{0%,to{opacity:1}50%{opacity:.2}}.reconnection-overlay{z-index:9999;-webkit-backdrop-filter:blur(10px)saturate(.7);background:#060614d1;justify-content:center;align-items:center;animation:.25s ease-out both overlay-fade-in;display:flex;position:fixed;inset:0}.reconnection-card{text-align:center;background:#121228bf;border:1px solid #ffffff1a;border-radius:1.75rem;flex-direction:column;align-items:center;gap:1.25rem;width:calc(100% - 3rem);max-width:380px;padding:2.5rem 3rem;display:flex;box-shadow:0 0 0 1px #fbbf241f,0 0 60px #fbbf2414,0 24px 64px #0009}.reconnection-icon-wrap{background:#fbbf241f;border:1.5px solid #fbbf244d;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;animation:1.8s ease-in-out infinite wifi-pulse;display:flex}.reconnection-icon-wrap .material-symbols-outlined{color:#fbbf24;font-size:36px}.reconnection-heading{color:#f0f0f8;letter-spacing:-.01em;margin:0;font-size:1.4rem;font-weight:700}.reconnection-subtitle{color:#ffffff8c;margin:-.5rem 0 0;font-size:.875rem;line-height:1.5}.reconnection-countdown{background:#ffffff0a;border:1px solid #ffffff14;border-radius:.875rem;width:100%;padding:.875rem 1.5rem}.reconnection-countdown__label{color:#fff6;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem;font-size:.75rem}.reconnection-countdown__value{font-variant-numeric:tabular-nums;color:#fbbf24;font-family:Courier New,monospace;font-size:2rem;font-weight:700;line-height:1}.reconnection-countdown__unit{color:#fff6;margin-top:.2rem;font-size:.75rem}.reconnection-attempt{color:#ffffff8c;align-items:center;gap:.625rem;font-size:.875rem;display:flex}.reconnection-spinner{border:2px solid #fbbf2433;border-top-color:#fbbf24;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.9s linear infinite reconnect-spin}.reconnection-dots span{animation:1.2s ease-in-out infinite dot-blink}.reconnection-dots span:nth-child(2){animation-delay:.2s}.reconnection-dots span:nth-child(3){animation-delay:.4s}.reconnection-divider{background:#ffffff12;width:100%;height:1px}.reconnection-leave-btn{all:unset;cursor:pointer;color:#f87171cc;letter-spacing:.01em;box-sizing:border-box;border:1.5px solid #f8717159;border-radius:.875rem;justify-content:center;align-items:center;gap:.5rem;width:100%;min-height:48px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.reconnection-leave-btn:hover,.reconnection-leave-btn:focus-visible{color:#f87171;background:#f871711a;border-color:#f8717199;transform:translateY(-1px);box-shadow:0 4px 16px #f8717126}.reconnection-leave-btn:active{transform:translateY(0)}.reconnection-leave-btn .material-symbols-outlined{font-size:18px}@media (width<=480px){.reconnection-card{border-radius:1.25rem;gap:1rem;padding:2rem 1.5rem}.reconnection-icon-wrap{width:60px;height:60px}.reconnection-icon-wrap .material-symbols-outlined{font-size:30px}.reconnection-heading{font-size:1.2rem}.reconnection-countdown__value{font-size:1.6rem}}.waiting-page{background-image:radial-gradient(circle,#1a472a 0%,#0f2318 100%);flex-direction:column;min-height:100dvh;display:flex;position:relative;overflow:hidden}.waiting-page:before{content:"";opacity:.05;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.waiting-card-motif{opacity:.03;pointer-events:none;border:4px solid #fff3;border-radius:16px;position:absolute}.waiting-topbar{z-index:10;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px));-webkit-backdrop-filter:blur(20px);background:#01120899;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;display:flex;position:relative;box-shadow:0 8px 32px #00220480}.waiting-topbar-left{align-items:center;gap:12px;display:flex}.waiting-back-btn{border-radius:var(--radius-full);width:36px;height:36px;color:var(--primary);transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.waiting-back-btn:hover{background:#ffffff0d}.waiting-room-badge{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#19392d66;border:1px solid #ffffff0d;align-items:center;gap:8px;padding:6px 14px;display:flex}.waiting-room-badge span{font-family:var(--font-headline);letter-spacing:-.02em;text-transform:uppercase;color:var(--primary);font-size:12px;font-weight:700}.waiting-copy-btn{color:#1b5433b3;transition:color var(--transition-fast);align-items:center;display:flex;font-size:18px!important}.waiting-copy-btn:hover{color:var(--primary)}.waiting-settings-btn{border-radius:var(--radius-full);width:36px;height:36px;color:var(--primary);transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.waiting-settings-btn:hover{background:#ffffff0d}.waiting-main{z-index:5;-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;align-items:center;padding:20px 16px 140px;display:flex;position:relative;overflow-y:auto}.waiting-title{text-align:center;margin-bottom:20px}.waiting-title h2{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.04em;color:var(--on-surface);font-size:clamp(28px,6vw,44px);font-weight:900}.waiting-title p{font-family:var(--font-headline);letter-spacing:.15em;text-transform:uppercase;color:#7ddc7a99;margin-top:4px;font-size:10px;font-weight:700}.room-code-card{-webkit-backdrop-filter:blur(24px);background:#19392d73;border:1px solid #7ddc7a1f;border-radius:16px;flex-direction:column;gap:8px;width:100%;max-width:520px;margin-bottom:20px;padding:14px 18px;display:flex;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0a}.room-code-label{font-family:var(--font-headline);letter-spacing:.12em;text-transform:uppercase;color:#7ddc7ab3;align-items:center;gap:6px;font-size:10px;font-weight:700;display:flex}.room-code-display{background:#00000059;border:1px solid #ffffff0f;border-radius:12px;align-items:center;gap:12px;padding:10px 16px;display:flex}.room-code-value{letter-spacing:.1em;color:var(--on-surface);-webkit-user-select:all;user-select:all;cursor:text;flex:1;font-family:JetBrains Mono,Fira Code,SF Mono,Cascadia Code,monospace;font-size:clamp(20px,5vw,28px);font-weight:700}.room-code-copy-btn{color:var(--primary);font-family:var(--font-headline);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;white-space:nowrap;background:#7ddc7a1f;border:1px solid #7ddc7a33;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-size:11px;font-weight:700;transition:all .2s;display:flex}.room-code-copy-btn:hover{background:#7ddc7a38;border-color:#7ddc7a66;transform:scale(1.04);box-shadow:0 0 16px #7ddc7a26}.room-code-copy-btn:active{transform:scale(.97)}.room-code-copy-btn.copied{border-color:var(--primary);color:var(--on-primary-container);background:#7ddc7a4d;box-shadow:0 0 20px #7ddc7a40}.room-code-copy-btn .material-symbols-outlined{font-size:16px}.room-code-copy-label{font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit}.waiting-player-grid{grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-width:600px;display:grid}.player-slot-filled{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#19392d66;border:1px solid #ffffff0d;border-radius:14px;padding:14px;position:relative;overflow:hidden}.player-slot-filled.is-you{background:var(--surface-high);outline:2px solid var(--primary);outline-offset:0;box-shadow:0 0 24px #7ddc7a1f}.player-slot-shimmer{opacity:.3;pointer-events:none;position:absolute;inset:0}.player-slot-crown{color:var(--tertiary);position:absolute;top:8px;right:8px;font-size:16px!important}.player-slot-check{border-radius:var(--radius-full);background:var(--primary);width:22px;height:22px;color:var(--on-primary);box-shadow:0 0 8px var(--primary);justify-content:center;align-items:center;display:flex;position:absolute;top:8px;right:8px}.player-slot-check .material-symbols-outlined{font-size:14px!important}.player-slot-inner{z-index:1;align-items:center;gap:10px;display:flex;position:relative}.player-avatar-wrap{flex-shrink:0;position:relative}.player-avatar-circle{border-radius:var(--radius-full);background:var(--surface-highest);width:44px;height:44px;font-family:var(--font-headline);color:var(--primary);border:2px solid #7ddc7a40;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.player-avatar-circle.is-you{border-color:var(--primary);background:var(--primary-container);color:var(--on-primary-container);box-shadow:0 0 12px #7ddc7a59}.player-avatar-online{border-radius:var(--radius-full);background:var(--primary);border:2px solid var(--surface-high);width:12px;height:12px;position:absolute;bottom:0;right:0}.player-info{flex-direction:column;gap:2px;min-width:0;display:flex}.player-name-row{align-items:center;gap:6px;min-width:0;display:flex}.player-name{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.02em;color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.player-you-badge{text-transform:uppercase;color:var(--primary);background:#7ddc7a1a;border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:8px;font-weight:700}.player-status{font-family:var(--font-headline);letter-spacing:.1em;text-transform:uppercase;color:var(--primary);font-size:9px;font-weight:700}.player-slot-empty{opacity:.5;background:#19392d1a;border:2px dashed #ffffff0f;border-radius:14px;align-items:center;gap:10px;padding:14px;display:flex}.player-slot-empty-avatar{border-radius:var(--radius-full);color:#ffffff14;background:#ffffff08;border:2px dashed #ffffff14;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.player-slot-empty-avatar .material-symbols-outlined{font-size:20px!important}.player-slot-empty-label{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:.08em;color:#1b543399;font-size:11px;font-weight:700}.waiting-footer{z-index:20;-webkit-backdrop-filter:blur(24px);background:#011208e6;border-top:1px solid #ffffff14;width:100%;position:fixed;bottom:0;left:0;box-shadow:0 -10px 40px #000000b3}.waiting-action-bar{padding:12px 16px;padding-left:max(16px, env(safe-area-inset-left,0px));padding-right:max(16px, env(safe-area-inset-right,0px))}.waiting-start-btn{width:100%;font-family:var(--font-headline);letter-spacing:.1em;text-transform:uppercase;transition:all var(--transition-fast);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px 24px;font-size:14px;font-weight:900;display:flex;position:relative;overflow:hidden}.waiting-start-btn--host{color:#fff;background:linear-gradient(135deg,#b71c1c,#e53935);box-shadow:0 4px 20px #a9011166}.waiting-start-btn--host:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 28px #a9011199}.waiting-start-btn--host:active:not(:disabled){transform:scale(.98)}.waiting-start-btn--host:disabled{opacity:.5;cursor:not-allowed;filter:saturate(.5)}.waiting-start-btn--ready{color:#fff;background:linear-gradient(135deg,#2e7d32,#43a047);box-shadow:0 4px 20px #43a04766}.waiting-start-btn--ready:hover{box-shadow:0 4px 28px #43a04799}.waiting-start-btn--ready:active{transform:scale(.98)}.waiting-start-btn--wait{color:#ffffffe6;background:linear-gradient(135deg,#b71c1c,#c62828);box-shadow:0 4px 16px #a901114d}.waiting-start-btn--wait:hover{box-shadow:0 4px 24px #a9011180}.waiting-start-btn--wait:active{transform:scale(.98)}.waiting-tabs{padding:6px 12px 8px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));background:#00000026;border-top:1px solid #ffffff0a;justify-content:space-around;align-items:center;display:flex}.waiting-tab{color:#1b5433b3;font-family:var(--font-headline);letter-spacing:.1em;text-transform:uppercase;transition:all var(--transition-fast);border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:6px 20px;font-size:9px;font-weight:700;display:flex}.waiting-tab.active{color:var(--on-primary);background:linear-gradient(135deg,#43a047cc,#46a34ae6);box-shadow:0 0 15px #7ddc7a59}.waiting-tab:not(.active):hover{color:var(--on-surface-variant)}.waiting-tab .material-symbols-outlined{font-size:20px}@media (width>=769px){.waiting-topbar{padding:16px 24px}.waiting-back-btn,.waiting-settings-btn{width:40px;height:40px}.waiting-room-badge{gap:10px;padding:8px 18px}.waiting-room-badge span{font-size:14px}.waiting-main{justify-content:center;padding:40px 32px 180px}.waiting-title{margin-bottom:36px}.waiting-title h2{font-size:52px}.waiting-title p{letter-spacing:.2em;margin-top:6px;font-size:11px}.room-code-card{border-radius:20px;gap:12px;margin-bottom:36px;padding:20px 28px}.room-code-label{gap:8px;font-size:11px}.room-code-display{border-radius:14px;gap:14px;padding:14px 20px}.room-code-copy-btn{border-radius:10px;padding:10px 20px;font-size:12px}.room-code-copy-btn .material-symbols-outlined{font-size:18px}.waiting-player-grid{gap:20px;max-width:900px}.player-slot-filled{border-radius:20px;padding:22px}.player-avatar-circle{border-width:3px;width:56px;height:56px;font-size:20px}.player-avatar-online{border-width:3px;width:14px;height:14px}.player-slot-inner{gap:16px}.player-name{font-size:16px}.player-status{font-size:10px}.player-you-badge{padding:2px 7px;font-size:9px}.player-slot-crown{top:12px;right:12px;font-size:20px!important}.player-slot-check{width:26px;height:26px;top:12px;right:12px}.player-slot-check .material-symbols-outlined{font-size:16px!important}.player-slot-empty{border-radius:20px;gap:16px;padding:22px}.player-slot-empty-avatar{width:56px;height:56px}.player-slot-empty-avatar .material-symbols-outlined{font-size:24px!important}.player-slot-empty-label{font-size:13px}.waiting-action-bar{max-width:600px;margin:0 auto;padding:14px 40px}.waiting-start-btn{border-radius:14px;padding:16px 36px;font-size:15px}.waiting-tabs{padding:8px 16px 12px}.waiting-tab{gap:4px;padding:8px 24px;font-size:10px}}@media (width<=950px) and (height<=500px){.waiting-main{padding:8px 16px 120px;padding-left:max(16px, env(safe-area-inset-left,0px));padding-right:max(16px, env(safe-area-inset-right,0px))}.waiting-title{margin-bottom:8px}.waiting-title h2{font-size:clamp(24px,5vw,36px)}.room-code-card{border-radius:12px;max-width:420px;margin-bottom:10px;padding:8px 14px}.room-code-label{font-size:8px}.room-code-display{border-radius:8px;padding:6px 10px}.room-code-value{font-size:clamp(16px,3vw,22px)}.room-code-copy-btn{padding:5px 10px;font-size:9px}.waiting-player-grid{gap:8px}.player-slot-filled{border-radius:10px;padding:10px}.player-avatar-circle{width:36px;height:36px;font-size:13px}.player-slot-inner{gap:8px}.player-name{font-size:11px}.player-status{font-size:8px}.player-slot-empty{border-radius:10px;padding:10px}.player-slot-empty-avatar{width:36px;height:36px}.waiting-card-motif{display:none}.waiting-action-bar{padding:8px 12px}.waiting-start-btn{padding:10px 20px;font-size:12px}.waiting-tabs{padding:4px 8px 6px}.waiting-tab{gap:2px;padding:4px 12px;font-size:8px}.waiting-tab .material-symbols-outlined{font-size:18px}}@media (width<=380px){.room-code-card{padding:10px 14px}.room-code-value{font-size:18px}.player-slot-filled{padding:10px}.player-avatar-circle{width:36px;height:36px;font-size:14px}.player-name{font-size:12px}.player-slot-empty-avatar{width:36px;height:36px}}.game-page{background-image:radial-gradient(circle,#1a472a 0%,#04170d 100%);width:100vw;height:100dvh;display:flex;position:relative;overflow:hidden}.game-page:before{content:"";opacity:.05;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.game-sidebar{z-index:10;-webkit-backdrop-filter:blur(24px);background:#011208a6;border-right:0;flex-direction:column;flex-shrink:0;width:220px;padding:24px 16px;display:flex;position:relative;box-shadow:16px 0 48px #00220480}@media (width<=768px){.game-sidebar{display:none}}.game-sidebar-profile{align-items:center;gap:12px;margin-bottom:32px;display:flex}.game-sidebar-avatar{border-radius:var(--radius-full);background:var(--primary-container);border:2px solid var(--primary);width:48px;height:48px;font-family:var(--font-headline);color:var(--on-primary-container);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.game-sidebar-name{font-family:var(--font-headline);color:var(--primary);font-size:13px;font-weight:700}.game-sidebar-level{color:#1b5433b3;font-size:11px}.game-sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.game-sidebar-link{border-radius:var(--radius-sm);font-family:var(--font-headline);color:#1b5433b3;transition:all var(--transition-fast);border-right:2px solid #0000;align-items:center;gap:12px;padding:10px 12px;font-size:13px;font-weight:500;display:flex}.game-sidebar-link:hover{color:var(--on-surface-variant);background:#7ddc7a0d}.game-sidebar-link.active{color:var(--primary);border-right-color:var(--primary)}.game-sidebar-footer-btn{background:linear-gradient(135deg, var(--primary), var(--primary-container));color:var(--on-primary);font-family:var(--font-headline);letter-spacing:.12em;text-transform:uppercase;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-top:16px;padding:12px 16px;font-size:11px;font-weight:700;box-shadow:0 4px 16px #46a34a4d}.game-sidebar-footer-btn:hover{filter:brightness(1.1)}.game-canvas{z-index:1;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.game-topbar{z-index:20;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:absolute;top:0;left:0;right:0}.game-topbar-title{font-family:var(--font-headline);color:var(--primary);text-transform:uppercase;letter-spacing:-.02em;font-size:16px;font-weight:700}.game-topbar-actions{align-items:center;gap:16px;display:flex}.game-topbar-icon-btn{color:var(--primary);transition:color var(--transition-fast);justify-content:center;align-items:center;display:flex}.game-topbar-icon-btn:hover{color:var(--on-surface)}.opponent-top{z-index:10;flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;top:64px;left:50%;transform:translate(-50%)}.opponent-avatar-wrap{position:relative}.opponent-avatar{border-radius:var(--radius-full);border:2px solid var(--primary);background:var(--surface-high);width:60px;height:60px;font-family:var(--font-headline);color:var(--primary);justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex;position:relative}.opponent-card-badge{background:var(--secondary-container);color:var(--on-secondary-container);font-family:var(--font-mono);border-radius:var(--radius-full);white-space:nowrap;padding:2px 8px;font-size:9px;font-weight:700;position:absolute;bottom:-8px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0006}.opponent-name{font-family:var(--font-headline);color:var(--on-surface);margin-top:8px;font-size:13px;font-weight:500}.opponent-hand{display:flex}.opponent-card{background:var(--surface-highest);width:32px;height:46px;box-shadow:var(--shadow-card);border:1px solid #ffffff14;border-radius:6px}.opponent-hand .opponent-card+.opponent-card{margin-left:-14px}.opponent-left{z-index:10;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.opponent-left-inner{flex-direction:column;align-items:center;gap:6px;display:flex;transform:rotate(90deg)}.opponent-right{z-index:10;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.opponent-right-inner{flex-direction:column;align-items:center;gap:6px;display:flex;transform:rotate(-90deg)}.game-center-table{z-index:5;justify-content:center;align-items:center;gap:40px;display:flex;position:relative}.game-direction-ring{pointer-events:none;border:1px solid #7ddc7a14;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:-80px}.game-direction-icon{color:#7ddc7a1f;font-size:160px!important}.draw-pile{cursor:pointer;transition:transform var(--transition-fast);position:relative}.draw-pile:active{transform:scale(.95)}.draw-pile-shadow-3,.draw-pile-shadow-2,.draw-pile-shadow-1{border-radius:14px;width:104px;height:146px;position:absolute;top:0;left:0}.draw-pile-shadow-3{background:var(--surface-lowest);transform:translate(6px,6px)}.draw-pile-shadow-2{background:var(--surface-low);border-left:1px solid #ffffff0a;transform:translate(4px,4px)}.draw-pile-shadow-1{background:var(--surface-high);border-left:1px solid #ffffff0a;transform:translate(2px,2px)}.draw-pile-top{background:var(--surface-highest);border:1px solid #ffffff14;border-radius:14px;justify-content:center;align-items:center;width:104px;height:146px;display:flex;position:relative;box-shadow:0 10px 20px #00000080}.draw-pile-inner{border:2px solid #7ddc7a2e;border-radius:8px;justify-content:center;align-items:center;width:78px;height:116px;display:flex}.draw-pile-count{font-family:var(--font-headline);color:var(--primary);opacity:.8;font-size:32px;font-weight:700}.discard-pile{position:relative}.discard-drop-zone{pointer-events:none;border:2px dashed #7ddc7a2e;border-radius:20px;position:absolute;inset:-20px}.discard-color-ring{pointer-events:none;filter:blur(2px);opacity:.5;border:3px solid;border-radius:18px;position:absolute;inset:-12px}.discard-color-ring.blue{border-color:var(--uno-blue);box-shadow:0 0 30px #1e88e566}.discard-color-ring.red{border-color:var(--uno-red);box-shadow:0 0 30px #e5393566}.discard-color-ring.green{border-color:var(--uno-green);box-shadow:0 0 30px #43a04766}.discard-color-ring.yellow{border-color:var(--uno-yellow);box-shadow:0 0 30px #fdd83566}.discard-stack{width:104px;height:146px;position:relative}.discard-card-behind-2,.discard-card-behind-1,.discard-card-top{border-radius:14px;position:absolute;inset:0;box-shadow:0 10px 20px #00000080}.discard-card-behind-2{background:var(--uno-red);transform:rotate(-12deg)translate(4px)}.discard-card-behind-1{background:var(--uno-yellow);transform:rotate(6deg)translate(-2px)}.discard-card-top{border:1px solid #fff3;flex-direction:column;padding:8px;display:flex}.discard-card-top.blue{background:var(--uno-blue)}.discard-card-top.red{background:var(--uno-red)}.discard-card-top.green{background:var(--uno-green)}.discard-card-top.yellow{background:var(--uno-yellow)}.discard-corner-num{font-family:var(--font-headline);color:#fff;font-size:20px;font-weight:700;line-height:1}.discard-corner-num.bottom{align-self:flex-end;transform:rotate(180deg)}.discard-center{flex:1;justify-content:center;align-items:center;display:flex}.discard-oval{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:68px;height:96px;display:flex}.discard-big-num{font-family:var(--font-headline);color:#fff;text-shadow:0 2px 12px #0006;font-size:52px;font-style:italic;font-weight:900}.game-hud{z-index:20;flex-direction:column;align-items:flex-end;gap:12px;display:flex;position:absolute;top:64px;right:24px}.game-hud-turn-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-left:4px solid var(--primary);text-align:right;background:#1a2e22b3;border-radius:16px;padding:16px 22px;box-shadow:0 8px 32px #0006}.game-hud-turn-label{font-family:var(--font-headline);color:var(--primary);letter-spacing:-.03em;font-size:22px;font-weight:700}.game-hud-timer{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:#1b5433cc;justify-content:flex-end;align-items:center;gap:6px;margin-top:4px;font-size:12px;font-weight:500;display:flex}.game-hud-round{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--font-mono);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.06em;background:#25392d80;border-radius:10px;padding:8px 18px;font-size:11px}.game-hud-uno-btn{background:var(--secondary-container);color:#fff;font-family:var(--font-headline);letter-spacing:.05em;border-radius:var(--radius-full);transition:transform var(--transition-fast);padding:14px 28px;font-size:22px;font-weight:900;animation:1.8s ease-in-out infinite pulse-uno;box-shadow:0 0 30px #a9011180}.game-hud-uno-btn:hover{transform:scale(1.05)}.game-hud-uno-btn:active{transform:scale(.95)}@keyframes pulse-uno{0%,to{box-shadow:0 0 20px #a9011166}50%{box-shadow:0 0 40px #a90111b3}}.player-hand-zone{z-index:15;align-items:flex-end;padding:0 60px;display:flex;position:absolute;bottom:60px;left:50%;transform:translate(-50%)}.discard-top-card-wrap{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.discard-top-card-wrap .card-root{--card-width:104px;width:104px}.game-bottom-nav{z-index:20;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#01120880;border-radius:20px 20px 0 0;gap:4px;padding:8px 12px 12px;display:flex;position:absolute;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -8px 32px #00000080}.game-bottom-nav-btn{color:#1b5433b3;font-family:var(--font-headline);letter-spacing:.12em;text-transform:uppercase;transition:all var(--transition-fast);border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:8px 22px;font-size:9px;font-weight:700;display:flex}.game-bottom-nav-btn:hover{color:var(--on-surface-variant);background:#7ddc7a0d}.discard-pile.drop-zone-active .discard-drop-zone{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary), 0 0 24px #46c87880, 0 0 48px #46c87833;border-style:solid;animation:.9s ease-in-out infinite drop-zone-pulse}.discard-pile.drop-zone-active .discard-stack{filter:brightness(1.15)}@keyframes drop-zone-pulse{0%,to{box-shadow:0 0 0 2px var(--primary), 0 0 24px #46c87880, 0 0 48px #46c87833}50%{box-shadow:0 0 0 3px var(--primary), 0 0 32px #46c878b3, 0 0 64px #46c87859}}.game-sidebar-reject-btn{color:#fff;font-family:var(--font-headline);letter-spacing:.12em;text-transform:uppercase;border-radius:var(--radius-md);transition:all var(--transition-fast);opacity:.5;pointer-events:none;background:linear-gradient(135deg,#c62828,#7b0000);margin-top:8px;padding:12px 16px;font-size:11px;font-weight:700;box-shadow:0 4px 16px #c6282859}.game-sidebar-reject-btn.active{opacity:1;pointer-events:auto}.game-sidebar-reject-btn.active:hover{filter:brightness(1.12);transform:translateY(-1px)}.game-sidebar-played-label{border-radius:var(--radius-sm);font-family:var(--font-mono);letter-spacing:.05em;color:var(--primary);text-align:center;background:#46c87814;border:1px solid #46c87833;margin-top:8px;padding:8px 12px;font-size:10px;line-height:1.5;display:none}.game-sidebar-played-label.visible{display:block}.game-hud-turn-label.my-turn{color:gold;text-shadow:0 0 20px #ffd70080;animation:1.5s ease-in-out infinite my-turn-pulse}@keyframes my-turn-pulse{0%,to{text-shadow:0 0 20px #ffd70066}50%{text-shadow:0 0 36px #ffd700cc}}.draw-pile.is-my-turn .draw-pile-top{border-color:#7ddc7a4d;box-shadow:0 10px 20px #00000080,0 0 24px #46c87859}.game-hud-uno-btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none;animation:none}.game-sidebar-gameover{border-radius:var(--radius-md);text-align:center;color:gold;font-family:var(--font-headline);background:#ffd70014;border:1px solid #ffd70040;flex-direction:column;align-items:center;gap:10px;margin-top:16px;padding:16px;font-size:13px;font-weight:700;animation:.4s ease-out slideDown;display:flex}.turn-timer-bar{z-index:60;pointer-events:none;height:6px;transition:height .25s;position:absolute;top:0;left:0;right:0}.turn-timer-bar--mine{height:8px}.turn-timer-bar__track{background:#ffffff0a;width:100%;height:100%;position:relative;overflow:hidden}.turn-timer-bar__fill{will-change:width;border-radius:0 4px 4px 0;height:100%;transition:width .8s linear,background .4s;position:absolute;top:0;left:0}.turn-timer-bar--safe .turn-timer-bar__fill{background:linear-gradient(90deg,#43a047,#7ddc7a,#98f994);box-shadow:0 0 12px #7ddc7a80,0 2px 8px #7ddc7a4d}.turn-timer-bar--warn .turn-timer-bar__fill{background:linear-gradient(90deg,#f9a825,#fdd835,#ffe082);box-shadow:0 0 12px #fdd83580,0 2px 8px #f9a8254d}.turn-timer-bar--danger .turn-timer-bar__fill{background:linear-gradient(90deg,#b71c1c,#e53935,#ff6f60);box-shadow:0 0 16px #e5393599,0 2px 12px #e5393566}.turn-timer-bar__shimmer{pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff26 30%,#ffffff59 50%,#ffffff26 70%,#0000 100%) 0 0/200% 100%;border-radius:0 4px 4px 0;height:100%;animation:2.5s linear infinite timer-shimmer;position:absolute;top:0;left:0}@keyframes timer-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.turn-timer-bar__edge{pointer-events:none;border-radius:50%;width:12px;height:200%;transition:left .8s linear;position:absolute;top:50%;transform:translate(-50%,-50%)}.turn-timer-bar--safe .turn-timer-bar__edge{background:radial-gradient(circle,#7ddc7acc,#0000 70%)}.turn-timer-bar--warn .turn-timer-bar__edge{background:radial-gradient(circle,#fdd835cc,#0000 70%)}.turn-timer-bar--danger .turn-timer-bar__edge{background:radial-gradient(circle,#e53935e6,#0000 70%)}.turn-timer-bar__ticks{pointer-events:none;height:100%;position:absolute;top:0;left:0;right:0}.turn-timer-bar__tick{background:#ffffff14;width:1px;height:100%;position:absolute;top:0}.turn-timer-bar__badge{-webkit-backdrop-filter:blur(12px);pointer-events:auto;z-index:61;background:#011208d9;border:1px solid #ffffff0f;border-top:none;border-radius:0 0 12px 12px;align-items:center;gap:6px;padding:4px 14px;transition:all .3s;display:flex;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.turn-timer-bar__seconds{font-family:var(--font-headline);letter-spacing:-.02em;font-size:16px;font-weight:900;line-height:1;transition:color .3s}.turn-timer-bar--safe .turn-timer-bar__seconds{color:#7ddc7a}.turn-timer-bar--warn .turn-timer-bar__seconds{color:#fdd835}.turn-timer-bar--danger .turn-timer-bar__seconds{color:#e53935}.turn-timer-bar__unit{font-family:var(--font-mono);color:#d0e8d766;letter-spacing:.06em;font-size:10px;font-weight:500}.turn-timer-bar__label{font-family:var(--font-headline);letter-spacing:.18em;text-transform:uppercase;color:gold;text-shadow:0 0 10px #ffd70066;font-size:9px;font-weight:800;animation:1.5s ease-in-out infinite timer-label-pulse}@keyframes timer-label-pulse{0%,to{opacity:1}50%{opacity:.6}}.turn-timer-bar--shake{animation:.4s ease-in-out infinite timer-bar-shake}@keyframes timer-bar-shake{0%,to{transform:translate(0)}25%{transform:translate(-1px)}75%{transform:translate(1px)}}.turn-timer-bar--danger .turn-timer-bar__badge{animation:.8s ease-in-out infinite timer-badge-danger-pulse}@keyframes timer-badge-danger-pulse{0%,to{box-shadow:0 4px 16px #0006,0 0 8px #e539354d}50%{box-shadow:0 4px 20px #00000080,0 0 16px #e5393599}}.turn-timer-bar--mine .turn-timer-bar__badge{border-color:#ffd70026}.player-avatar{flex-direction:column;align-items:center;gap:4px;display:flex;position:relative}.player-avatar__circle{border-radius:var(--radius-full);border:2px solid #ffffff1f;justify-content:center;align-items:center;transition:box-shadow .3s,border-color .3s;display:flex;position:relative;overflow:hidden}.player-avatar--sm .player-avatar__circle{width:40px;height:40px}.player-avatar--md .player-avatar__circle{width:56px;height:56px}.player-avatar--lg .player-avatar__circle{width:72px;height:72px}.player-avatar__initials{font-family:var(--font-headline);color:#fff;text-shadow:0 1px 4px #0006;font-weight:700}.player-avatar--sm .player-avatar__initials{font-size:14px}.player-avatar--md .player-avatar__initials{font-size:18px}.player-avatar--lg .player-avatar__initials{font-size:24px}.player-avatar--active .player-avatar__circle{border-color:var(--primary);animation:1.8s ease-in-out infinite avatar-active-glow;box-shadow:0 0 0 3px #7ddc7a59,0 0 20px #7ddc7a80,0 0 40px #7ddc7a40}@keyframes avatar-active-glow{0%,to{box-shadow:0 0 0 3px #7ddc7a59,0 0 20px #7ddc7a80,0 0 40px #7ddc7a33}50%{box-shadow:0 0 0 4px #7ddc7a80,0 0 30px #7ddc7ab3,0 0 60px #7ddc7a59}}.player-avatar--mine .player-avatar__circle{border-color:gold;box-shadow:0 0 12px #ffd7004d}.player-avatar--disconnected .player-avatar__circle{filter:saturate(0)brightness(.6)}.player-avatar__disconnected-overlay{color:#e53935;border-radius:var(--radius-full);background:#000000a6;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.player-avatar__uno-badge{color:#fff;font-family:var(--font-headline);letter-spacing:.06em;border-radius:var(--radius-full);white-space:nowrap;background:#e53935;border:1.5px solid #ffffff4d;padding:2px 6px;font-size:9px;font-weight:900;animation:1s ease-in-out infinite uno-badge-pulse;position:absolute;top:-6px;right:-12px;box-shadow:0 0 10px #e5393580}@keyframes uno-badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08);box-shadow:0 0 16px #e53935b3}}.player-avatar__hand-count{background:var(--surface-highest);color:var(--on-surface);font-family:var(--font-mono);border-radius:var(--radius-full);white-space:nowrap;border:1px solid #ffffff1a;padding:1px 7px;font-size:9px;font-weight:700;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.player-avatar__name{font-family:var(--font-headline);color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:11px;font-weight:600;overflow:hidden}.player-avatar__name-you{color:var(--primary);font-size:9px;font-weight:500}.player-avatar--disconnected .player-avatar__name{color:var(--on-surface-variant);opacity:.5}.game-log{z-index:25;-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-md);background:#011208bf;border:1px solid #7ddc7a1a;width:240px;transition:all .25s;position:absolute;bottom:68px;left:16px;overflow:hidden;box-shadow:0 8px 32px #00000080}.game-log__header{cursor:pointer;text-align:left;width:100%;color:var(--on-surface-variant);font-family:var(--font-headline);align-items:center;gap:8px;padding:10px 12px;font-size:12px;font-weight:600;transition:background .15s;display:flex}.game-log__header:hover{background:#7ddc7a0d}.game-log__icon{color:#7ddc7a80;flex-shrink:0;font-size:16px!important}.game-log__title{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--primary);flex:1;font-size:10px}.game-log__last-entry{font-family:var(--font-body);color:var(--on-surface-variant);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:11px;overflow:hidden}.game-log__last-entry[data-type=turn]{color:var(--primary)}.game-log__last-entry[data-type=play]{color:#e8c41d}.game-log__last-entry[data-type=win]{color:gold}.game-log__last-entry[data-type=error]{color:var(--secondary)}.game-log__chevron{color:var(--on-surface-variant);opacity:.6;flex-shrink:0;align-items:center;display:flex}.game-log__list{scrollbar-width:thin;scrollbar-color:#7ddc7a33 transparent;max-height:200px;padding:0 0 8px;overflow-y:auto}.game-log__list::-webkit-scrollbar{width:4px}.game-log__list::-webkit-scrollbar-track{background:0 0}.game-log__list::-webkit-scrollbar-thumb{background:#7ddc7a33;border-radius:4px}.game-log__entry{border-left:2px solid #0000;align-items:baseline;gap:8px;padding:4px 12px;font-size:11px;animation:.2s ease-out log-entry-in;display:flex}@keyframes log-entry-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.game-log__entry[data-type=turn]{border-left-color:var(--primary)}.game-log__entry[data-type=play]{border-left-color:#e8c41d}.game-log__entry[data-type=system]{border-left-color:#ffffff1a}.game-log__entry[data-type=win]{border-left-color:gold}.game-log__entry[data-type=error]{border-left-color:var(--secondary)}.game-log__entry-ts{font-family:var(--font-mono);color:var(--on-surface-variant);opacity:.5;flex-shrink:0;font-size:9px}.game-log__entry-msg{font-family:var(--font-body);color:var(--on-surface-variant);line-height:1.4}.game-log__entry[data-type=turn] .game-log__entry-msg{color:var(--primary)}.game-log__entry[data-type=play] .game-log__entry-msg{color:#e8c41d}.game-log__entry[data-type=win] .game-log__entry-msg{color:gold;font-weight:700}.game-log__entry[data-type=error] .game-log__entry-msg{color:var(--secondary)}.connection-status{z-index:25;border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;font-family:var(--font-mono);letter-spacing:.06em;-webkit-user-select:none;user-select:none;background:#01120880;border:1px solid #7ddc7a14;flex-wrap:wrap;align-items:center;gap:6px;max-width:220px;padding:6px 12px;font-size:10px;transition:all .25s;display:flex;position:absolute;top:16px;left:16px}.connection-status:hover{background:#011208cc;border-color:#7ddc7a26}.connection-status--connected{background:#01120859;padding:6px 10px}.connection-status--error{border-radius:var(--radius-md);background:#a901111f;border-color:#e539354d}.connection-status--expanded{border-radius:var(--radius-md)}.connection-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.connection-dot--idle{background:var(--on-surface-variant);opacity:.3}.connection-dot--connecting{background:#e8c41d;animation:.8s ease-in-out infinite blink-dot;box-shadow:0 0 8px #e8c41d}.connection-dot--connected{background:var(--primary);animation:3s ease-in-out infinite pulse-dot;box-shadow:0 0 8px #7ddc7a99}.connection-dot--error{background:#e53935;animation:.5s ease-in-out infinite blink-dot;box-shadow:0 0 8px #e5393599}@keyframes blink-dot{0%,to{opacity:1}50%{opacity:.2}}.connection-status__label{color:var(--on-surface-variant);opacity:.8}.connection-status--connected .connection-status__label{opacity:.5}.connection-status--error .connection-status__label{color:#e53935;opacity:1}.connection-status__ping{font-family:var(--font-mono);color:var(--primary);opacity:.7;font-size:10px}.connection-status__error-msg{width:100%;font-family:var(--font-body);color:#ffb4ac;border-top:1px solid #e5393533;margin-top:2px;padding-top:4px;font-size:11px;line-height:1.4}.color-picker-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;animation:.2s ease-out color-picker-fade-in;display:flex;position:fixed;inset:0}@keyframes color-picker-fade-in{0%{opacity:0}to{opacity:1}}.color-picker-card{-webkit-backdrop-filter:blur(24px);background:#0f2318f2;border:1px solid #7ddc7a26;border-radius:24px;outline:none;flex-direction:column;align-items:center;gap:24px;padding:32px 36px;animation:.25s ease-out color-picker-slide-up;display:flex;box-shadow:0 24px 80px #0009,inset 0 1px #ffffff0d}@keyframes color-picker-slide-up{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.color-picker-title{font-family:var(--font-headline);color:var(--on-surface);letter-spacing:-.02em;text-transform:uppercase;align-items:center;gap:10px;font-size:20px;font-weight:700;display:flex}.color-picker-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.color-picker-btn{cursor:pointer;background:#ffffff0a;border:2px solid #ffffff14;border-radius:18px;flex-direction:column;align-items:center;gap:10px;min-width:110px;padding:20px 28px;transition:all .2s;display:flex}.color-picker-btn:hover{border-color:var(--picker-color);box-shadow:0 0 24px var(--picker-glow), 0 0 48px var(--picker-glow);background:#ffffff14;transform:scale(1.06)}.color-picker-btn:active{transform:scale(.96)}.color-picker-btn-swatch{background:var(--picker-color);width:56px;height:56px;box-shadow:0 4px 16px var(--picker-glow);border-radius:14px;transition:all .2s}.color-picker-btn:hover .color-picker-btn-swatch{box-shadow:0 6px 24px var(--picker-glow);transform:scale(1.08)}.color-picker-btn-label{font-family:var(--font-headline);letter-spacing:.08em;text-transform:uppercase;color:var(--on-surface);font-size:13px;font-weight:700}.color-picker-hint{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:#7ddc7a80;font-size:10px}.current-color-badge{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#011208b3;border:1px solid #ffffff14;align-items:center;gap:8px;margin-top:12px;padding:6px 14px;transition:all .3s;display:flex}.current-color-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;transition:background .3s,box-shadow .3s}.current-color-dot.color-red{background:#e53935;box-shadow:0 0 10px #e5393580}.current-color-dot.color-blue{background:#1e88e5;box-shadow:0 0 10px #1e88e580}.current-color-dot.color-green{background:#43a047;box-shadow:0 0 10px #43a04780}.current-color-dot.color-yellow{background:#fdd835;box-shadow:0 0 10px #fdd83580}.current-color-label{font-family:var(--font-headline);letter-spacing:.1em;text-transform:uppercase;color:var(--on-surface);font-size:11px;font-weight:700}.game-page--portrait{background:radial-gradient(circle,#1a472a 0%,#04170d 100%);flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.mobile-topbar{z-index:50;height:56px;padding:0 16px;padding-top:env(safe-area-inset-top,0px);-webkit-backdrop-filter:blur(20px);background:#10241899;border-bottom:1px solid #7ddc7a14;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 24px #0000004d}.mobile-topbar__menu-btn{border-radius:var(--radius-md);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .15s;display:flex}.mobile-topbar__menu-btn:active{transform:scale(.92)}.mobile-topbar__menu-btn .material-symbols-outlined{color:var(--primary);font-size:24px}.mobile-topbar__color-pill{border-radius:var(--radius-full);background:#00000040;border:1px solid #7ddc7a26;align-items:center;gap:6px;padding:4px 12px;display:flex}.mobile-topbar__color-pill.color-RED{background:#e539351a;border-color:#e539354d}.mobile-topbar__color-pill.color-GREEN{background:#43a0471a;border-color:#43a0474d}.mobile-topbar__color-pill.color-BLUE{background:#1e88e51a;border-color:#1e88e54d}.mobile-topbar__color-pill.color-YELLOW{background:#fdd8351a;border-color:#fdd8354d}.mobile-topbar__color-dot{border-radius:var(--radius-full);width:8px;height:8px}.mobile-topbar__color-dot.color-RED{background:var(--uno-red);box-shadow:0 0 8px var(--uno-red)}.mobile-topbar__color-dot.color-GREEN{background:var(--uno-green);box-shadow:0 0 8px var(--uno-green)}.mobile-topbar__color-dot.color-BLUE{background:var(--uno-blue);box-shadow:0 0 8px var(--uno-blue)}.mobile-topbar__color-dot.color-YELLOW{background:var(--uno-yellow);box-shadow:0 0 8px var(--uno-yellow)}.mobile-topbar__color-label{font-family:var(--font-headline);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:700}.mobile-topbar__color-pill.color-RED .mobile-topbar__color-label{color:var(--uno-red)}.mobile-topbar__color-pill.color-GREEN .mobile-topbar__color-label{color:var(--uno-green)}.mobile-topbar__color-pill.color-BLUE .mobile-topbar__color-label{color:var(--uno-blue)}.mobile-topbar__color-pill.color-YELLOW .mobile-topbar__color-label{color:var(--uno-yellow)}.mobile-topbar__right{align-items:center;gap:8px;display:flex}.mobile-topbar__icon-btn{cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .15s;display:flex}.mobile-topbar__icon-btn:active{transform:scale(.92)}.mobile-topbar__icon-btn .material-symbols-outlined{color:#d0e8d780;font-size:22px}.mobile-opponents{padding-top:calc(56px + env(safe-area-inset-top,0px) + 12px);justify-content:center;align-items:center;gap:12px;min-height:120px;padding-bottom:8px;display:flex}.mobile-opponents__arrow{color:#7ddc7a33;font-size:12px}.mobile-opponents__arrow:nth-child(2){color:var(--primary);animation:2s ease-in-out infinite pulse}.mobile-opponent{opacity:.6;flex-direction:column;align-items:center;gap:2px;transition:opacity .3s;display:flex}.mobile-opponent--active{opacity:1}.mobile-opponent--active .player-avatar__circle{box-shadow:0 0 15px var(--primary);border-color:var(--primary)!important}.mobile-opponent--empty{opacity:.3}.mobile-opponent__placeholder{font-family:var(--font-headline);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.1em;font-size:10px}.mobile-center-table{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:200px;padding:0 32px;display:flex;position:relative}.mobile-direction-ring{border-radius:var(--radius-full);border:1px solid #7ddc7a0d;justify-content:center;align-items:center;width:160px;height:160px;display:flex;position:absolute}.mobile-direction-ring__inner{border-radius:var(--radius-full);border:1px dashed #7ddc7a1a;width:128px;height:128px;animation:10s linear infinite mobile-spin}@keyframes mobile-spin{to{transform:rotate(360deg)}}.mobile-piles-row{z-index:10;align-items:center;gap:48px;display:flex}.mobile-draw-pile-wrap{flex-direction:column;align-items:center;gap:8px;display:flex}.mobile-draw-pile{width:80px;height:120px}.mobile-pile-label{font-family:var(--font-headline);letter-spacing:.2em;text-transform:uppercase;color:var(--primary);font-size:10px;font-weight:700}.mobile-discard-wrap{flex-direction:column;align-items:center;display:flex}.mobile-color-indicator{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#011208b3;border:1px solid #7ddc7a1a;align-items:center;gap:8px;margin-top:16px;padding:6px 16px;display:flex}.mobile-color-indicator.color-RED{border-color:#e5393540}.mobile-color-indicator.color-GREEN{border-color:#43a04740}.mobile-color-indicator.color-BLUE{border-color:#1e88e540}.mobile-color-indicator.color-YELLOW{border-color:#fdd83540}.mobile-color-indicator__dot{border-radius:var(--radius-full);width:10px;height:10px}.mobile-color-indicator__dot.color-RED{background:var(--uno-red);box-shadow:0 0 10px var(--uno-red)}.mobile-color-indicator__dot.color-GREEN{background:var(--uno-green);box-shadow:0 0 10px var(--uno-green)}.mobile-color-indicator__dot.color-BLUE{background:var(--uno-blue);box-shadow:0 0 10px var(--uno-blue)}.mobile-color-indicator__dot.color-YELLOW{background:var(--uno-yellow);box-shadow:0 0 10px var(--uno-yellow)}.mobile-color-indicator__label{font-family:var(--font-headline);letter-spacing:.12em;text-transform:uppercase;color:var(--on-surface);font-size:11px;font-weight:700}.mobile-turn-status{z-index:10;align-items:center;gap:12px;margin-top:12px;display:flex}.mobile-turn-label{font-family:var(--font-headline);letter-spacing:.15em;text-transform:uppercase;color:#7ddc7a80;font-size:12px;font-weight:700}.mobile-turn-label--mine{color:gold;text-shadow:0 0 10px #ffd70066;animation:2s ease-in-out infinite pulse}.game-page--portrait .turn-timer-bar{z-index:55;position:fixed;top:0;left:0;right:0}.game-page--portrait .turn-timer-bar__badge{padding:3px 10px;font-size:12px}.game-page--portrait .turn-timer-bar__seconds{font-size:13px}.mobile-player-hand{padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:15;align-items:flex-end;display:flex;position:absolute;bottom:0;left:0;right:0;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 4% 96%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 4% 96%,#0000 100%)}.mobile-uno-fab{bottom:calc(24px + env(safe-area-inset-bottom,0px));border-radius:var(--radius-full);color:#fff;width:56px;height:56px;font-family:var(--font-headline);letter-spacing:-.02em;cursor:pointer;z-index:20;opacity:0;pointer-events:none;background:#a90111;border:none;justify-content:center;align-items:center;font-size:13px;font-weight:900;transition:all .3s;display:flex;position:fixed;right:20px;transform:scale(.75);box-shadow:0 8px 24px #a9011166}.mobile-uno-fab--visible{opacity:1;pointer-events:auto;animation:2s ease-in-out infinite uno-pulse;transform:scale(1)}.mobile-uno-fab:disabled{opacity:.4;cursor:not-allowed}@keyframes uno-pulse{0%,to{box-shadow:0 8px 24px #a9011166}50%{box-shadow:0 8px 32px #a90111b3,0 0 16px #a901114d}}.game-page--portrait .connection-status{position:static}.game-page--portrait .connection-status__label,.game-page--portrait .connection-status__ping,.game-page--portrait .connection-status__error-msg{display:none}.game-page--portrait .player-avatar--sm .player-avatar__circle{width:40px;height:40px}.game-page--portrait .player-avatar--md .player-avatar__circle{width:48px;height:48px}.game-page--portrait .player-avatar--sm .player-avatar__initials{font-size:13px}.game-page--portrait .player-avatar--md .player-avatar__initials{font-size:16px}.game-page--portrait .player-avatar__name{max-width:64px;font-size:9px}.game-page--portrait .player-avatar__hand-count{padding:1px 6px;font-size:9px}.game-page--portrait .player-avatar__uno-badge{padding:2px 6px;font-size:8px}.game-page--portrait .draw-pile,.game-page--portrait .draw-pile-top{width:80px;height:120px}.game-page--portrait .draw-pile-inner{width:66px;height:106px}.game-page--portrait .draw-pile-count{font-size:28px}.game-page--portrait .discard-pile{width:80px;height:120px}.game-page--portrait .discard-color-ring{width:100px;height:140px;top:-10px;left:-10px}.game-page--portrait .card-pile-root{width:80px!important;height:120px!important}.game-page--portrait .card-root{--card-width:80px}.game-page--portrait .color-picker-card{border-radius:16px;gap:12px;padding:16px 20px}.game-page--portrait .color-picker-btn{border-radius:12px;min-width:80px;min-height:52px;padding:12px 16px}@media (width<=768px) and (orientation:portrait){.game-sidebar{display:none!important}.game-topbar,.game-hud,.game-bottom-nav,.game-log,.opponent-top,.opponent-left,.opponent-right,.game-center-table{display:none}}.mobile-toast-container{display:none}@media (width<=768px) and (orientation:portrait){.mobile-toast-container{z-index:50;pointer-events:none;flex-direction:column;gap:4px;max-width:80vw;display:flex;position:fixed;top:40px;left:50%;transform:translate(-50%)}}.mobile-toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-family:var(--font-body);color:var(--on-surface-variant);text-align:center;white-space:nowrap;background:#011208e6;border:1px solid #7ddc7a26;border-radius:8px;padding:6px 14px;font-size:11px;animation:.2s ease-out toast-in,.3s ease-in 2.7s forwards toast-out}.mobile-toast[data-type=turn]{border-left:2px solid var(--primary);color:var(--primary)}.mobile-toast[data-type=play]{color:#e8c41d;border-left:2px solid #e8c41d}.mobile-toast[data-type=error]{border-left:2px solid var(--secondary);color:var(--secondary)}.mobile-toast[data-type=win]{color:gold;border-left:2px solid gold}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{to{opacity:0;transform:translateY(-4px)}}.game-over-overlay{display:none}@media (width<=768px) and (orientation:portrait){.game-over-overlay{z-index:200;-webkit-backdrop-filter:blur(16px);background:#04170deb;flex-direction:column;justify-content:center;align-items:center;gap:16px;animation:.3s ease-out color-picker-fade-in;display:flex;position:fixed;inset:0}}.game-over-overlay__icon{color:gold;filter:drop-shadow(0 0 20px #ffd70080);font-size:56px}.game-over-overlay__title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.03em;color:gold;text-shadow:0 0 30px #ffd70066;font-size:clamp(24px,5vw,40px);font-weight:900}.game-over-overlay__subtitle{font-family:var(--font-headline);color:var(--on-surface-variant);font-size:14px;font-weight:600}.game-over-overlay__btn{background:var(--primary-container);color:var(--on-primary-container);font-family:var(--font-headline);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border-bottom:3px solid #0003;min-width:48px;min-height:48px;margin-top:8px;padding:14px 32px;font-size:14px;font-weight:700;box-shadow:0 8px 32px #46a34a33}.game-over-overlay__btn:hover{box-shadow:var(--shadow-glow-green)}.mobile-drawer-backdrop{display:none}@media (width<=768px) and (orientation:portrait){.mobile-drawer-backdrop{z-index:100;background:#00000080;animation:.2s ease-out color-picker-fade-in;display:block;position:fixed;inset:0}.mobile-drawer{z-index:101;-webkit-backdrop-filter:blur(24px);padding:12px 20px 20px;padding-bottom:max(20px, env(safe-area-inset-bottom,0px));background:#0f2318f2;border-top:1px solid #7ddc7a26;border-radius:20px 20px 0 0;max-height:80vh;animation:.25s ease-out drawer-slide-up;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -16px 64px #0009}}@keyframes drawer-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-drawer__handle{background:#ffffff26;border-radius:2px;width:36px;height:4px;margin:0 auto 12px}.mobile-drawer__profile{align-items:center;gap:12px;margin-bottom:16px;display:flex}.mobile-drawer__avatar{border-radius:var(--radius-full);background:var(--primary-container);border:2px solid var(--primary);width:40px;height:40px;font-family:var(--font-headline);color:var(--on-primary-container);justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.mobile-drawer__name{font-family:var(--font-headline);color:var(--primary);font-size:14px;font-weight:700}.mobile-drawer__stats{color:var(--on-surface-variant);font-size:11px}.mobile-drawer__actions{flex-direction:column;gap:8px;margin-top:8px;display:flex}.mobile-drawer__action-btn{border-radius:var(--radius-md);color:var(--on-surface-variant);font-family:var(--font-headline);text-transform:uppercase;letter-spacing:.06em;transition:background var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff0f;align-items:center;gap:10px;min-height:48px;padding:12px 16px;font-size:12px;font-weight:600;display:flex}.mobile-drawer__action-btn:hover{background:#ffffff14}.mobile-drawer__action-btn--danger{color:var(--secondary);border-color:#a9011133}.draw-pile-mobile-label{display:none}.player-avatar__uno-badge--big{color:#fff;font-family:var(--font-headline);letter-spacing:.06em;border-radius:var(--radius-full);white-space:nowrap;z-index:10;background:linear-gradient(135deg,#e53935,#ff6f00);border:2px solid #ffd70099;padding:4px 10px;font-size:13px;font-weight:900;animation:.8s ease-in-out infinite uno-badge-big-pulse;position:absolute;top:-10px;right:-16px;box-shadow:0 0 16px #e53935b3,0 0 32px #ff6b0066,0 2px 12px #00000080}@keyframes uno-badge-big-pulse{0%,to{transform:scale(1);box-shadow:0 0 16px #e53935b3,0 0 32px #ff6b0066}50%{transform:scale(1.15);box-shadow:0 0 24px #e53935e6,0 0 48px #ff6b0099,0 0 64px #ffd7004d}}.player-avatar--catchable .player-avatar__circle{border-color:#e53935!important;animation:.5s ease-in-out infinite avatar-catchable-flash!important;box-shadow:0 0 0 3px #e5393580,0 0 20px #e5393599,0 0 40px #e539354d!important}@keyframes avatar-catchable-flash{0%,to{box-shadow:0 0 0 3px #e5393580,0 0 20px #e5393599}50%{box-shadow:0 0 0 5px #e53935b3,0 0 30px #e53935cc,0 0 50px #e5393566}}.player-avatar__catch-warning{z-index:10;filter:drop-shadow(0 0 4px #e53935cc);font-size:16px;animation:.6s ease-in-out infinite catch-warning-bounce;position:absolute;top:-8px;left:-8px}@keyframes catch-warning-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes catch-btn-urgency{0%,to{transform:translate(-50%)scale(1);box-shadow:0 0 30px #e5393599,0 0 60px #e539354d,0 8px 24px #00000080}50%{transform:translate(-50%)scale(1.06);box-shadow:0 0 40px #e53935cc,0 0 80px #e5393580,0 8px 32px #0009}}.game-page--portrait .player-avatar__uno-badge--big{padding:3px 8px;font-size:10px;top:-8px;right:-12px}.game-page--portrait .player-avatar__catch-warning{font-size:12px;top:-6px;left:-6px}.card-root{width:var(--card-width,104px);aspect-ratio:2/3;perspective:800px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:none;flex-shrink:0;position:relative}.card-flip-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform;position:relative}.card-face,.card-back{backface-visibility:hidden;border-radius:14px;position:absolute;inset:0;overflow:hidden;box-shadow:0 10px 24px #0000008c,inset 0 0 0 2px #ffffff38}.card-back{background:#011208;justify-content:center;align-items:center;display:flex;transform:rotateY(180deg)}.card-back-dots{opacity:.18;background-image:radial-gradient(#7ddc7a 1px,#0000 1px);background-size:18px 18px;position:absolute;inset:0}.card-back-pill{z-index:1;background:var(--surface-high);border:1px solid #7ddc7a33;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:75%;height:55%;display:flex;position:relative;transform:rotate(-15deg);box-shadow:inset 0 2px 12px #0006}.card-back-pill-title{font-family:var(--font-headline);color:var(--primary);letter-spacing:-.04em;font-size:18px;font-weight:900;line-height:1}.card-back-pill-sub{font-family:var(--font-mono);color:#7ddc7a8c;letter-spacing:.35em;text-transform:uppercase;font-size:7px}.card-face{border:1px solid #ffffff2e;flex-direction:column;padding:8px;display:flex}.card-face.color-red{background:var(--uno-red)}.card-face.color-green{background:var(--uno-green)}.card-face.color-blue{background:var(--uno-blue)}.card-face.color-yellow{background:var(--uno-yellow)}.card-face.color-black{background:#212121}.card-corner{font-family:var(--font-headline);color:#fff;align-items:center;gap:2px;font-size:18px;font-style:italic;font-weight:700;line-height:1;display:flex}.card-face.color-yellow .card-corner{color:#fff;text-shadow:0 1px 4px #00000073}.card-corner.bottom-right{align-self:flex-end;transform:rotate(180deg)}.card-center{flex:1;justify-content:center;align-items:center;display:flex;position:relative}.card-oval{clip-path:ellipse(45% 40%);background-image:radial-gradient(circle,#ffffff1f 0%,#0000 70%);justify-content:center;align-items:center;width:80%;height:55%;display:flex;position:relative;transform:rotate(-20deg)}.card-oval.oval-white{background:#fff radial-gradient(circle at 40% 35%,#fff 0%,#f0f0f0 100%)}.card-oval.oval-wild{background:conic-gradient(#e53935 0deg 90deg,#43a047 90deg 180deg,#1e88e5 180deg 270deg,#fdd835 270deg 360deg);box-shadow:inset 0 0 0 4px #fff3}.card-oval-number{font-family:var(--font-headline);text-shadow:0 2px 8px #00000040;font-size:60px;font-style:italic;font-weight:900;line-height:1;transform:rotate(-20deg)}.color-yellow .card-oval-number{text-shadow:0 2px 8px #0006;color:#fff!important}.card-oval-icon{filter:drop-shadow(0 2px 6px #00000040);transform:rotate(-20deg);font-size:52px!important}.card-oval-label{font-family:var(--font-headline);color:#fff;text-shadow:0 2px 8px #0000004d;font-size:42px;font-style:italic;font-weight:900;transform:rotate(-20deg)}.card-root:not(.no-hover):hover .card-face,.card-root:not(.no-hover):hover .card-back{box-shadow:0 20px 40px #0009,inset 0 0 0 2px #ffffff59}.card-root.is-active .card-face{box-shadow:0 0 0 2px var(--primary), 0 0 28px #7ddc7a80, inset 0 0 0 2px #ffffff38}.card-root.is-disabled{cursor:not-allowed;pointer-events:none}.card-root.is-disabled .card-face,.card-root.is-disabled .card-back{opacity:.35;filter:grayscale(.5)saturate(.5)}.card-root.is-dragging .card-face,.card-root.is-dragging .card-back{box-shadow:20px 20px 48px #000000a6,inset 0 0 0 2px #ffffff4d}.card-root.color-red:not(.is-disabled):hover .card-face{box-shadow:0 0 28px #e5393580,inset 0 0 0 2px #ffffff38}.card-root.color-green:not(.is-disabled):hover .card-face{box-shadow:0 0 28px #43a04780,inset 0 0 0 2px #ffffff38}.card-root.color-blue:not(.is-disabled):hover .card-face{box-shadow:0 0 28px #1e88e580,inset 0 0 0 2px #ffffff38}.card-root.color-yellow:not(.is-disabled):hover .card-face{box-shadow:0 0 28px #fdd83566,inset 0 0 0 2px #ffffff38}@keyframes pulse-active-card{0%,to{box-shadow:0 0 0 2px var(--primary), 0 0 20px #7ddc7a66, inset 0 0 0 2px #ffffff38}50%{box-shadow:0 0 0 2px var(--primary), 0 0 36px #7ddc7ab3, inset 0 0 0 2px #ffffff38}}.card-root.is-active .card-face{animation:2s ease-in-out infinite pulse-active-card}.card-root.size-sm{--card-width:36px}.card-root.size-sm .card-face,.card-root.size-sm .card-back{border-radius:7px}.card-root.size-sm .card-corner,.card-root.size-sm .card-oval-number,.card-root.size-sm .card-oval-icon,.card-root.size-sm .card-oval-label{display:none}.card-hand{align-items:flex-end;display:flex;position:relative}.card-hand-item{transform-origin:bottom;transition:z-index;position:relative}.card-root.is-unplayable .card-face,.card-root.is-unplayable .card-back{opacity:.4;filter:saturate(.4)brightness(.7)}.card-root.is-unplayable{cursor:not-allowed}.card-root.is-selected .card-face{box-shadow:0 0 0 2px var(--primary), 0 0 20px #7ddc7a80, 0 -8px 24px #7ddc7a4d, inset 0 0 0 2px #ffffff38}@media (width<=768px) and (orientation:portrait){.card-root{--card-width:80px;touch-action:auto;width:80px}.card-face,.card-back{border-radius:12px}.card-corner{font-size:14px}.card-oval-number{font-size:44px}.card-oval-icon{font-size:38px!important}.card-oval-label{font-size:32px}.card-hand{-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;scrollbar-width:none;-ms-overflow-style:none;justify-content:flex-start;gap:0;padding:12px 16px 8px;overflow:auto visible}.card-hand::-webkit-scrollbar{display:none}.card-hand-item{scroll-snap-align:center;flex-shrink:0}.card-root.size-sm{--card-width:24px}.card-root.size-sm .card-face,.card-root.size-sm .card-back{border-radius:4px}}
