:root{--color-bg: #080e1a;--color-surface: #111827;--color-surface-2: #1a2332;--color-surface-hover: #1e2d45;--color-border: #1f2e42;--color-border-subtle: #162032;--color-text: #e8ecf1;--color-text-muted: #7a8ba5;--color-text-dim: #4a5a72;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-glow: rgba(59, 130, 246, .15);--color-accent: #f0c040;--color-accent-glow: rgba(240, 192, 64, .12);--color-error: #ef4444;--color-success: #22c55e;--color-warning: #f59e0b;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--font-body: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-display: "Inter", "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .45);--shadow-glow: 0 0 30px rgba(59, 130, 246, .08);--transition-fast: .15s ease;--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(59,130,246,.06),transparent),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(240,192,64,.03),transparent)}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}.app-root{flex:1;display:flex;flex-direction:column}.page{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem}.auth-page{justify-content:center;min-height:100vh;position:relative;overflow:hidden;background:radial-gradient(ellipse 60% 50% at 50% 30%,rgba(59,130,246,.08),transparent 70%),radial-gradient(ellipse 40% 40% at 30% 80%,rgba(240,192,64,.04),transparent)}.auth-brand{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:1.75rem;position:relative;z-index:1}.auth-card{background:#111827cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg),var(--shadow-glow);position:relative;overflow:hidden}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}.auth-card h1{font-size:1.75rem;font-family:var(--font-display);margin-bottom:.25rem;color:var(--color-accent);font-weight:700}.auth-subtitle{color:var(--color-text-muted);margin-bottom:1.75rem;font-size:.9rem}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#fca5a5;padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.85rem;display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.room-conflict-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;width:100%;margin-top:.25rem}.room-conflict-code{font-weight:600;color:var(--color-text);margin-right:auto}.auth-form{display:flex;flex-direction:column;gap:1.125rem}.auth-switch{text-align:center;margin-top:1.75rem;color:var(--color-text-muted);font-size:.85rem}.auth-switch a{font-weight:600}.form-field{display:flex;flex-direction:column;gap:.4rem;width:100%}.form-field label{font-size:.8rem;font-weight:600;color:var(--color-text-muted);letter-spacing:.02em}.form-field input,.input{width:100%;box-sizing:border-box;background:#0000004d;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.75rem 1rem;color:var(--color-text);font-size:.95rem;font-family:var(--font-body);transition:all var(--transition-fast)}.form-field input:focus,.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);background:#0006}.form-field input:disabled,.input:disabled{opacity:.5;cursor:not-allowed}.form-field input::placeholder{color:var(--color-text-dim)}.form-hint{font-size:.75rem;color:var(--color-text-dim)}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--color-text-muted);letter-spacing:.02em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;font-family:var(--font-body);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);text-decoration:none;position:relative;overflow:hidden;letter-spacing:.01em}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:linear-gradient(135deg,var(--color-primary),#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f640}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4a8ef7,var(--color-primary-hover));transform:translateY(-2px);box-shadow:0 6px 20px #3b82f659}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-danger{background:linear-gradient(135deg,var(--color-error),#dc2626);color:#fff;box-shadow:0 2px 8px #ef444433}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ef44444d}.page-bg-suits{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.page-bg-icon{position:absolute;opacity:.04;animation:suit-drift 25s ease-in-out infinite}.page-bg-1{width:120px;top:2%;left:5%;color:#3b82f6;animation-delay:0s}.page-bg-2{width:90px;top:15%;right:8%;color:#ef4444;animation-delay:-4s}.page-bg-3{width:70px;top:50%;left:2%;color:#ef4444;animation-delay:-8s}.page-bg-4{width:100px;bottom:15%;right:3%;color:#3b82f6;animation-delay:-12s}.page-bg-5{width:60px;bottom:5%;left:20%;color:#3b82f6;animation-delay:-16s}.page-bg-6{width:80px;top:40%;right:15%;color:#ef4444;animation-delay:-20s}@keyframes suit-drift{0%,to{transform:translateY(0) rotate(0);opacity:.04}25%{transform:translateY(-18px) rotate(6deg);opacity:.06}50%{transform:translateY(8px) rotate(-4deg);opacity:.035}75%{transform:translateY(-12px) rotate(3deg);opacity:.055}}.page-topbar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:640px;margin-bottom:1.5rem;position:relative;z-index:1}.page-brand{display:flex;align-items:center;gap:.6rem}.brand-icon{width:28px;height:28px;color:var(--color-primary);filter:drop-shadow(0 0 10px rgba(59,130,246,.5))}.brand-text{font-size:1.5rem;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em;background:linear-gradient(135deg,var(--color-text) 40%,var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-back{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--color-primary);font-size:.9rem;font-weight:600;cursor:pointer;padding:6px 12px 6px 4px;min-height:44px;border-radius:var(--radius-sm);transition:background var(--transition-fast);font-family:var(--font-body)}.page-back:hover{background:#3b82f61a}.page-topbar-right{display:flex;align-items:center;gap:12px}.page-username{color:var(--color-accent);font-size:.85rem;font-weight:600}.page-logout{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#ef444433,#ef44441a);border:1.5px solid rgba(239,68,68,.4);color:#fb7185;padding:.55rem 1.2rem;min-height:44px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);letter-spacing:.02em}.page-logout:hover{background:linear-gradient(135deg,#ef444459,#ef444433);border-color:#ef4444a6;box-shadow:0 0 24px #ef444433;transform:translateY(-1px);color:#fda4af}.player-card{width:100%;max-width:640px;background:linear-gradient(145deg,var(--color-surface),var(--color-surface-2));border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:0;margin-bottom:1.5rem;position:relative;z-index:1;box-shadow:0 4px 24px #0000004d;overflow:hidden}.player-card-glow{position:absolute;top:-30%;right:-15%;width:200px;height:200px;background:radial-gradient(circle,rgba(59,130,246,.06),transparent 70%);pointer-events:none}.player-top{display:flex;align-items:center;gap:1rem}.player-avatar{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--color-surface-2),var(--color-bg));border:2.5px solid var(--tier-color, var(--color-accent));display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px color-mix(in srgb,var(--tier-color, var(--color-accent)) 35%,transparent);flex-shrink:0}.avatar-letter{font-size:1.35rem;font-weight:800;color:var(--color-text)}.player-info{flex:1;min-width:0}.player-name{font-size:1.15rem;font-weight:700;color:var(--color-text);margin-bottom:.2rem}.player-tier{font-size:.8rem;font-weight:600;letter-spacing:.03em;display:flex;align-items:center;gap:.35rem}.player-stats-row{display:flex;gap:1.5rem;width:100%;padding-top:.85rem;margin-top:.75rem;border-top:1px solid var(--color-border)}.player-stat{display:flex;flex-direction:column;align-items:center;flex:1}.player-stat-val{font-size:1.2rem;font-weight:800;color:var(--color-text)}.player-stat-lbl{font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-top:.1rem}.home-page{padding-top:1rem;position:relative;overflow:hidden}.home-modes{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:640px;margin-bottom:1.25rem;position:relative;z-index:1}.mode-card{display:flex;align-items:center;gap:1rem;padding:1.15rem 1.25rem;border-radius:var(--radius-lg);text-decoration:none;color:var(--color-text);position:relative;overflow:hidden;transition:all var(--transition-normal);border:1px solid transparent}.mode-card-glow{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity var(--transition-normal);pointer-events:none;border-radius:inherit}.mode-card:hover .mode-card-glow{opacity:1}.mode-card:hover{transform:translateY(-2px);color:var(--color-text)}.mode-single{background:linear-gradient(135deg,#3b82f621,#3b82f60a);border-color:#3b82f638}.mode-single .mode-card-glow{background:radial-gradient(ellipse at 15% 50%,rgba(59,130,246,.16),transparent 70%)}.mode-single:hover{border-color:#3b82f680;box-shadow:0 4px 28px #3b82f624,inset 0 1px #3b82f61f}.mode-multi{background:linear-gradient(135deg,#f0c0401c,#f0c04008);border-color:#f0c04033}.mode-multi .mode-card-glow{background:radial-gradient(ellipse at 15% 50%,rgba(240,192,64,.13),transparent 70%)}.mode-multi:hover{border-color:#f0c04080;box-shadow:0 4px 28px #f0c0401f,inset 0 1px #f0c0401a}.mode-icon-wrap{width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.mode-single .mode-icon-wrap{background:linear-gradient(135deg,#3b82f62e,#3b82f614)}.mode-multi .mode-icon-wrap{background:linear-gradient(135deg,#f0c04026,#f0c0400f)}.mode-suit-icon{width:26px;height:26px}.mode-single .mode-suit-icon{color:var(--color-primary);filter:drop-shadow(0 0 8px rgba(59,130,246,.6))}.mode-multi .mode-suit-icon{color:var(--color-accent);filter:drop-shadow(0 0 8px rgba(240,192,64,.6))}.mode-text h2{font-size:1.02rem;font-weight:700;margin-bottom:.15rem}.mode-text p{font-size:.78rem;color:var(--color-text-muted)}.mode-card>svg:last-child{margin-left:auto;color:var(--color-text-dim);transition:all var(--transition-fast);flex-shrink:0}.mode-card:hover>svg:last-child{color:var(--color-text-muted);transform:translate(4px)}.home-secondary{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem;width:100%;max-width:640px;position:relative;z-index:1}.sec-card{display:flex;align-items:center;gap:.65rem;padding:.9rem .95rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text);transition:all var(--transition-normal)}.sec-card:hover{transform:translateY(-2px);box-shadow:0 4px 18px #00000040;color:var(--color-text)}.sec-gold{background:linear-gradient(145deg,var(--color-surface),rgba(240,192,64,.04))}.sec-gold:hover{border-color:#f0c04059;box-shadow:0 4px 18px #f0c04014}.sec-blue{background:linear-gradient(145deg,var(--color-surface),rgba(59,130,246,.04))}.sec-blue:hover{border-color:#3b82f64d;box-shadow:0 4px 18px #3b82f614}.sec-muted:hover{border-color:#ffffff1a}.sec-svg-icon{width:32px;height:32px;flex-shrink:0}.sec-gold .sec-svg-icon{color:#f0c040}.sec-blue .sec-svg-icon{color:#3b82f6}.sec-muted .sec-svg-icon{color:var(--color-text-muted)}.sec-card h3{font-size:.82rem;font-weight:700;margin-bottom:.05rem}.sec-card p{font-size:.68rem;color:var(--color-text-muted)}.profile-page{max-width:640px;margin:0 auto}.profile-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.profile-header-info{flex:1;min-width:0}.profile-header-info h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.profile-settings-link{flex-shrink:0}.avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0;box-shadow:0 4px 16px #3b82f640}.profile-email{color:var(--color-text-dim);font-size:.85rem}.tier-badge{display:inline-block;padding:.15rem .6rem;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--color-accent-glow);color:var(--color-accent);border:1px solid rgba(240,192,64,.2)}.profile-rating-section{display:flex;gap:2rem;justify-content:center;margin-bottom:1.5rem}.rating-display,.rank-display{text-align:center}.rating-number,.rank-number{display:block;font-size:2rem;font-weight:800;color:var(--color-accent);line-height:1.2}.rating-label,.rank-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.profile-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;width:100%;max-width:600px;margin-bottom:2rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;text-align:center;display:flex;flex-direction:column;gap:.25rem;transition:border-color var(--transition-fast)}.stat-card:hover{border-color:#3b82f633}.stat-value{font-size:1.75rem;font-weight:800;color:var(--color-text)}.stat-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.profile-matches{width:100%}.profile-matches h2{font-size:1.1rem;margin-bottom:1rem;font-weight:700}.match-card{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.match-card:hover{border-color:#ffffff14}.match-win{border-left:3px solid var(--color-success)}.match-loss{border-left:3px solid var(--color-error)}.match-badge{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase}.match-badge.win{background:#22c55e26;color:var(--color-success)}.match-badge.loss{background:#ef44441a;color:#fca5a5}.match-score{font-weight:700;font-size:.9rem}.match-meta{font-size:.75rem;color:var(--color-text-muted)}.match-date{font-size:.75rem;color:var(--color-text-dim)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;padding:3rem 2rem;color:var(--color-text-muted);font-size:.9rem}.empty-state p{margin:0;line-height:1.6}.empty-state .btn{margin-top:.25rem}.loading-indicator{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;padding:3rem 2rem;color:var(--color-text-muted);font-size:.9rem}.loading-indicator:before{content:"";display:block;width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--color-accent);border-radius:50%;animation:spin .75s linear infinite}.error-retry-row{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.not-found-page{justify-content:center;min-height:100vh;text-align:center}.not-found-page h1{font-size:6rem;font-weight:800;background:linear-gradient(135deg,var(--color-text-muted) 30%,var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}.not-found-page p{color:var(--color-text-muted);margin-bottom:2rem}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--color-text-muted);font-size:.9rem}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted)}.btn-outline:hover:not(:disabled){border-color:#3b82f666;color:var(--color-primary);background:var(--color-primary-glow)}.btn-sm{padding:.35rem .75rem;min-height:44px;font-size:.8rem;border-radius:var(--radius-sm)}.btn-lg{padding:1rem 2rem;font-size:1rem;width:100%;max-width:340px;border-radius:var(--radius-md)}.setup-page,.multiplayer-page{align-items:center;max-width:540px;margin:0 auto;padding-top:1rem;position:relative;overflow:hidden}.setup-page h1,.multiplayer-page h1{font-size:1.75rem;font-weight:700;letter-spacing:-.01em;background:linear-gradient(135deg,var(--color-text) 40%,var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.setup-hero{width:100%;text-align:center;margin-bottom:1.5rem;position:relative;z-index:1}.setup-hero-icon{display:flex;align-items:center;justify-content:center;margin:0 auto .5rem;animation:hero-float 3s ease-in-out infinite}.hero-suit-svg{width:56px;height:56px;color:var(--color-accent);filter:drop-shadow(0 0 20px rgba(240,192,64,.45))}@keyframes hero-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.setup-subtitle{color:var(--color-text-muted);margin-bottom:0;font-size:.9rem}.setup-section-label{width:100%;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:.75rem;padding-left:4px}.difficulty-grid{display:flex;flex-direction:column;gap:.625rem;width:100%;margin-bottom:1.5rem}.difficulty-card{display:flex;align-items:flex-start;gap:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;text-align:left;cursor:pointer;transition:all var(--transition-normal);color:var(--color-text);font-family:var(--font-body);position:relative}.difficulty-card:after{content:"";position:absolute;right:1.25rem;top:1.15rem;width:18px;height:18px;border-radius:50%;border:2px solid var(--color-border);transition:all var(--transition-fast);flex-shrink:0}.difficulty-card:hover{border-color:#3b82f64d;background:var(--color-surface-hover);transform:translate(4px)}.difficulty-card.selected{border-color:var(--color-primary);background:linear-gradient(135deg,#3b82f614,#3b82f626);box-shadow:0 0 20px #3b82f61a,inset 0 0 30px #3b82f608}.difficulty-card.selected:after{border-color:var(--color-primary);background:var(--color-primary);box-shadow:inset 0 0 0 3px var(--color-surface),0 0 8px #3b82f666}.diff-rank{font-size:1.8rem;line-height:1;flex-shrink:0;margin-top:2px}.diff-info{flex:1;padding-right:2rem}.difficulty-card h3{font-size:.95rem;font-weight:700;margin-bottom:.2rem}.difficulty-card p{font-size:.8rem;color:var(--color-text-muted)}.diff-detail{margin-top:.4rem;font-size:.75rem!important;color:var(--color-primary)!important;font-style:italic}.setup-match-info{display:flex;align-items:center;justify-content:center;gap:0;width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem 1.5rem;margin-bottom:1.5rem}.match-info-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.match-info-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:600}.match-info-value{font-size:.9rem;font-weight:700;color:var(--color-text)}.match-info-divider{width:1px;height:28px;background:var(--color-border)}.setup-open-round-note{font-size:.75rem;color:var(--color-text-muted);text-align:center;margin-top:-.75rem;margin-bottom:1.5rem;font-style:italic}.setup-start-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;font-size:1.05rem!important;padding:1rem!important;background:linear-gradient(135deg,#3b82f6,#2563eb,#1d4ed8)!important;box-shadow:0 4px 20px #3b82f659,0 0 40px #3b82f61a;transition:all .2s ease!important}.setup-start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #3b82f673,0 0 60px #3b82f626}.setup-start-btn:active:not(:disabled){transform:translateY(0)}.start-icon{font-size:.85rem}.start-loading{display:flex;align-items:center;gap:8px}.start-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lobby-tabs{display:flex;width:100%;gap:4px;margin-bottom:1.5rem;border-radius:var(--radius-md);padding:4px;background:var(--color-surface);border:1px solid var(--color-border);box-sizing:border-box}.tab{flex:1;padding:.65rem;min-height:44px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.tab.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #3b82f640}.tab:hover:not(.active){color:var(--color-text);background:#ffffff0a}.lobby-panel{display:flex;flex-direction:column;align-items:stretch;gap:1.25rem;width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-sizing:border-box}.lobby-info{color:var(--color-text-muted);text-align:center;font-size:.85rem;line-height:1.5}.room-code-input{text-align:center;font-size:1.5rem!important;font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-family:var(--font-mono)!important}.lobby-toggle-row,.lobby-info-row{margin:0}@media(max-width:640px){.page{padding:1rem}.auth-card{padding:1.5rem;border-radius:var(--radius-lg)}.home-secondary{grid-template-columns:1fr}.player-card{padding:1rem 1.15rem}.player-stats-row{gap:.75rem}.page-bg-icon{opacity:.025}.page-bg-1,.page-bg-4{width:80px}.page-bg-2,.page-bg-6{width:60px}.page-bg-3,.page-bg-5{width:50px}.page-topbar{flex-wrap:wrap;gap:.5rem}.profile-header{flex-direction:column;text-align:center}.profile-stats{grid-template-columns:repeat(2,1fr)}.room-info-footer{flex-direction:column;align-items:center;gap:.25rem}.stat-value{font-size:1.5rem}}@media(min-width:768px){.profile-stats{grid-template-columns:repeat(4,1fr)}}.room-page{max-width:640px;margin:0 auto;width:100%;position:relative;overflow:hidden}.room-header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:1.5rem;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border);position:relative;z-index:1}.room-code-display{display:flex;flex-direction:column;align-items:center;gap:.2rem}.room-code-label{font-size:.65rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.room-code-value{background:var(--color-accent-glow);border:1px solid rgba(240,192,64,.2);color:var(--color-accent);font-size:1.2rem;font-weight:700;letter-spacing:.18em;padding:.35rem 1.25rem;min-height:44px;display:flex;align-items:center;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono)}.room-code-value:hover{background:#f0c0402e;transform:scale(1.02)}.room-status-badge{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.room-section-title{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.room-players{width:100%;position:relative;z-index:1}.player-slots{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;width:100%}.player-slot{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-normal);width:100%;box-sizing:border-box}.player-slot.local{border-color:#3b82f64d;background:var(--color-primary-glow)}.player-slot.ready{border-color:#22c55e4d}.player-slot.empty{border-style:dashed;opacity:.4;border-color:var(--color-border)}.player-slot-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;box-shadow:0 2px 8px #3b82f633}.player-slot-avatar.empty-avatar{background:var(--color-border);color:var(--color-text-dim);box-shadow:none}.player-slot-info{display:flex;flex-direction:column;flex:1;min-width:0}.player-slot-name{font-weight:600;font-size:.9rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-tag{color:var(--color-primary);font-weight:500;font-size:.8em}.host-tag{color:var(--color-accent)}.player-slot-status{font-size:.72rem;font-weight:500}.player-slot-status.ready{color:var(--color-success)}.player-slot-status.waiting{color:var(--color-text-dim)}.player-kick{color:var(--color-error);padding:.25rem .5rem;opacity:.6;transition:opacity var(--transition-fast)}.player-kick:hover{opacity:1}.readiness-bar{width:100%;margin-bottom:1.5rem;position:relative;z-index:1}.readiness-track{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden;margin-bottom:.4rem}.readiness-fill{height:100%;background:linear-gradient(90deg,var(--color-success),#4ade80);border-radius:2px;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #22c55e4d}.readiness-label{font-size:.72rem;color:var(--color-text-dim)}.room-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1.5rem;width:100%;position:relative;z-index:1}.room-actions .btn-lg,.room-actions .btn-accent{width:100%;max-width:400px}.btn-ready-active{background:linear-gradient(135deg,var(--color-success),#16a34a);color:#fff;border:none;box-shadow:0 2px 10px #22c55e40}.btn-ready-active:hover{background:linear-gradient(135deg,#22c55e,#15803d);box-shadow:0 4px 16px #22c55e59}.btn-accent{background:linear-gradient(135deg,var(--color-accent),#eab308);color:#0a1628;border:none;font-weight:700;box-shadow:0 2px 10px #f0c04033}.btn-accent:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f0c0404d}.btn-accent:disabled{opacity:.4;cursor:not-allowed}.add-ai-section{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:340px}.ai-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.ai-difficulty-select{display:flex;gap:.375rem}.ai-panel-actions{display:flex;gap:.375rem;justify-content:flex-end}.room-info-footer{display:flex;justify-content:center;gap:1.5rem;font-size:.72rem;color:var(--color-text-dim);padding-top:1rem;border-top:1px solid var(--color-border);width:100%;box-sizing:border-box;position:relative;z-index:1}.error-dismiss{background:none;border:none;color:var(--color-error);font-size:1.2rem;cursor:pointer;margin-left:.5rem;line-height:1}.game-board{position:relative;width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:#0b0f0a}.game-loading-indicator{flex:1;justify-content:center}.game-topbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#00000080;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:20;flex-shrink:0}.topbar-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#ccc;padding:6px 8px;min-height:44px;min-width:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.topbar-btn:hover{background:#ffffff26;color:#fff}.topbar-center{display:flex;align-items:center;gap:.6rem}.topbar-round{font-weight:700;color:var(--color-accent);font-size:.9rem}.topbar-divider{width:1px;height:14px;background:#fff3}.topbar-phase{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff80;font-weight:600}.topbar-room{font-size:.75rem;color:#fff6;font-family:var(--font-mono)}.topbar-trump{font-size:.75rem;font-weight:700;color:#6c8ebf;letter-spacing:.04em}.topbar-open-round{color:#f0b429;font-weight:700;letter-spacing:.06em}.game-toast{position:absolute;top:56px;left:50%;transform:translate(-50%);z-index:30;padding:.5rem 1rem;border-radius:8px;font-size:.8rem;display:flex;align-items:center;gap:.5rem;animation:slide-down .3s ease-out}.game-toast-error{background:#e74c3ce6;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast-dismiss{background:none;border:none;color:#fff;font-size:1.1rem;cursor:pointer;padding:0 .25rem;opacity:.7}.toast-dismiss:hover{opacity:1}.felt-table{flex:1;position:relative;background:radial-gradient(ellipse at 50% 45%,#1e5631,#14422a 40%,#0d2e1c,#071a10);border-top:2px solid rgba(30,86,49,.4);overflow:hidden;min-height:0}.felt-table:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='6' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='0.5' fill='rgba(255,255,255,0.02)'/%3E%3C/svg%3E") repeat;pointer-events:none}.opponent-seat{position:absolute;display:flex;flex-direction:column;align-items:center;gap:4px;z-index:5;transition:transform .3s ease}.opponent-top{top:8px;left:50%;transform:translate(-50%)}.opponent-left{left:8px;top:50%;transform:translateY(-50%)}.opponent-right{right:8px;top:50%;transform:translateY(-50%)}.opponent-info{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2px}.opponent-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#3a7bd5,#2563a8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;border:2px solid rgba(255,255,255,.15);transition:all .3s}.opponent-avatar.avatar-ai{background:linear-gradient(135deg,#7c3aed,#5b21b6);font-size:1rem}.avatar-glow{border-color:var(--color-accent)!important;box-shadow:0 0 16px #e8b93180,0 0 32px #e8b93133;animation:glow-pulse 2s ease-in-out infinite}@keyframes glow-pulse{0%,to{box-shadow:0 0 16px #e8b93180,0 0 32px #e8b93133}50%{box-shadow:0 0 24px #e8b931b3,0 0 48px #e8b9314d}}.opponent-name{font-size:.75rem;font-weight:600;color:#ffffffd9;text-shadow:0 1px 3px rgba(0,0,0,.5);display:flex;align-items:center;gap:4px}.opponent-score{font-size:.7rem;color:var(--color-accent);font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.5);display:flex;align-items:center;gap:5px}.opponent-total{font-size:.65rem;color:#ffffff80;font-weight:500}.scoreboard-glass{max-width:420px;width:95%;max-height:80vh;overflow-y:auto}.scoreboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.scoreboard-table td,.scoreboard-table th{text-align:center}.sb-rank{color:var(--color-text-muted);font-size:.7rem;width:28px}.sb-name{text-align:left!important;font-weight:600}.sb-you{font-size:.65rem;color:var(--color-accent);margin-left:4px}.sb-total{font-weight:700;font-size:.9rem}.row-local{background:#4f8cff14}.sb-history-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:1rem 0 .5rem}.sb-history{display:flex;flex-direction:column;gap:4px}.sb-history-round{display:flex;align-items:center;gap:8px;font-size:.72rem;flex-wrap:wrap}.sb-history-rnum{font-size:.65rem;font-weight:700;color:var(--color-text-muted);min-width:22px}.sb-history-entry{background:#ffffff0d;border-radius:4px;padding:2px 6px;color:#ffffffb3}.disconnect-dot{width:6px;height:6px;border-radius:50%;background:var(--color-error);display:inline-block}.is-disconnected{opacity:.4}.opponent-cards{display:flex;justify-content:center;position:relative;height:50px;width:90px}.opponent-card-back{position:absolute;left:50%;top:0;margin-left:-16px;transform-origin:center 120%}.opponent-card-back:nth-child(n+6){display:none}.opponent-card-back:nth-child(1){transform:rotate(-10deg)}.opponent-card-back:nth-child(2){transform:rotate(-5deg)}.opponent-card-back:nth-child(3){transform:rotate(0)}.opponent-card-back:nth-child(4){transform:rotate(5deg)}.opponent-card-back:nth-child(5){transform:rotate(10deg)}.opponent-top .opponent-cards{margin-bottom:4px}.opponent-left .opponent-cards{transform:rotate(90deg);margin-bottom:8px}.opponent-right .opponent-cards{transform:rotate(-90deg);margin-bottom:8px}.turn-timer-ring{position:absolute;top:-4px;right:-4px;width:20px;height:20px}.turn-timer-ring svg{width:100%;height:100%}.trick-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:10}.trick-empty-text{font-size:.9rem;color:#fff6;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:.02em}.trick-played-cards{display:flex;justify-content:center;gap:-8px;position:relative}.trick-played-card{display:flex;flex-direction:column;align-items:center;gap:2px;animation:card-appear .25s ease-out both;transform:rotate(calc((var(--trick-index) - var(--trick-total) / 2 + .5) * 8deg)) translate(calc((var(--trick-index) - var(--trick-total) / 2 + .5) * 12px));transition:transform .45s ease-in,opacity .45s ease-in}.trick-collecting.trick-collect-bottom .trick-played-card{opacity:0;transform:translateY(180px) scale(.6)}.trick-collecting.trick-collect-top .trick-played-card{opacity:0;transform:translateY(-180px) scale(.6)}.trick-collecting.trick-collect-left .trick-played-card{opacity:0;transform:translate(-240px) scale(.6)}.trick-collecting.trick-collect-right .trick-played-card{opacity:0;transform:translate(240px) scale(.6)}.trick-played-label{font-size:.6rem;color:#fff9;text-shadow:0 1px 2px rgba(0,0,0,.5)}.trick-winner-badge{background:#e8b93133;border:1px solid var(--color-accent);color:var(--color-accent);padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card-visual{position:relative;border-radius:8px;box-shadow:0 2px 8px #0000004d,0 1px 2px #0003;transition:transform .15s ease,box-shadow .15s ease;flex-shrink:0;border:none;padding:0;cursor:default;font-family:Georgia,Times New Roman,serif}.card-sm{width:36px;height:52px}.card-md{width:60px;height:86px}.card-lg{width:72px;height:102px}.card-face{background:linear-gradient(145deg,#fff,#faf8f2,#f4f0e8);color:var(--card-color, #1a1a2e);display:flex;align-items:center;justify-content:center;overflow:hidden}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1;z-index:2}.card-corner-top{top:2px;left:3px}.card-corner-bottom{bottom:2px;right:3px;transform:rotate(180deg)}.card-sm .card-rank{font-size:.5rem;font-weight:700}.card-sm .card-suit-small{font-size:.4rem}.card-md .card-rank{font-size:.6rem;font-weight:700}.card-md .card-suit-small{font-size:.5rem}.card-lg .card-rank{font-size:.7rem;font-weight:700}.card-lg .card-suit-small{font-size:.6rem}.card-content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.card-pips{position:absolute;top:12%;right:8%;bottom:12%;left:8%}.card-pip{position:absolute;font-size:.7em;line-height:1;transform:translate(-50%,-50%)}.card-pip-inv{transform:translate(-50%,-50%) rotate(180deg)}.card-sm .card-pip{font-size:.5em}.card-md .card-pip{font-size:.65em}.card-lg .card-pip{font-size:.85em}.face-card-art{width:80%;height:75%;position:relative;z-index:1}.card-is-face .card-content{padding:8% 4%}.ace-art{width:70%;height:65%}.card-sm .face-card-art{width:85%;height:78%}.card-sm .ace-art{width:75%;height:68%}.card-back{background:linear-gradient(135deg,#8b1a1a,brown 30%,#8b1a1a 70%,#6b1010);border:1px solid rgba(255,255,255,.15)}.card-back-pattern{position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:5px;border:1px solid rgba(255,255,255,.15);background:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,.04) 3px,rgba(255,255,255,.04) 6px),repeating-linear-gradient(-45deg,transparent,transparent 3px,rgba(255,255,255,.04) 3px,rgba(255,255,255,.04) 6px)}.card-playable{cursor:pointer}.card-playable:hover{transform:translateY(-12px) scale(1.05)!important;box-shadow:0 12px 28px #0006,0 0 20px #e8b93133;z-index:50!important}.card-disabled{opacity:.45;cursor:default;filter:brightness(.85)}.card-highlighted{box-shadow:0 0 0 2px var(--color-accent),0 4px 12px #e8b9314d}.call-overlay{position:absolute;bottom:140px;left:50%;transform:translate(-50%);z-index:25}.call-glass{background:#0a1628d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1rem 1.5rem;text-align:center}.call-title{color:var(--color-accent);font-size:.85rem;margin-bottom:.75rem;font-weight:600}.call-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:320px}.call-chip{width:40px;height:40px;border-radius:50%;border:1px solid rgba(232,185,49,.3);background:#e8b9311a;color:var(--color-accent);font-weight:700;font-size:.9rem;cursor:pointer;transition:all .15s;font-family:var(--font-body)}.call-chip:hover{background:var(--color-accent);color:#0a1628;transform:scale(1.1);box-shadow:0 4px 16px #e8b93166}.hand-dock{position:relative;flex-shrink:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 70%,transparent 100%);padding:6px 12px 12px;z-index:15}.hand-player-info{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:6px}.hand-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#3a7bd5,#2563a8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.6rem;border:2px solid rgba(255,255,255,.15);transition:all .3s}.hand-player-name{font-size:.75rem;font-weight:600;color:#ffffffd9}.hand-score{font-size:.7rem;color:var(--color-accent);font-weight:600}.hand-fan{display:flex;justify-content:center;align-items:flex-end;position:relative;min-height:90px;padding:0 8px;overflow:visible}.hand-fan-card{position:relative;transform-origin:center 140%;transform:rotate(calc((var(--fan-index) - var(--fan-total) / 2 + .5) * 2.5deg));margin:0 -10px;transition:transform .2s ease,box-shadow .2s ease,z-index 0s;z-index:calc(var(--fan-index))}.turn-waiting{position:absolute;bottom:140px;left:50%;transform:translate(-50%);color:#ffffff80;font-size:.8rem;display:flex;align-items:center;gap:8px;z-index:15;background:#0006;padding:6px 16px;border-radius:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.waiting-dots{display:flex;gap:4px}.waiting-dots span{width:6px;height:6px;border-radius:50%;background:#ffffff80;animation:dot-bounce 1.4s ease-in-out infinite}.waiting-dots span:nth-child(2){animation-delay:.16s}.waiting-dots span:nth-child(3){animation-delay:.32s}@keyframes dot-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.low-time-pulse{color:var(--color-warning);font-weight:700;animation:pulse .8s ease-in-out infinite}.result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.result-glass{background:#162032f2;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;text-align:center;max-width:380px;width:100%;box-shadow:0 24px 48px #0006}.result-title{font-size:1.5rem;color:var(--color-accent);margin-bottom:.5rem}.result-trophy{font-size:3rem;margin-bottom:1rem}.result-scores{display:flex;flex-direction:column;gap:6px;margin-bottom:1.5rem}.result-row{display:flex;align-items:center;gap:.5rem;padding:8px 12px;border-radius:8px;background:#ffffff0a}.result-winner{background:#e8b9311f;border:1px solid rgba(232,185,49,.3)}.result-rank{font-size:.75rem;color:var(--color-text-muted);width:28px}.result-name{flex:1;text-align:left;font-weight:600}.result-pts{font-weight:700;color:var(--color-accent)}.result-actions{display:flex;gap:.75rem;justify-content:center}.round-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.8rem}.round-table th{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:6px 8px;border-bottom:1px solid var(--color-border);font-weight:700}.round-table td{padding:8px;border-bottom:1px solid rgba(42,58,82,.2)}.row-met{background:#27ae600f}.row-missed{background:#e74c3c0f}.score-pos{color:var(--color-success)}.score-neg{color:var(--color-error)}.btn-game{padding:10px 24px;border:none;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .15s;font-family:var(--font-body)}.btn-game-primary{background:linear-gradient(135deg,var(--color-accent),#d4a82a);color:#0a1628}.btn-game-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #e8b9314d}.btn-game-outline{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--color-text)}.btn-game-outline:hover{border-color:#fff6;background:#ffffff0d}.disconnect-bar{position:absolute;top:50px;left:50%;transform:translate(-50%);background:#e74c3c26;border:1px solid rgba(231,76,60,.3);color:var(--color-error);padding:4px 16px;border-radius:20px;font-size:.7rem;z-index:25;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes card-deal{0%{opacity:0;transform:scale(.5) translateY(-60px)}60%{opacity:1;transform:scale(1.02) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes card-appear{0%{opacity:0;transform:scale(.7) translateY(20px)}to{opacity:1;transform:rotate(calc((var(--trick-index) - var(--trick-total) / 2 + .5) * 8deg)) translate(calc((var(--trick-index) - var(--trick-total) / 2 + .5) * 12px))}}@keyframes slide-up{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes slide-down{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes celebration-bounce{0%{transform:scale(0);opacity:0}40%{transform:scale(1.15);opacity:1}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}.anim-deal{animation:card-deal .3s ease-out both}.anim-slide-up{animation:slide-up .3s ease-out both}.anim-fade-in{animation:fade-in .2s ease-out both}.anim-celebrate{animation:celebration-bounce .8s ease-out both}.anim-deal-0{animation-delay:0ms}.anim-deal-1{animation-delay:60ms}.anim-deal-2{animation-delay:.12s}.anim-deal-3{animation-delay:.18s}.anim-deal-4{animation-delay:.24s}.anim-deal-5{animation-delay:.3s}.anim-deal-6{animation-delay:.36s}.anim-deal-7{animation-delay:.42s}.anim-deal-8{animation-delay:.48s}.anim-deal-9{animation-delay:.54s}.anim-deal-10{animation-delay:.6s}.anim-deal-11{animation-delay:.66s}.anim-deal-12{animation-delay:.72s}@media(max-width:480px){.card-lg{width:48px;height:68px}.card-md{width:40px;height:58px}.card-sm{width:28px;height:40px}.card-lg .card-rank{font-size:.55rem}.card-lg .card-suit-small{font-size:.45rem}.hand-fan-card{margin:0 -12px}.hand-fan{min-height:66px;padding:0 4px}.opponent-avatar{width:26px;height:26px;font-size:.65rem}.opponent-cards{height:38px;width:70px}.opponent-card-back{margin-left:-12px}.call-overlay{bottom:100px}.call-chips{max-width:280px;gap:4px}.call-chip{width:44px;height:44px;font-size:.8rem}.call-glass{padding:.75rem 1rem}.result-glass{padding:1.25rem}.result-title{font-size:1.2rem}.result-trophy{font-size:2rem}.turn-waiting{bottom:100px}.hand-dock{padding:4px 8px 8px}}@media(min-width:768px){.card-lg{width:72px;height:102px}.card-lg .card-rank{font-size:.85rem}.card-lg .card-suit-small{font-size:.7rem}.card-lg .card-pip{font-size:1em}.hand-fan-card{margin:0 -8px}.hand-fan{min-height:100px}.opponent-name{font-size:.82rem}.opponent-score{font-size:.75rem}}@media(min-width:1024px){.card-lg{width:84px;height:120px}.card-lg .card-rank{font-size:.95rem}.card-lg .card-suit-small{font-size:.75rem}.card-lg .card-pip{font-size:1.1em}.trick-played-card .card-visual{width:100px;height:142px}.trick-played-card .card-rank{font-size:1.1rem}.trick-played-card .card-suit-small{font-size:.85rem}.trick-played-card .card-pip{font-size:1.2em}.trick-played-label{font-size:.7rem}.hand-fan-card{margin:0 -6px}.hand-fan{min-height:110px}.opponent-cards{height:56px;width:100px}.opponent-name{font-size:.9rem}.opponent-score{font-size:.82rem}.hand-score{font-size:.78rem}}@media(min-width:1280px){.trick-played-card .card-visual{width:110px;height:156px}.trick-played-card .card-rank{font-size:1.2rem}.trick-played-card .card-suit-small{font-size:.9rem}.trick-played-card .card-pip{font-size:1.3em}.trick-played-label{font-size:.75rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-delay:0ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.leaderboard-page{max-width:700px;margin:0 auto;width:100%;position:relative;overflow:hidden}.leaderboard-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.5rem}.leaderboard-header h1{margin:0}.leaderboard-total{font-size:.85rem;color:var(--color-text-muted)}.my-rank-card{display:flex;align-items:center;gap:1.5rem;background:var(--color-accent-glow);border:1px solid rgba(240,192,64,.15);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1.5rem}.my-rank-position{display:flex;flex-direction:column;align-items:center}.my-rank-position .rank-number{font-size:1.5rem;font-weight:800;color:var(--color-accent)}.my-rank-position .rank-total{font-size:.7rem;color:var(--color-text-muted)}.my-rank-info{flex:1;display:flex;flex-direction:column}.my-rank-name{font-weight:600}.my-rank-percentile{font-size:.8rem;color:var(--color-text-muted)}.my-rank-rating{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.rating-value{font-size:1.1rem;font-weight:700}.tier-purple{background:#9b59b626;color:#9b59b6}.tier-red{background:#e74c3c26;color:#e74c3c}.tier-orange{background:#f39c1226;color:#f39c12}.tier-blue{background:#3498db26;color:#3498db}.tier-green{background:#27ae6026;color:#27ae60}.tier-gray{background:#95a5a626;color:#95a5a6}.tier-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.35rem}.tier-dot.tier-purple{background:#9b59b6}.tier-dot.tier-red{background:#e74c3c}.tier-dot.tier-orange{background:#f39c12}.tier-dot.tier-blue{background:#3498db}.tier-dot.tier-green{background:#27ae60}.tier-dot.tier-gray{background:#95a5a6}.leaderboard-table{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface)}.leaderboard-table-header{display:grid;grid-template-columns:50px 2fr 1fr 1fr 1fr;gap:.5rem;padding:.75rem 1rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-dim);background:#0003;border-bottom:1px solid var(--color-border)}.leaderboard-row{display:grid;grid-template-columns:50px 2fr 1fr 1fr 1fr;gap:.5rem;padding:.6rem 1rem;font-size:.85rem;align-items:center;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition-fast)}.leaderboard-row:last-child{border-bottom:none}.leaderboard-row:hover{background:#ffffff05}.leaderboard-row-me{background:var(--color-primary-glow)}.leaderboard-top-1{border-left:3px solid #f0c040}.leaderboard-top-2{border-left:3px solid #94a3b8}.leaderboard-top-3{border-left:3px solid #c2884e}.lb-col-rank{text-align:center;font-weight:600}.lb-col-player{display:flex;align-items:center;gap:.5rem}.lb-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;flex-shrink:0}.lb-name{display:flex;align-items:center;gap:.35rem}.lb-you-badge{font-size:.55rem;background:var(--color-primary);color:#fff;padding:.1rem .35rem;border-radius:4px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.lb-col-rating,.lb-col-games,.lb-col-winrate{text-align:center}.lb-col-rating{display:flex;align-items:center;justify-content:center;gap:0;font-weight:600}.rank-medal{font-size:1.2rem}.leaderboard-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}.pagination-info{font-size:.85rem;color:var(--color-text-muted)}.profile-page{max-width:600px;margin:0 auto;width:100%;position:relative;overflow:hidden}.profile-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.profile-header-info{flex:1}.profile-header-info h1{margin:0 0 .2rem}.profile-settings-link{align-self:flex-start}.avatar-lg{width:64px;height:64px;font-size:1.4rem}.profile-rating-section{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.rating-display,.rank-display{display:flex;flex-direction:column;align-items:center}.rating-number,.rank-number{font-size:1.5rem;font-weight:800;color:var(--color-accent)}.rating-label,.rank-label{font-size:.75rem;color:var(--color-text-muted)}.profile-matches{margin-top:1.5rem}.profile-matches h2{margin-bottom:.75rem}.match-list{display:flex;flex-direction:column;gap:.5rem}.match-card{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.match-card.match-win{border-left:3px solid var(--color-success)}.match-card.match-loss{border-left:3px solid var(--color-error)}.match-badge{display:inline-block;padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700}.match-badge.win{background:#27ae6026;color:var(--color-success)}.match-badge.loss{background:#e74c3c26;color:var(--color-error)}.match-info{flex:1;display:flex;flex-direction:column}.match-score{font-weight:600}.match-meta,.match-date{font-size:.75rem;color:var(--color-text-muted)}.settings-page{max-width:640px;margin:0 auto;width:100%;position:relative;overflow:hidden}.settings-page h1{margin-bottom:1.5rem;font-size:1.75rem;font-weight:700}.settings-section{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem;box-sizing:border-box}.settings-section h2{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.settings-form{display:flex;flex-direction:column;gap:1rem}.settings-form-row{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.settings-form-row{grid-template-columns:1fr 1fr}}.settings-form-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}@media(min-width:640px){.settings-form-actions{justify-content:flex-end}.settings-form-actions .settings-message{margin-right:auto}}.settings-info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(42,58,82,.1)}.settings-info-row:last-of-type{border-bottom:none}.settings-label{color:var(--color-text-muted);font-size:.85rem}.settings-value{font-weight:600;font-size:.85rem}.settings-message{padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.8rem}.settings-message.success{background:#27ae601f;color:var(--color-success)}.settings-message.error{background:#e74c3c1f;color:var(--color-error)}.settings-danger{border-color:#ef444433;background:#ef444408}.settings-danger h2{color:var(--color-error)}.settings-danger p{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(42,58,82,.1)}.settings-toggle-row:last-child{border-bottom:none}.toggle-info{display:flex;flex-direction:column;gap:.15rem}.toggle-label{font-weight:600;font-size:.9rem}.toggle-desc{font-size:.75rem;color:var(--color-text-muted)}.toggle-switch{position:relative;width:44px;height:24px;border-radius:12px;background:#ffffff14;border:none;cursor:pointer;padding:0;flex-shrink:0;transition:all var(--transition-normal)}.toggle-switch.active{background:var(--color-primary);box-shadow:0 0 12px #3b82f64d}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch.active .toggle-knob{transform:translate(20px)}.settings-slider-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0 .75rem}.settings-slider-row label{font-size:.8rem;color:var(--color-text-muted);min-width:50px}.settings-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff14;border-radius:2px;outline:none}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;box-shadow:0 0 8px #3b82f64d}.slider-value{font-size:.8rem;min-width:35px;text-align:right;color:var(--color-text-muted)}@media(max-width:640px){.settings-section{padding:1.15rem}.settings-toggle-row{align-items:flex-start;gap:.75rem}.settings-form-actions .btn,.settings-danger .btn{width:100%}}@media(max-width:600px){.leaderboard-table-header,.leaderboard-row{grid-template-columns:40px 1.5fr 1fr 0fr 0fr}.lb-col-games,.lb-col-winrate{display:none}.my-rank-card{flex-direction:column;gap:.75rem;text-align:center}.my-rank-rating{align-items:center}}
