@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";:root{--font-display: "Space Grotesk", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--gold-h: 45;--gold-s: 100%;--gold-l: 55%;--gold: hsl(var(--gold-h) var(--gold-s) var(--gold-l));--gold-glow: hsl(45 100% 65%);--gold-dark: hsl(45 100% 45%);--accent-purple: hsl(280 80% 65%);--accent-purple-glow: hsl(280 80% 75%);--accent-cyan: hsl(190 90% 60%);--accent-cyan-glow: hsl(190 90% 70%);--accent-orange: hsl(25 95% 60%);--accent-orange-glow: hsl(25 95% 70%);--accent-pink: hsl(330 80% 65%);--accent-pink-glow: hsl(330 80% 75%);--emerald-h: 152;--emerald-s: 75%;--emerald-l: 45%;--emerald: hsl(var(--emerald-h) var(--emerald-s) var(--emerald-l));--emerald-light: hsl(152 75% 52%);--emerald-dark: hsl(152 75% 35%);--team-red: hsl(0 85% 65%);--team-red-glow: hsl(0 85% 75%);--team-blue: hsl(217 90% 65%);--team-blue-glow: hsl(217 90% 75%);--bg-deep: hsl(240 35% 9%);--bg-base: hsl(240 30% 12%);--bg-elevated: hsl(240 25% 16%);--bg-surface: hsl(240 20% 19%);--bg-glass: hsla(240 30% 12% / .92);--bg-glass-light: hsla(240 20% 21% / .8);--bg-glass-heavy: hsla(240 25% 16% / .95);--text-primary: hsl(0 0% 98%);--text-secondary: hsl(240 15% 80%);--text-muted: hsl(240 15% 60%);--text-accent: var(--gold);--border-subtle: hsla(0 0% 100% / .1);--border-medium: hsla(0 0% 100% / .15);--border-accent: hsla(45 100% 55% / .5);--shadow-sm: 0 2px 8px hsla(0 0% 0% / .3), 0 1px 2px hsla(0 0% 0% / .2);--shadow-md: 0 4px 16px hsla(0 0% 0% / .35), 0 2px 4px hsla(0 0% 0% / .25);--shadow-lg: 0 8px 32px hsla(0 0% 0% / .4), 0 4px 8px hsla(0 0% 0% / .3);--shadow-xl: 0 16px 48px hsla(0 0% 0% / .5), 0 8px 16px hsla(0 0% 0% / .4);--shadow-glow-gold: 0 0 32px hsla(45 100% 55% / .4), 0 0 64px hsla(45 100% 55% / .2);--shadow-glow-purple: 0 0 32px hsla(280 80% 65% / .35), 0 0 64px hsla(280 80% 65% / .15);--shadow-glow-cyan: 0 0 32px hsla(190 90% 60% / .35), 0 0 64px hsla(190 90% 60% / .15);--shadow-glow-emerald: 0 0 32px hsla(152 75% 45% / .35), 0 0 64px hsla(152 75% 45% / .15);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 28px;--radius-full: 9999px;--card-white: hsl(48 30% 96%);--card-shadow: 0 2px 12px hsla(0 0% 0% / .2);--red-suit: hsl(0 75% 55%);--black-suit: hsl(0 0% 10%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:radial-gradient(ellipse 80% 50% at top left,hsla(280 80% 65% / .12) 0%,transparent 60%),radial-gradient(ellipse 80% 50% at top right,hsla(190 90% 60% / .12) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at bottom left,hsla(45 100% 55% / .08) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at bottom right,hsla(330 80% 65% / .08) 0%,transparent 70%),linear-gradient(135deg,var(--bg-deep) 0%,var(--bg-base) 40%,hsl(240 28% 14%) 100%);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative}#root{min-height:100vh}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.04;pointer-events:none;z-index:0}body:after{content:"";position:fixed;inset:0;background:radial-gradient(1.5px 1.5px at 20% 30%,hsla(45 100% 55% / .25),transparent),radial-gradient(1.5px 1.5px at 60% 70%,hsla(280 80% 65% / .25),transparent),radial-gradient(1px 1px at 50% 50%,hsla(190 90% 60% / .2),transparent),radial-gradient(1px 1px at 80% 20%,hsla(330 80% 65% / .2),transparent),radial-gradient(1px 1px at 30% 80%,hsla(25 95% 60% / .15),transparent);background-size:250% 250%;animation:sparkle 25s ease-in-out infinite;pointer-events:none;z-index:0;opacity:.5;filter:blur(.5px)}@keyframes sparkle{0%,to{background-position:0% 0%,100% 100%,50% 50%,0% 100%,30% 80%;opacity:.4}50%{background-position:100% 100%,0% 0%,50% 50%,100% 0%,70% 20%;opacity:.6}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;position:relative;z-index:1}.login-card{background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(24px) saturate(180%);backdrop-filter:blur(24px) saturate(180%);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-xl),0 0 0 1px #ffffff0d inset;max-width:420px;width:100%;text-align:center;animation:slideUp .5s var(--ease-out);position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsla(45 100% 55% / .05),transparent,hsla(280 80% 65% / .05));pointer-events:none;z-index:0}.login-card>*{position:relative;z-index:1}.login-card h1{font-family:var(--font-display);font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;letter-spacing:-.02em}.login-card .subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:1rem}.login-hero{margin-bottom:32px}.login-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:var(--text-muted);font-size:.85rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-medium)}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper .input-icon{position:absolute;left:16px;font-size:1rem;z-index:1;pointer-events:none}.input-wrapper input{padding-left:44px!important;width:100%}.lobby-card{max-width:520px}.lang-switch{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.lang-btn{padding:10px 24px;border:1px solid var(--border-medium);background:transparent;border-radius:var(--radius-full);cursor:pointer;font-family:var(--font-body);font-weight:600;font-size:.9rem;color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out)}.lang-btn:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-accent)}.lang-btn.active{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--bg-deep);border-color:transparent}.input-group{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.input-group input{padding:16px 20px;border:1px solid var(--border-medium);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;background:var(--bg-surface);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out)}.input-group input::placeholder{color:var(--text-muted)}.input-group input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #ffbf0026}.btn-primary{width:100%;padding:16px 24px;background:linear-gradient(135deg,var(--gold) 0%,var(--accent-orange) 50%,var(--gold-dark) 100%);background-size:200% 200%;color:var(--bg-deep);border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all var(--duration-normal) var(--ease-spring);box-shadow:0 4px 24px #ffc61a66,0 0 #ffc61a00;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,hsla(0 0% 100% / .2),transparent);transform:translate(-100%);transition:transform .6s}.btn-primary:hover{transform:translateY(-3px) scale(1.02);background-position:100% 0%;box-shadow:0 8px 32px #ffc61a80,0 0 0 4px #ffc61a33}.btn-primary:hover:before{transform:translate(100%)}.btn-primary:active{transform:translateY(-1px) scale(.98)}.btn-secondary{padding:14px 28px;background:transparent;color:var(--text-primary);border:2px solid var(--border-medium);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.btn-secondary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--accent-purple) / .1,var(--accent-cyan) / .1);opacity:0;transition:opacity var(--duration-normal)}.btn-secondary:hover{background:#33334d99;border-color:var(--gold);color:var(--gold);transform:translateY(-2px);box-shadow:0 4px 16px #ffc61a33}.btn-secondary:hover:before{opacity:1}.games-list{margin:24px 0;text-align:left}.games-list h3{color:var(--gold);margin-bottom:16px;font-family:var(--font-display);font-size:1.1rem;font-weight:600}.game-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;transition:all var(--duration-fast) var(--ease-out)}.game-item:hover{background:var(--bg-elevated);border-color:var(--border-medium);transform:translate(4px)}.game-info-row{display:flex;flex-direction:column;gap:4px}.game-id{font-family:var(--font-display);font-weight:600;color:var(--text-primary)}.game-status{font-size:.85rem;color:var(--text-muted)}.game-status.waiting{color:var(--emerald-light)}.game-status.playing{color:var(--gold)}.btn-join{padding:10px 22px;background:linear-gradient(135deg,var(--emerald) 0%,var(--emerald-dark) 100%);color:var(--text-primary);border:none;border-radius:var(--radius-full);font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.btn-join:hover{transform:scale(1.05);box-shadow:0 4px 16px #19865366}.error-message{background:#ef434326;border:1px solid hsla(0 84% 60% / .3);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;color:var(--team-red);font-size:.9rem}.auth-toggle{margin-top:20px;text-align:center}.auth-link{color:var(--gold);cursor:pointer;text-decoration:underline;font-size:.9rem;transition:color var(--duration-fast)}.auth-link:hover{color:var(--gold-glow)}.invite-notice{background:linear-gradient(135deg,#9956f5,#a411ee);color:var(--text-primary);padding:14px 20px;border-radius:var(--radius-md);margin-bottom:20px;font-weight:600;text-align:center;animation:bounceIn .5s var(--ease-spring)}.lobby-container{min-height:100vh;position:relative;z-index:1;display:flex;flex-direction:column}.lobby-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 32px;background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:50}.lobby-nav-left{display:flex;align-items:center}.lobby-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lobby-nav-center{display:flex;gap:6px}.lobby-nav-item{padding:8px 16px;color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-out);background:none;border:none;cursor:pointer;font-family:var(--font-body)}.lobby-nav-item:hover{background:var(--bg-surface);color:var(--text-primary)}.lobby-nav-right{display:flex;align-items:center;gap:14px}.lobby-nav .lang-switch{margin-bottom:0}.lobby-user{font-size:.85rem;color:var(--text-secondary);font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby-content{max-width:960px;width:100%;margin:0 auto;padding:32px 24px 60px}.lobby-hero{text-align:center;margin-bottom:32px}.lobby-hero h1{font-family:var(--font-display);font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.lobby-hero p{color:var(--text-secondary);font-size:1rem}.lobby-actions{display:flex;gap:12px;align-items:center;margin-bottom:32px;flex-wrap:wrap}.lobby-create-btn{padding:12px 28px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);color:var(--bg-deep);border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 4px 16px #ffbf004d;white-space:nowrap;flex-shrink:0}.lobby-create-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #ffbf0066}.lobby-search-wrap{flex:1;min-width:200px;position:relative;display:flex;align-items:center}.lobby-search-icon{position:absolute;left:14px;font-size:.9rem;pointer-events:none;z-index:1}.lobby-search{width:100%;padding:12px 16px 12px 40px;background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;transition:border-color var(--duration-fast)}.lobby-search::placeholder{color:var(--text-muted)}.lobby-search:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #ffbf001a}.lobby-search-clear{position:absolute;right:10px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:4px}.lobby-search-clear:hover{color:var(--text-primary)}.lobby-join-code{display:flex;gap:8px;flex-shrink:0}.lobby-join-code input{width:120px;padding:12px 14px;background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem}.lobby-join-code input::placeholder{color:var(--text-muted)}.lobby-join-code input:focus{outline:none;border-color:var(--gold)}.lobby-join-btn{padding:12px 20px;background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all var(--duration-fast);font-family:var(--font-body);font-size:.9rem}.lobby-join-btn:hover{background:var(--bg-surface);border-color:var(--gold);color:var(--gold)}.lobby-error{margin-bottom:20px;text-align:center}.lobby-section{margin-bottom:32px}.lobby-section-title{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.section-dot{width:8px;height:8px;border-radius:50%}.section-dot.open{background:var(--emerald-light)}.section-dot.active{background:var(--gold)}.section-count{background:var(--bg-surface);padding:2px 10px;border-radius:var(--radius-full);font-size:.8rem;color:var(--text-muted);font-weight:500}.lobby-games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.lobby-game-card{background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;transition:all var(--duration-normal) var(--ease-spring);display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm),0 0 0 1px #ffffff08 inset}.lobby-game-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsla(280 80% 65% / .08) 0%,transparent 50%,hsla(190 90% 60% / .08) 100%);opacity:0;transition:opacity var(--duration-normal)}.lobby-game-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--duration-normal)}.lobby-game-card:hover{border-color:var(--gold);transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-lg),0 0 32px #ffc61a33,0 0 0 1px #ffc61a1a inset}.lobby-game-card:hover:before,.lobby-game-card:hover:after{opacity:1}.lobby-game-card.joinable{border-color:#1dc97880;background:linear-gradient(135deg,var(--bg-glass-heavy),hsla(152 75% 45% / .08))}.lobby-game-card.joinable:hover{border-color:var(--emerald-light);box-shadow:0 8px 32px #1dc9784d,0 0 0 2px #1dc97826}.game-card-header{display:flex;justify-content:space-between;align-items:center}.game-card-code{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--text-primary);letter-spacing:.05em}.game-card-time{font-size:.75rem;color:var(--text-muted)}.game-card-badge{font-size:.7rem;padding:3px 10px;border-radius:var(--radius-full);font-weight:600}.game-card-badge.playing{background:#ffbf001f;color:var(--gold)}.game-card-badge.finished{background:#ffffff0f;color:var(--text-muted)}.game-card-body{display:flex;align-items:center;gap:12px}.game-card-seats{display:flex;gap:4px}.lobby-game-card .seat-dot{width:10px;height:10px;border-radius:50%;transition:all var(--duration-fast);position:static}.lobby-game-card .seat-dot.filled{background:var(--emerald-light);box-shadow:0 0 6px #20ac6b66}.lobby-game-card .seat-dot.empty{background:var(--bg-surface);border:1px solid var(--border-medium)}.game-card-count{font-size:.85rem;color:var(--text-secondary);font-weight:600}.game-card-players{font-size:.85rem;color:var(--text-secondary)}.game-card-humans{font-size:.75rem;color:var(--text-muted)}.game-card-join{width:100%;padding:10px;background:linear-gradient(135deg,var(--emerald) 0%,var(--emerald-dark) 100%);color:var(--text-primary);border:none;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.game-card-join:hover{transform:scale(1.02);box-shadow:0 4px 16px #20ac6b4d}.game-card-join.rejoin{background:linear-gradient(135deg,var(--team-blue) 0%,hsl(217 91% 50%) 100%)}.lobby-empty{text-align:center;padding:60px 24px;color:var(--text-muted)}.lobby-empty-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.lobby-empty p{font-size:1rem}@media(max-width:768px){.lobby-nav{padding:12px 16px}.lobby-nav-center{display:none}.lobby-content{padding:20px 16px 40px}.lobby-hero h1{font-size:1.5rem}.lobby-actions{flex-direction:column}.lobby-search-wrap{min-width:100%}.lobby-join-code{width:100%}.lobby-join-code input{flex:1}.lobby-games-grid{grid-template-columns:1fr}}@media(max-width:480px){.lobby-nav{flex-wrap:wrap;gap:8px}.lobby-hero h1{font-size:1.3rem}.lobby-game-card{padding:12px}}.game-table-container{display:flex;flex-direction:column;min-height:100vh;padding:12px;position:relative;z-index:1}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:16px;box-shadow:var(--shadow-md)}.game-info{display:flex;gap:20px;color:var(--text-secondary);font-size:.9rem;align-items:center;flex-wrap:wrap}.game-info span{display:flex;align-items:center;gap:6px}.trump-badge{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--bg-deep);padding:6px 16px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:.85rem;box-shadow:0 2px 12px #ffbf004d}.free-play-badge{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:6px 14px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:.8rem;box-shadow:0 2px 12px #22c35d66;animation:free-play-pulse 2s ease-in-out infinite}@keyframes free-play-pulse{0%,to{box-shadow:0 2px 12px #22c35d66}50%{box-shadow:0 2px 20px #22c35db3}}.free-play-toggle{border:1px solid hsla(142 70% 45% / .3);background:var(--bg-elevated)!important}.top-bar-right{display:flex;align-items:center;gap:12px}.btn-leave-game{padding:8px 16px;background:#b82e2e4d;border:1px solid hsla(0 60% 45% / .5);color:var(--team-red);border-radius:var(--radius-full);cursor:pointer;font-size:.85rem;font-weight:500;transition:all var(--duration-fast) var(--ease-out)}.btn-leave-game:hover{background:#b82e2e80;color:var(--text-primary)}.team-legend{display:flex;gap:16px;font-size:.85rem}.team-legend span{display:flex;align-items:center;gap:6px}.game-id-btn{display:flex;align-items:center;gap:8px;background:var(--bg-surface);border:1px dashed var(--border-medium);color:var(--text-secondary);padding:8px 16px;border-radius:var(--radius-full);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.game-id-btn:hover{background:var(--bg-elevated);border-color:var(--gold);color:var(--text-primary);transform:scale(1.02)}.game-id-btn.copied{background:#19865333;border-color:var(--emerald);border-style:solid}.copy-hint{opacity:.6;font-size:.8rem}.rules-btn{background:#ffbf0026;border:1px solid hsla(45 100% 50% / .3);color:var(--gold);padding:10px 18px;border-radius:var(--radius-full);cursor:pointer;font-size:.9rem;font-weight:500;transition:all var(--duration-fast) var(--ease-out)}.rules-btn:hover{background:#ffbf0040;transform:translateY(-1px)}.game-table{flex:1;position:relative;width:100%;max-width:920px;height:460px;margin:0 auto;background:radial-gradient(ellipse at center,hsla(0 0% 100% / .02) 0%,transparent 50%),radial-gradient(ellipse at center,var(--emerald-light) 0%,var(--emerald) 40%,var(--emerald-dark) 80%,hsl(152 69% 15%) 100%);border-radius:50%;box-shadow:inset 0 0 100px #0006,inset 0 0 30px #0003,var(--shadow-xl),var(--shadow-glow-emerald)}.players-area{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.player-slot{position:absolute;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:20;pointer-events:auto}.player-slot.left{top:50%;left:20px;transform:translateY(-50%)}.player-slot.top-left{top:40px;left:20%;transform:translate(-50%)}.player-slot.top-center{top:10px;left:50%;transform:translate(-50%)}.player-slot.top-right{top:40px;right:20%;transform:translate(50%)}.player-slot.right{top:50%;right:20px;transform:translateY(-50%)}.player-info{position:relative;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:12px 18px;color:var(--text-primary);text-align:center;min-width:100px;box-shadow:var(--shadow-md);transition:all var(--duration-normal) var(--ease-out)}.player-info.current-turn{border-color:var(--gold);box-shadow:var(--shadow-md),0 0 30px #ffbf0080,0 0 60px #ffbf0033;animation:turnGlow 2s ease-in-out infinite;position:relative;z-index:25}.player-info.current-turn:after{content:"";position:absolute;inset:-4px;border-radius:calc(var(--radius-lg) + 4px);border:2px solid transparent;background:linear-gradient(135deg,var(--gold),var(--gold-glow),var(--gold-dark),var(--gold)) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:turnRingSpin 3s linear infinite;pointer-events:none}@keyframes turnGlow{0%,to{box-shadow:var(--shadow-md),0 0 25px #ffbf0080,0 0 50px #ffbf0026}50%{box-shadow:var(--shadow-md),0 0 40px #ffbf00b3,0 0 70px #ffbf0040}}@keyframes turnRingSpin{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(15deg)}}.turn-arrow{position:absolute;bottom:-22px;left:50%;transform:translate(-50%);font-size:1rem;color:var(--gold);animation:turnArrowBounce 1s ease-in-out infinite;filter:drop-shadow(0 0 6px hsla(45 100% 50% / .6));z-index:26;pointer-events:none}.player-slot.left .turn-arrow{inset:50% -22px auto auto;transform:translateY(-50%) rotate(-90deg)}.player-slot.right .turn-arrow{inset:50% auto auto -22px;transform:translateY(-50%) rotate(90deg)}@keyframes turnArrowBounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(4px)}}.player-slot.left .turn-arrow{animation-name:turnArrowBounceHorizontal}.player-slot.right .turn-arrow{animation-name:turnArrowBounceHorizontalReverse}@keyframes turnArrowBounceHorizontal{0%,to{transform:translateY(-50%) rotate(-90deg) translateY(0)}50%{transform:translateY(-50%) rotate(-90deg) translateY(4px)}}@keyframes turnArrowBounceHorizontalReverse{0%,to{transform:translateY(-50%) rotate(90deg) translateY(0)}50%{transform:translateY(-50%) rotate(90deg) translateY(4px)}}.player-info.team1{border-left:3px solid var(--team-red);background:linear-gradient(135deg,hsla(0 84% 60% / .2) 0%,var(--bg-glass) 100%)}.player-info.team2{border-left:3px solid var(--team-blue);background:linear-gradient(135deg,hsla(217 91% 60% / .2) 0%,var(--bg-glass) 100%)}.player-info.same-team{box-shadow:var(--shadow-md),0 0 0 2px #ffffff4d}.player-info.opponent-team{opacity:.85}.team-indicator{position:absolute;top:6px;right:8px;font-size:.7rem}.player-name{font-family:var(--font-display);font-weight:600;font-size:.95rem;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:85px}.player-cards-count{font-size:.8rem;color:var(--text-secondary);font-weight:500}.player-badge{font-size:.7rem;background:#ffffff26;padding:3px 10px;border-radius:var(--radius-full);margin-top:6px;font-weight:500}.player-badge.ai{background:linear-gradient(135deg,#e92063,#d01673)}.player-badge.entrusted{background:linear-gradient(135deg,#944cdc,#6231c4)}.player-played-cards{display:flex;justify-content:center;min-height:55px}.played-cards-row{display:flex;gap:4px}@keyframes dealIn{0%{opacity:0;transform:translateY(-10px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-deal{animation:dealIn .3s var(--ease-out)}.player-passed{color:var(--text-muted);font-style:italic;font-size:.85rem;padding:6px 14px;background:#ffffff0d;border-radius:var(--radius-full)}.center-area{position:absolute;top:55%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:30;width:60%;max-width:500px;pointer-events:auto}.hand-to-beat{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:24px 40px;box-shadow:var(--shadow-lg)}.beat-label{color:var(--text-secondary);font-size:.9rem;margin-bottom:12px;font-weight:500}.beat-type{color:var(--gold);font-family:var(--font-display);font-weight:700;font-size:1.1rem;text-shadow:0 0 20px hsla(45 100% 50% / .3)}.beat-cards{display:flex;justify-content:center;gap:8px;margin:16px 0}.beat-cards .card{transform:scale(1.05);box-shadow:var(--shadow-lg)}.beat-player{color:var(--text-muted);font-size:.85rem}.new-round-msg{color:var(--emerald-light);font-family:var(--font-display);font-size:1.2rem;font-weight:600;padding:24px;text-align:center}.new-round-icon{font-size:3.5rem;margin-bottom:12px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.1) translateY(-5px)}}.card{width:60px;height:90px;background:linear-gradient(145deg,#fbfbf8,#f4f2ec,#ebe9e0);border-radius:var(--radius-sm);display:flex;flex-direction:column;justify-content:space-between;padding:5px;box-shadow:var(--card-shadow),inset 0 1px #fffc;position:relative;transition:transform var(--duration-fast) var(--ease-spring),box-shadow var(--duration-fast);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid hsla(0 0% 0% / .1)}.card:before{content:"";position:absolute;inset:2px;border-radius:6px;border:1px solid hsla(0 0% 100% / .5);pointer-events:none}.card.red-suit{color:var(--red-suit)}.card.black-suit{color:var(--black-suit)}.card-corner{display:flex;flex-direction:column;align-items:center;line-height:1}.card-corner.top{align-self:flex-start}.card-corner.bottom{align-self:flex-end;transform:rotate(180deg)}.card-rank{font-family:var(--font-display);font-size:1rem;font-weight:800;text-shadow:0 1px 0 hsla(0 0% 100% / .5)}.card-suit-small{font-size:.8rem}.card-suit-center{font-size:1.8rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);filter:drop-shadow(0 1px 1px hsla(0 0% 0% / .1))}.card.joker{background:linear-gradient(135deg,#ed5e5e,#fc3,#3dc7f5,#f28cf2,#ed5e5e);background-size:200% 200%;animation:jokerGradient 4s ease infinite;color:var(--text-primary);text-shadow:1px 1px 3px hsla(0 0% 0% / .4);border:2px solid hsla(0 0% 100% / .4)}@keyframes jokerGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.card.joker .card-suit-center{font-size:1.2rem;font-weight:700}.card.small{width:42px;height:63px;padding:3px;border-radius:6px}.card.small .card-rank{font-size:.75rem}.card.small .card-suit-small{font-size:.6rem}.card.small .card-suit-center{font-size:1.2rem}.interactive-card{transition:transform .1s ease-out,box-shadow .2s ease-out;transform-style:preserve-3d;will-change:transform}.interactive-card:hover{box-shadow:0 20px 40px #0006,0 0 20px #ffc61a33;z-index:100}.card-glare{position:absolute;inset:0;background:radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),hsla(0 0% 100% / .2) 0%,transparent 80%);pointer-events:none;opacity:0;transition:opacity .3s;border-radius:inherit;z-index:5}.interactive-card:hover .card-glare{opacity:1}.card-shadow{position:absolute;inset:-10px;background:radial-gradient(ellipse at center,hsla(0 0% 0% / .3) 0%,transparent 70%);border-radius:inherit;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;z-index:-1;filter:blur(10px)}.interactive-card:hover .card-shadow{opacity:1;transform:scale(1.2)}.deal-animation{animation:dealCard .6s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes dealCard{0%{transform:translateY(-200px) rotateX(90deg) rotateY(180deg) scale(.3);opacity:0}to{transform:translateY(0) rotateX(0) rotateY(0) scale(1);opacity:1}}.landing-card-table-section{padding:80px 24px;text-align:center}.landing-demo-desc{color:var(--text-muted);margin-top:-30px;margin-bottom:40px}.card-table{max-width:700px;margin:0 auto;background:radial-gradient(ellipse at 50% 80%,hsla(140 30% 15% / .3) 0%,var(--bg-glass-heavy) 70%);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:40px 40px 20px;box-shadow:var(--shadow-xl);overflow:hidden}.card-table-played{min-height:160px;display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:30px}.card-table-hint{color:var(--text-muted);font-size:.95rem;opacity:.5;font-style:italic}.card-table-played-card{position:absolute;transition:transform .4s var(--ease-spring),opacity .3s;animation:cardLand .4s var(--ease-spring) forwards}.card-table-played-card .interactive-card{width:80px;height:120px}@keyframes cardLand{0%{transform:translateY(120px) rotate(0) scale(.6);opacity:0}to{opacity:1}}.card-table-played+.card-table-hand{border-top:1px solid hsla(0 0% 100% / .06);padding-top:24px}.card-table-hand{display:flex;justify-content:center;align-items:flex-end;min-height:180px;position:relative;padding:0 20px 20px}.card-table-card{cursor:pointer;transform-origin:bottom center;transform:rotate(var(--fan-angle)) translateY(0);transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s,filter .2s;margin:0 -14px;position:relative;z-index:var(--card-index)}.card-table-card:first-child{margin-left:0}.card-table-card:last-child{margin-right:0}.card-table-card .interactive-card{width:80px;height:120px}.card-table-card:hover:not(.playing){transform:rotate(var(--fan-angle)) translateY(-28px);z-index:50!important;filter:brightness(1.1)}.card-table-card.playing{transform:rotate(0) translateY(-140px) scale(.9);opacity:0;pointer-events:none;z-index:100!important}.physics-card{position:absolute;top:50%;left:50%;transform-origin:center center;user-select:none;-webkit-user-select:none}.physics-card.dragging{cursor:grabbing!important;z-index:1000!important}@media(max-width:768px){.card-table{padding:30px 20px 16px;margin:0 10px}.card-table-card{margin:0 -16px}.card-table-card .interactive-card,.card-table-played-card .interactive-card{width:64px;height:96px}.card-table-played{min-height:130px}.card-table-hand{min-height:150px}.card-table-card:hover:not(.playing){transform:rotate(var(--fan-angle)) translateY(-20px)}.card-table-card.playing{transform:rotate(0) translateY(-110px) scale(.9)}}@media(max-width:480px){.card-table{padding:24px 12px 12px}.card-table-card{margin:0 -18px}.card-table-card .interactive-card,.card-table-played-card .interactive-card{width:52px;height:78px}.card-table-played{min-height:110px;margin-bottom:20px}.card-table-hand{min-height:120px;padding:0 8px 14px}}.my-hand-area{margin-top:auto;background:linear-gradient(180deg,#0f1729f2,#0b111efa);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border-subtle);box-shadow:0 -12px 50px #00000080;position:relative;overflow:hidden}.my-hand-area:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}.my-hand-area.team1:before{background:linear-gradient(90deg,transparent,var(--team-red-glow),transparent)}.my-hand-area.team2:before{background:linear-gradient(90deg,transparent,var(--team-blue-glow),transparent)}.my-hand-area.team1{border-top:2px solid var(--team-red)}.my-hand-area.team2{border-top:2px solid var(--team-blue)}.my-hand-area.my-turn{border-top-color:var(--gold)!important}.my-hand-area.my-turn:before{background:linear-gradient(90deg,transparent,var(--gold-glow),var(--gold),var(--gold-glow),transparent)!important;height:3px!important;animation:myTurnGlow 2s ease-in-out infinite}.my-hand-area.my-turn .my-hand-header{background:#ffbf000f}@keyframes myTurnGlow{0%,to{opacity:.7}50%{opacity:1}}.my-hand-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#0003;border-bottom:1px solid var(--border-subtle)}.hand-info{display:flex;align-items:center;gap:14px}.my-hand-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-secondary)}.selected-count{background:linear-gradient(135deg,#ffbf0033,#ffbf001a);color:var(--gold);padding:6px 16px;border-radius:var(--radius-full);font-size:.85rem;font-weight:600;border:1px solid hsla(45 100% 50% / .3)}.turn-indicator{background:linear-gradient(135deg,var(--gold) 0%,var(--gold-glow) 50%,var(--gold-dark) 100%);background-size:200% 200%;color:var(--bg-deep);padding:10px 28px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:1.05rem;box-shadow:0 0 20px #ffbf0080,0 4px 20px #ffbf004d;animation:turnPulse 2s ease-in-out infinite,turnShimmer 3s linear infinite;letter-spacing:.02em}@keyframes turnPulse{0%,to{box-shadow:0 4px 20px #ffbf0080,0 0 40px #ffbf0040;transform:scale(1)}50%{box-shadow:0 4px 30px #ffbf00b3,0 0 60px #ffbf0059;transform:scale(1.03)}}@keyframes turnShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.waiting-turn{background:#ffffff0f;color:var(--text-secondary);padding:8px 20px;border-radius:var(--radius-full);font-size:.9rem;border:1px solid var(--border-subtle);display:flex;align-items:center;gap:8px}.waiting-turn .turn-player-name{font-weight:700;font-family:var(--font-display);color:var(--text-primary)}.waiting-turn .turn-dots{display:inline-flex;gap:3px}.waiting-turn .turn-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-muted);animation:dotBounce 1.4s ease-in-out infinite}.waiting-turn .turn-dots span:nth-child(2){animation-delay:.2s}.waiting-turn .turn-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.hand-cards-sorted{display:flex;justify-content:center;align-items:flex-end;padding:40px 30px 28px;gap:0;min-height:145px;position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.hand-cards-sorted::-webkit-scrollbar{height:4px}.hand-cards-sorted::-webkit-scrollbar-track{background:transparent}.hand-cards-sorted::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.card-wrapper{position:relative;cursor:grab;--card-overlap: -16px;margin:0 var(--card-overlap);touch-action:none}.card-wrapper:first-child{margin-left:0}.card-wrapper:last-child{margin-right:0}.card-wrapper:active{cursor:grabbing}.card-wrapper.dragging{opacity:.35;transform:scale(.96)}.drag-overlay-card{cursor:grabbing;transform:rotate(3deg) scale(1.08);filter:drop-shadow(0 12px 24px hsla(0 0% 0% / .5));pointer-events:none}.drag-overlay-card .card{box-shadow:0 8px 32px #0006,0 0 0 2px var(--gold),0 0 30px #ffbf004d;border:2px solid var(--gold)}.hand-cards-sorted .card{--card-width: 64px;--card-height: 96px;width:var(--card-width);height:var(--card-height);flex-shrink:0;z-index:1;transition:transform var(--duration-fast) var(--ease-spring),box-shadow var(--duration-fast)}.hand-cards-sorted .card .card-rank{font-size:1rem}.hand-cards-sorted .card .card-suit-small{font-size:.75rem}.hand-cards-sorted .card .card-suit-center{font-size:1.8rem}.hand-cards-sorted .card-wrapper:hover .card:not(.selected){transform:translateY(-22px);z-index:50;box-shadow:var(--shadow-lg),0 0 20px #ffc61a33;filter:brightness(1.1)}.hand-cards-sorted .card-wrapper:hover{z-index:50}.hand-cards-sorted .card.selected{transform:translateY(-34px);border:3px solid var(--gold);box-shadow:0 0 0 4px #ffc61a4d,0 0 0 8px #ffc61a26,0 15px 40px #ffc61a66,var(--shadow-lg);filter:brightness(1.05)}.hand-cards-sorted .card.suggested{transform:translateY(-20px);z-index:40;border:2px solid var(--team-blue);box-shadow:0 0 20px #3c83f680,0 0 40px #3c83f633;animation:suggestPulse 1.5s ease-in-out infinite}@keyframes suggestPulse{0%,to{box-shadow:0 0 20px #3c83f680,0 0 40px #3c83f633}50%{box-shadow:0 0 30px #3c83f6b3,0 0 60px #3c83f64d}}.hand-cards-sorted .card.joker{animation:jokerGradient 3s ease infinite}.no-cards-message{color:var(--text-muted);font-style:italic;padding:30px;text-align:center;font-size:1rem}.action-buttons{display:flex;justify-content:center;align-items:center;gap:14px;padding:20px 24px;flex-wrap:wrap}.btn-play{background:linear-gradient(135deg,var(--emerald-light) 0%,var(--emerald) 50%,var(--emerald-dark) 100%);background-size:200% 200%;color:var(--text-primary);font-family:var(--font-display);font-size:1.05rem;font-weight:700;padding:14px 34px;border-radius:var(--radius-lg);border:none;box-shadow:0 4px 20px #1dc97866,inset 0 1px #ffffff40;cursor:pointer;transition:all var(--duration-normal) var(--ease-spring);min-width:145px;position:relative;overflow:hidden}.btn-play:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,hsla(0 0% 100% / .2),transparent);transform:translate(-100%);transition:transform .6s}.btn-play:hover:not(:disabled){transform:translateY(-3px) scale(1.02);background-position:100% 0%;box-shadow:0 8px 32px #1dc97880,inset 0 1px #ffffff4d}.btn-play:hover:not(:disabled):before{transform:translate(100%)}.btn-play:active:not(:disabled){transform:translateY(0)}.btn-play:disabled{background:linear-gradient(135deg,#596273,#434956);box-shadow:none;cursor:not-allowed;opacity:.7}.btn-pass{background:linear-gradient(135deg,#47476b,#393956);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;font-weight:600;padding:12px 26px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm),inset 0 1px #ffffff1a;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.btn-pass:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--team-red) / .2,transparent);opacity:0;transition:opacity var(--duration-normal)}.btn-pass:hover:not(:disabled){background:linear-gradient(135deg,var(--team-red) 0%,hsl(0 85% 55%) 100%);border-color:var(--team-red);box-shadow:0 4px 20px #f25a5a66,inset 0 1px #fff3;transform:translateY(-2px)}.btn-pass:hover:not(:disabled):before{opacity:1}.btn-pass:disabled{opacity:.5;cursor:not-allowed}.btn-suggest{background:linear-gradient(135deg,var(--team-blue) 0%,hsl(217 90% 55%) 100%);background-size:200% 200%;color:var(--text-primary);font-family:var(--font-body);font-size:1rem;font-weight:600;padding:12px 26px;border-radius:var(--radius-md);border:none;box-shadow:0 4px 20px #5593f659,inset 0 1px #fff3;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.btn-suggest:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,hsla(0 0% 100% / .15),transparent);transform:translate(-100%);transition:transform .6s}.btn-suggest:hover:not(:disabled){transform:translateY(-2px) scale(1.02);background-position:100% 0%;box-shadow:0 6px 28px #5593f673,inset 0 1px #ffffff40}.btn-suggest:hover:not(:disabled):before{transform:translate(100%)}.btn-suggest.has-suggestion{background:linear-gradient(135deg,#1dc98f,#169c70);box-shadow:0 4px 20px #1dc98f66,inset 0 1px #fff3}.btn-suggest:disabled{opacity:.5;cursor:not-allowed}.undo-btn{background:linear-gradient(135deg,#f97415,#d65c05);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:12px 22px;border-radius:var(--radius-md);border:none;box-shadow:0 4px 18px #f974154d;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.undo-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #f9741566}.undo-btn:disabled{opacity:.5;cursor:not-allowed}.btn-deselect{background:linear-gradient(135deg,#6f7a90,#545d6d);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:12px 22px;border-radius:var(--radius-md);border:none;box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.btn-deselect:hover{background:linear-gradient(135deg,#8c95a6,#6a758a);transform:translateY(-2px)}.waiting-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--text-primary)}.waiting-text{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin-bottom:12px}.waiting-subtext{color:var(--text-secondary);font-size:1rem}.waiting-dots:after{content:"";animation:dots 1.5s infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.invite-section{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:12px}.btn-fill-ai{padding:18px 44px;background:linear-gradient(135deg,#ed5e5e,#f97415);color:var(--text-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:1.3rem;font-weight:700;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:0 6px 30px #ed5e5e80;animation:pulseInvite 1.5s ease-in-out infinite}.btn-fill-ai:hover{transform:scale(1.05);box-shadow:0 8px 40px #ed5e5e99}@keyframes pulseInvite{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.invite-divider{color:var(--text-muted);font-size:.9rem}.btn-invite{padding:14px 28px;background:linear-gradient(135deg,#9956f5,#a411ee);color:var(--text-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 4px 24px #9956f566}.btn-invite:hover{transform:scale(1.05);box-shadow:0 6px 30px #9956f580}.btn-invite.copied{background:linear-gradient(135deg,var(--emerald) 0%,var(--emerald-dark) 100%)}.invite-hint{color:var(--text-muted);font-size:.85rem;text-align:center}.waiting-actions{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:20px}.waiting-message{font-family:var(--font-display);font-size:1.3rem;color:var(--text-primary);text-shadow:0 2px 4px hsla(0 0% 0% / .3);margin-bottom:12px}.rules-overlay{position:fixed;inset:0;background:#0b111eeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;animation:fadeIn .3s var(--ease-out)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.rules-modal{background:linear-gradient(145deg,var(--bg-elevated),var(--bg-surface));-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:0;max-width:720px;width:100%;max-height:85vh;overflow:hidden;position:relative;box-shadow:var(--shadow-xl),0 0 0 1px #ffffff0d inset;animation:slideUp .4s var(--ease-spring);display:flex;flex-direction:column}.rules-modal:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top,hsla(45 100% 55% / .08) 0%,transparent 50%);pointer-events:none;z-index:0}.rules-close{position:absolute;top:20px;right:20px;background:#ffffff1a;border:1px solid var(--border-subtle);color:var(--text-secondary);width:40px;height:40px;border-radius:var(--radius-full);cursor:pointer;font-size:1.3rem;transition:all var(--duration-fast);z-index:10;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.rules-close:hover{background:#ef434333;color:var(--team-red);border-color:#ef43434d;transform:scale(1.1)}.rules-modal-header{padding:32px 32px 24px;border-bottom:1px solid var(--border-subtle);background:linear-gradient(135deg,hsla(45 100% 50% / .08) 0%,transparent 100%)}.rules-modal-header h2{text-align:center;margin-bottom:8px;font-family:var(--font-display);color:var(--gold);font-size:2rem;font-weight:700;letter-spacing:-.02em}.rules-modal-subtitle{text-align:center;color:var(--text-muted);font-size:.95rem;margin:0}.rules-content{padding:32px;overflow-y:auto;flex:1;color:var(--text-secondary);line-height:1.7}.rules-section{margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid var(--border-subtle)}.rules-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.rules-section-title{display:flex;align-items:center;gap:12px;color:var(--text-primary);margin-bottom:20px;font-family:var(--font-display);font-size:1.25rem;font-weight:600}.rules-section-icon{font-size:1.4rem;line-height:1}.rules-text{margin-bottom:16px;color:var(--text-secondary);font-size:.95rem}.rules-note{font-size:.85rem;color:var(--text-muted);font-style:italic;margin-top:12px;padding:10px 14px;background:#ffbf0014;border-left:3px solid var(--gold);border-radius:var(--radius-sm)}.rules-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}.rules-info-card{background:var(--bg-glass-light);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;display:flex;align-items:center;gap:12px;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.rules-info-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsla(280 80% 65% / .1),transparent);opacity:0;transition:opacity var(--duration-normal)}.rules-info-card:hover{border-color:var(--gold);background:#2d2d43f2;transform:translateY(-3px);box-shadow:var(--shadow-md),0 0 0 1px #ffc61a1a inset}.rules-info-card:hover:before{opacity:1}.rules-info-icon{font-size:1.8rem;line-height:1;flex-shrink:0}.rules-info-content{display:flex;flex-direction:column;gap:4px;flex:1}.rules-info-content strong{color:var(--text-primary);font-size:.9rem;font-weight:600}.rules-info-content span{color:var(--text-secondary);font-size:.85rem}.rules-ranking-chain{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;padding:24px;background:var(--bg-glass-light);-webkit-backdrop-filter:blur(8px) saturate(150%);backdrop-filter:blur(8px) saturate(150%);border-radius:var(--radius-md);margin:16px 0;border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm),0 0 0 1px #ffffff08 inset;position:relative;overflow:hidden}.rules-ranking-chain:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,hsla(45 100% 55% / .05) 0%,transparent 70%);pointer-events:none}.rules-rank-card{background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-sm);padding:10px 16px;font-family:var(--font-display);font-weight:600;font-size:.95rem;color:var(--text-primary);min-width:40px;text-align:center;transition:all var(--duration-normal) var(--ease-spring);position:relative;z-index:1;box-shadow:0 2px 4px #0000001a,inset 0 1px #ffffff1a}.rules-rank-card:hover{transform:scale(1.08) translateY(-2px);border-color:var(--gold);box-shadow:0 4px 16px #ffc61a4d,0 0 0 2px #ffc61a33,inset 0 1px #fff3;z-index:2}.rules-rank-trump{background:linear-gradient(135deg,#3c83f633,#3c83f61a);border-color:#3c83f666;color:var(--team-blue)}.rules-rank-joker{background:linear-gradient(135deg,#ffbf0033,#ffbf001a);border-color:#ffbf0066;color:var(--gold)}.rules-rank-arrow{color:var(--text-muted);font-size:1.2rem;font-weight:300}.rules-combinations{display:flex;flex-direction:column;gap:10px;margin-top:16px}.rules-combo-item{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--bg-glass-light);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.rules-combo-item:hover{border-color:var(--border-medium);background:#212c45e6}.rules-combo-badge{background:linear-gradient(135deg,var(--team-blue),var(--team-blue-glow));color:var(--text-primary);padding:6px 14px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:.85rem;min-width:50px;text-align:center;flex-shrink:0}.rules-combo-item div{display:flex;flex-direction:column;gap:4px;flex:1}.rules-combo-item strong{color:var(--text-primary);font-size:.95rem;font-weight:600}.rules-combo-item span{color:var(--text-secondary);font-size:.85rem}.rules-five-card-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}.rules-five-card-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--bg-glass-light);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.rules-five-card-item:hover{border-color:var(--border-medium);background:#212c45e6;transform:translate(4px)}.rules-five-card-rank{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--bg-deep);width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.9rem;flex-shrink:0}.rules-five-card-item div{display:flex;flex-direction:column;gap:6px;flex:1}.rules-five-card-item strong{color:var(--text-primary);font-size:1rem;font-weight:600}.rules-five-card-item span{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.rules-joker-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}.rules-joker-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--duration-fast)}.rules-joker-allowed{background:#20ac6b1a;border-color:#20ac6b33}.rules-joker-disallowed{background:#ef43431a;border-color:#ef434333}.rules-joker-item:hover{transform:translate(4px);border-color:var(--border-medium)}.rules-joker-icon{font-size:1.2rem;line-height:1;flex-shrink:0}.rules-joker-item span:last-child{color:var(--text-secondary);font-size:.95rem;flex:1}.rules-list{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}.rules-list li{padding-left:24px;position:relative;color:var(--text-secondary);line-height:1.7}.rules-list li:before{content:"•";position:absolute;left:8px;color:var(--gold);font-weight:700;font-size:1.2rem}.login-rules-btn{margin-top:20px;width:100%}.rules-modal::-webkit-scrollbar{width:10px}.rules-modal::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.rules-modal::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px;transition:background var(--duration-fast)}.rules-modal::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:768px){.rules-modal{max-width:100%;max-height:90vh;border-radius:var(--radius-lg)}.rules-modal-header{padding:24px 20px 20px}.rules-modal-header h2{font-size:1.6rem}.rules-content{padding:24px 20px}.rules-grid{grid-template-columns:1fr}.rules-ranking-chain{padding:16px;gap:6px}.rules-rank-card{padding:6px 10px;font-size:.85rem;min-width:36px}}.undo-vote-banner{position:fixed;top:90px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#f97415,#da500b);padding:16px 28px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:500;display:flex;align-items:center;gap:18px;animation:slideDown .3s var(--ease-out)}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.undo-vote-banner .vote-text{color:var(--text-primary);font-weight:600}.undo-vote-banner button{padding:10px 22px;border:none;border-radius:var(--radius-full);cursor:pointer;font-weight:600;transition:all var(--duration-fast)}.undo-vote-banner .vote-yes{background:#21c45d;color:var(--text-primary)}.undo-vote-banner .vote-yes:hover{background:#25da67}.undo-vote-banner .vote-no{background:#ed2c2c;color:var(--text-primary)}.undo-vote-banner .vote-no:hover{background:#ef4343}.message-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:14px 28px;border-radius:var(--radius-full);font-weight:600;z-index:1000;animation:slideUp .3s var(--ease-out);box-shadow:var(--shadow-lg)}.message-toast.error{background:var(--team-red);color:var(--text-primary)}.message-toast.success{background:#21c45d;color:var(--text-primary)}.message-toast.info{background:var(--team-blue);color:var(--text-primary)}.settings-panel{position:fixed;top:12px;right:12px;background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-medium);border-radius:var(--radius-lg);padding:18px;color:var(--text-primary);max-width:260px;z-index:200;box-shadow:var(--shadow-lg)}.settings-toggle{position:fixed;top:12px;right:12px;width:44px;height:44px;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-medium);border-radius:var(--radius-full);color:var(--text-secondary);font-size:1.2rem;cursor:pointer;z-index:201;transition:all var(--duration-fast)}.settings-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.player-settings{display:flex;flex-direction:column;gap:12px}.player-setting-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-surface);border-radius:var(--radius-sm)}.player-setting-item label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.9rem}.my-played-area{position:absolute;bottom:15%;left:50%;transform:translate(-50%)}.my-played-area .card{width:50px;height:75px}@keyframes bounceIn{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.page-container{min-height:100vh;position:relative;z-index:1;background:transparent}.page-content{max-width:900px;margin:0 auto;padding:32px 24px 80px;position:relative}.page-header{text-align:center;margin-bottom:32px}.page-header h1{font-family:var(--font-display);font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--gold) 0%,var(--accent-orange) 50%,var(--accent-pink) 100%);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;animation:gradientShift 8s ease infinite;filter:drop-shadow(0 2px 8px hsla(45 100% 55% / .2))}.page-subtitle{color:var(--text-secondary);font-size:1rem}.page-loading,.page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:1rem;gap:16px}.loading-dots{display:flex;gap:6px}.loading-dots span{width:8px;height:8px;border-radius:50%;background:var(--text-muted);animation:dotBounce 1.4s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.back-link{display:inline-block;color:var(--gold);text-decoration:none;font-size:.9rem;font-weight:500;margin-bottom:20px;transition:color var(--duration-fast)}.back-link:hover{color:var(--gold-glow)}.app-navbar{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-medium);position:sticky;top:0;z-index:100;box-shadow:0 2px 16px #0003,0 0 0 1px #ffffff0d inset}.navbar-brand{display:flex;align-items:center}.navbar-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,var(--gold) 0%,var(--accent-orange) 50%,var(--accent-pink) 100%);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;transition:all var(--duration-normal);animation:gradientShift 8s ease infinite}.navbar-logo:hover{filter:drop-shadow(0 2px 8px hsla(45 100% 55% / .3))}.navbar-links{display:flex;gap:8px}.navbar-link{padding:8px 16px;color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;border-radius:var(--radius-full);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.navbar-link:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#be5eed1f,#3dd6f51f);opacity:0;transition:opacity var(--duration-normal);border-radius:var(--radius-full)}.navbar-link:hover{color:var(--text-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.navbar-link:hover:before{opacity:1}.navbar-link.active{background:linear-gradient(135deg,#ffc61a40,#fa893833);color:var(--gold);box-shadow:0 0 16px #ffc61a4d,0 2px 8px #0000001a;font-weight:600}.navbar-actions{display:flex;align-items:center;gap:8px}.lang-switch-sm{display:flex;gap:4px}.lang-btn-sm{padding:6px 12px;border:1px solid var(--border-subtle);background:transparent;border-radius:var(--radius-full);cursor:pointer;font-size:.8rem;font-weight:600;color:var(--text-muted);transition:all var(--duration-fast)}.lang-btn-sm:hover{color:var(--text-primary);border-color:var(--border-medium)}.lang-btn-sm.active{background:var(--gold);color:var(--bg-deep);border-color:transparent}.rules-toc{background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:24px 28px;margin-bottom:40px;box-shadow:var(--shadow-md),0 0 0 1px #ffffff0d inset;position:relative;overflow:hidden}.rules-toc:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),var(--accent-orange),transparent);opacity:.6}.rules-toc-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:16px;background:linear-gradient(135deg,var(--gold),var(--accent-orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.rules-toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.rules-toc-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.rules-toc-link:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#be5eed1a,#3dd6f51a);opacity:0;transition:opacity var(--duration-normal)}.rules-toc-link:hover{color:var(--text-primary);background:#2d2d4399;transform:translate(4px);box-shadow:0 2px 8px #0000001a}.rules-toc-link:hover:before{opacity:1}.rules-toc-num{font-family:var(--font-display);font-weight:700;color:var(--gold);font-size:.9rem;min-width:24px}.leaderboard-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-medium);background:var(--bg-glass-light);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);box-shadow:var(--shadow-md),0 0 0 1px #ffffff0d inset}.leaderboard-table{width:100%;border-collapse:collapse;font-size:.9rem}.leaderboard-table thead{background:linear-gradient(135deg,var(--bg-surface),var(--bg-elevated));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:2px solid var(--border-medium)}.leaderboard-table th{padding:14px 16px;text-align:left;color:var(--text-secondary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;position:relative}.leaderboard-table th:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.3}.leaderboard-table td{padding:12px 16px;color:var(--text-primary);border-bottom:1px solid hsla(0 0% 100% / .05);transition:all var(--duration-fast)}.leaderboard-table tr:hover td{background:linear-gradient(135deg,#be5eed1a,#3dd6f51a);transform:translate(4px);box-shadow:-4px 0 8px #be5eed1a}.leaderboard-table tr.top-three td{background:linear-gradient(135deg,#ffc61a1f,#fa89381a);border-left:3px solid var(--gold);box-shadow:-4px 0 12px #ffc61a33;position:relative}.leaderboard-table tr.top-three td:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold),var(--accent-orange));opacity:.8}.rank-cell{font-size:1.1rem;width:50px;text-align:center}.player-link{color:var(--gold);text-decoration:none;font-weight:600;transition:all var(--duration-fast);background:linear-gradient(135deg,var(--gold),var(--accent-orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.player-link:hover{filter:drop-shadow(0 2px 4px hsla(45 100% 55% / .4));transform:scale(1.05)}.wins-cell{color:var(--emerald-light);font-weight:600}.winrate-cell{font-family:var(--font-display);font-weight:600;background:linear-gradient(135deg,var(--accent-purple),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.player-cell{font-weight:500}.history-list{display:flex;flex-direction:column;gap:10px}.history-card{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-primary);transition:all var(--duration-normal) var(--ease-out);cursor:pointer;position:relative;overflow:hidden;box-shadow:var(--shadow-sm),0 0 0 1px #ffffff08 inset}.history-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold),var(--accent-orange));opacity:0;transition:opacity var(--duration-normal)}.history-card:hover{background:#2d2d43f2;border-color:var(--gold);transform:translate(6px);box-shadow:var(--shadow-md),0 0 0 1px #ffc61a1a inset}.history-card:hover:before{opacity:1}.history-card-left{display:flex;align-items:center;gap:14px}.result-badge{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.result-badge.won{background:#21c45d33;color:#3bde77;border:1px solid hsla(142 71% 45% / .3)}.result-badge.lost{background:#ed2c2c26;color:#ef4343;border:1px solid hsla(0 84% 55% / .25)}.history-card-info{display:flex;flex-direction:column;gap:4px}.history-card-date{font-size:.9rem;font-weight:500}.history-card-details{font-size:.8rem;color:var(--text-muted)}.history-card-right{flex-shrink:0}.replay-hint{font-size:.8rem;color:var(--text-muted)}.replay-header{text-align:center;margin-bottom:24px}.replay-header h1{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.replay-date{color:var(--text-muted);font-size:.9rem}.replay-summary{display:flex;align-items:stretch;gap:16px;margin-bottom:32px}.replay-team{flex:1;padding:24px;background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);position:relative;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm),0 0 0 1px #ffffff08 inset}.replay-team:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--duration-normal)}.replay-team.winner{border-color:#ffc61a66;background:linear-gradient(135deg,hsla(45 100% 55% / .1),var(--bg-glass-heavy));box-shadow:var(--shadow-md),0 0 0 1px #ffc61a26 inset}.replay-team.winner:before{opacity:1}.replay-team.loser{opacity:.8}.replay-team-label{font-family:var(--font-display);font-weight:700;font-size:1rem;margin-bottom:12px}.replay-team-players{display:flex;flex-direction:column;gap:6px}.replay-player{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-secondary)}.replay-finish{font-family:var(--font-display);font-weight:600;color:var(--text-muted)}.replay-winner-badge{position:absolute;top:-10px;right:-10px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--bg-deep);padding:4px 12px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:.8rem;box-shadow:0 2px 12px #ffbf0066}.replay-vs{display:flex;align-items:center;font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--text-muted)}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.timeline-header h2{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--text-primary)}.timeline-count{font-size:.85rem;color:var(--text-muted)}.timeline-entries{display:flex;flex-direction:column}.timeline-entry{display:flex;gap:12px;padding:8px 0;align-items:flex-start}.timeline-entry.highlight{padding:12px 0}.timeline-time{width:48px;flex-shrink:0;font-size:.75rem;color:var(--text-muted);font-family:var(--font-display);text-align:right;padding-top:2px}.timeline-dot-col{display:flex;flex-direction:column;align-items:center;width:16px;flex-shrink:0}.timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--bg-surface);border:2px solid var(--border-medium);flex-shrink:0}.timeline-dot.team1{border-color:var(--team-red);background:#ef43434d}.timeline-dot.team2{border-color:var(--team-blue);background:#3c83f64d}.timeline-line{flex:1;width:2px;background:var(--border-subtle);min-height:16px}.timeline-content{flex:1;min-width:0}.timeline-action{display:flex;align-items:center;gap:8px}.timeline-icon{font-size:.9rem;flex-shrink:0}.timeline-text{font-size:.85rem;color:var(--text-primary);font-weight:500}.timeline-cards{display:flex;gap:3px;flex-wrap:wrap;margin-top:6px}.timeline-entry.game_started .timeline-dot,.timeline-entry.game_finished .timeline-dot,.timeline-entry.new_game_started .timeline-dot{background:var(--gold);border-color:var(--gold);width:12px;height:12px}.timeline-entry.player_finished .timeline-dot{background:#9956f5;border-color:#9956f5}.timeline-entry.match_won .timeline-dot{background:var(--gold);border-color:var(--gold);width:14px;height:14px;box-shadow:0 0 8px #ffbf0080}.lobby-nav-links{display:flex;gap:12px;margin-top:20px;justify-content:center}.lobby-nav-link{padding:10px 20px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;transition:all var(--duration-fast) var(--ease-out)}.lobby-nav-link:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--gold)}@media(max-width:640px){.page-content{padding:16px 12px 40px}.page-header h1{font-size:1.5rem}.replay-summary{flex-direction:column}.replay-vs{justify-content:center}.navbar-links{gap:4px}.navbar-link{padding:6px 10px;font-size:.8rem}.leaderboard-table th,.leaderboard-table td{padding:10px;font-size:.8rem}}@media(max-width:1024px){.hand-cards-sorted{padding:35px 20px 22px}.card-wrapper{--card-overlap: -14px}.hand-cards-sorted .card{--card-width: 58px;--card-height: 87px}}@media(max-width:768px){.game-table{height:420px}.player-slot.left{left:5px}.player-slot.right{right:5px;transform:translateY(-50%)}.player-slot.top-left{top:40px;left:15%}.player-slot.top-right{top:40px;right:15%}.player-slot.top-center{top:5px}.my-hand-header{padding:14px 18px;flex-wrap:wrap;gap:12px}.my-hand-title{font-size:.95rem}.turn-indicator{padding:8px 20px;font-size:.9rem}.hand-cards-sorted{padding:30px 15px 20px;min-height:125px}.card-wrapper{--card-overlap: -15px}.hand-cards-sorted .card{--card-width: 50px;--card-height: 75px;border-radius:8px}.hand-cards-sorted .card .card-rank{font-size:.85rem}.hand-cards-sorted .card .card-suit-center{font-size:1.4rem}.hand-cards-sorted .card-wrapper:hover .card:not(.selected){transform:translateY(-16px)}.hand-cards-sorted .card.selected{transform:translateY(-24px)}.action-buttons{padding:16px;gap:10px}.btn-play{padding:12px 26px;font-size:1rem;min-width:125px}.btn-pass,.btn-suggest{padding:10px 20px;font-size:.9rem}.player-info{padding:8px 14px;min-width:80px}.player-name{font-size:.85rem}.top-bar{flex-direction:column;gap:12px;padding:12px 18px}.game-info{justify-content:center;gap:12px}}@media(max-width:640px){.my-hand-area{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.my-hand-header{padding:12px 14px}.hand-info{gap:10px}.my-hand-title{font-size:.9rem}.selected-count{padding:5px 12px;font-size:.8rem}.turn-indicator{padding:7px 16px;font-size:.85rem}.waiting-turn{padding:6px 14px;font-size:.8rem}.hand-cards-sorted{padding:25px 10px 16px;min-height:105px}.card-wrapper{--card-overlap: -16px}.hand-cards-sorted .card{--card-width: 44px;--card-height: 66px;border-radius:6px}.hand-cards-sorted .card .card-rank{font-size:.75rem}.hand-cards-sorted .card .card-suit-small{font-size:.6rem}.hand-cards-sorted .card .card-suit-center{font-size:1.2rem}.hand-cards-sorted .card-wrapper:hover .card:not(.selected){transform:translateY(-12px)}.hand-cards-sorted .card.selected{transform:translateY(-20px);border-width:2px}.action-buttons{padding:14px 12px;gap:8px}.btn-play{padding:10px 20px;font-size:.95rem;min-width:105px;border-radius:var(--radius-md)}.btn-pass,.btn-suggest,.undo-btn,.btn-deselect{padding:9px 16px;font-size:.85rem;border-radius:10px}}@media(max-width:480px){.my-hand-area{border-radius:var(--radius-md) var(--radius-md) 0 0}.my-hand-header{padding:10px 12px}.my-hand-title{font-size:.85rem}.turn-indicator{padding:6px 14px;font-size:.8rem}.hand-cards-sorted{padding:20px 8px 14px;min-height:95px}.card-wrapper{--card-overlap: -17px}.hand-cards-sorted .card{--card-width: 38px;--card-height: 57px;border-radius:5px}.hand-cards-sorted .card .card-rank{font-size:.7rem}.hand-cards-sorted .card .card-suit-small{font-size:.55rem}.hand-cards-sorted .card .card-suit-center{font-size:1rem}.hand-cards-sorted .card-wrapper:hover .card:not(.selected){transform:translateY(-10px)}.hand-cards-sorted .card.selected{transform:translateY(-16px)}.action-buttons{padding:12px 8px;gap:6px}.btn-play{padding:9px 18px;font-size:.9rem;min-width:95px}.btn-pass,.btn-suggest,.undo-btn,.btn-deselect{padding:8px 14px;font-size:.8rem}}@media(max-width:375px){.card-wrapper{--card-overlap: -18px}.hand-cards-sorted .card{--card-width: 34px;--card-height: 51px;border-radius:4px}.hand-cards-sorted .card .card-rank{font-size:.65rem}.hand-cards-sorted .card .card-suit-center{font-size:.9rem}.action-buttons{flex-wrap:wrap}.btn-play,.btn-pass{flex:1 1 45%}}@media(hover:none)and (pointer:coarse){.hand-cards-sorted .card{transition:transform var(--duration-fast) ease,box-shadow var(--duration-fast)}.hand-cards-sorted .card:active:not(.selected){transform:translateY(-10px) scale(1.02)}.hand-cards-sorted .card.selected{transform:translateY(-20px) scale(1.02)}.btn-play:active:not(:disabled),.btn-pass:active:not(:disabled),.btn-suggest:active:not(:disabled){transform:scale(.98)}}@media(max-height:500px)and (orientation:landscape){.my-hand-area{border-radius:var(--radius-md) var(--radius-md) 0 0}.my-hand-header{padding:8px 14px}.hand-cards-sorted{padding:16px 12px 12px;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none}.hand-cards-sorted::-webkit-scrollbar{display:none}.hand-cards-sorted .card{--card-width: 42px;--card-height: 63px}.card-wrapper{--card-overlap: -12px}.action-buttons{padding:10px;gap:8px}.btn-play,.btn-pass,.btn-suggest,.undo-btn,.btn-deselect{padding:8px 16px;font-size:.85rem}}.game-over-overlay{position:fixed;inset:0;background:#0b111eeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .3s ease}.game-over-modal{background:linear-gradient(145deg,var(--bg-elevated),var(--bg-surface));border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:32px 40px;max-width:420px;width:100%;box-shadow:var(--shadow-xl),0 0 60px #00000080;animation:slideUp .4s var(--ease-spring)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.game-over-result{text-align:center;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border-subtle)}.game-over-result h1{font-family:var(--font-display);font-size:2rem;font-weight:700;margin-bottom:8px}.game-over-result.victory h1{background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px hsla(45 100% 50% / .4)}.game-over-result.defeat h1{color:var(--text-secondary)}.result-reason{font-size:1rem;color:var(--text-secondary)}.finish-order{margin-bottom:24px}.finish-order h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.finish-list{display:flex;flex-direction:column;gap:8px}.finish-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-glass-light);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--duration-fast) ease}.finish-item.is-me{border-color:var(--gold);background:#ffbf0014}.finish-item.team1{border-left:3px solid var(--team-red)}.finish-item.team2{border-left:3px solid var(--team-blue)}.finish-item.unfinished{opacity:.6;background:#0003}.finish-position{font-size:1.2rem;width:28px;text-align:center}.finish-name{flex:1;font-weight:500;color:var(--text-primary)}.finish-team{font-size:1rem}.tribute-info{text-align:center;padding:16px;background:#ffbf0014;border-radius:var(--radius-md);border:1px solid hsla(45 100% 50% / .2);margin-bottom:24px}.tribute-info p{font-size:.95rem;color:var(--gold)}.game-over-actions{display:flex;gap:12px;justify-content:center}.game-over-actions .btn-primary{min-width:180px}.finish-badge{position:absolute;top:-10px;right:-10px;font-size:1.3rem;z-index:10;animation:badgePop .4s var(--ease-spring)}@keyframes badgePop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.player-info.finished{opacity:.7;background:#ffffff08}.player-info.finished .player-cards-count{opacity:.5}@media(max-width:480px){.game-over-modal{padding:24px;border-radius:var(--radius-lg)}.game-over-result h1{font-size:1.6rem}.finish-item{padding:8px 12px}.finish-position{font-size:1rem;width:24px}.finish-name{font-size:.9rem}}.match-celebration-overlay{position:fixed;inset:0;background:#070a13f7;display:flex;align-items:center;justify-content:center;z-index:1200;overflow:hidden;animation:fadeIn .5s ease}.confetti-container{position:absolute;inset:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;top:-20px;width:10px;height:10px;animation:confettiFall linear infinite}.confetti-piece.red{background:#ef4343;border-radius:2px;transform:rotate(45deg)}.confetti-piece.gold{background:#ffbf00;border-radius:50%}@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.match-celebration-modal{position:relative;z-index:1;max-width:520px;width:100%;padding:40px;text-align:center;animation:celebrationEntry .8s cubic-bezier(.34,1.56,.64,1)}@keyframes celebrationEntry{0%{transform:scale(.7);opacity:0;filter:blur(10px)}to{transform:scale(1);opacity:1;filter:blur(0)}}.celebration-header{margin-bottom:32px}.celebration-trophy{font-size:4rem;margin-bottom:8px;animation:trophyBounce 2s ease-in-out infinite}@keyframes trophyBounce{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.1) translateY(-8px)}}.celebration-header.won h1{font-family:var(--font-display);font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold-glow),#fff,var(--gold));background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmerText 3s linear infinite;letter-spacing:.05em}@keyframes shimmerText{0%{background-position:0% 50%}to{background-position:200% 50%}}.celebration-header.lost h1{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--text-secondary)}.celebration-subtitle{font-size:1.2rem;color:var(--text-secondary);margin-top:8px}.match-progression{display:flex;justify-content:center;gap:32px;margin-bottom:32px;padding:16px 24px;background:#ffffff08;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.progression-step{display:flex;flex-direction:column;align-items:center;gap:6px}.prog-label{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--text-muted)}.prog-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border-medium);background:transparent;transition:all .3s ease}.prog-dot.team1.active{background:var(--team-red);border-color:var(--team-red);box-shadow:0 0 8px #ef434380}.prog-dot.team2.active{background:var(--team-blue);border-color:var(--team-blue);box-shadow:0 0 8px #3c83f680}.celebration-teams{display:flex;align-items:flex-start;gap:24px;margin-bottom:24px}.celebration-team{flex:1;padding:20px;background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.celebration-team.winner{border-color:#ffbf0066;background:#ffbf000d;box-shadow:0 0 20px #ffbf001a}.celebration-team-label{font-family:var(--font-display);font-weight:700;font-size:1rem;margin-bottom:12px;display:flex;align-items:center;justify-content:center;gap:6px}.winner-crown{color:var(--gold);font-size:1.2rem}.celebration-player{font-size:.9rem;color:var(--text-secondary);padding:4px 0}.celebration-vs{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--text-muted);align-self:center;padding-top:24px}.celebration-stats{font-size:.9rem;color:var(--text-muted);margin-bottom:24px}.btn-memory-card{padding:14px 28px;background:linear-gradient(135deg,#9956f5,#a411ee);color:var(--text-primary);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 4px 20px #9956f54d}.btn-memory-card:hover{transform:translateY(-2px);box-shadow:0 6px 28px #9956f566}.celebration-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-group-photo{padding:14px 28px;background:linear-gradient(135deg,var(--emerald) 0%,var(--emerald-dark) 100%);color:var(--text-primary);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 4px 20px #1986534d}.btn-group-photo:hover{transform:translateY(-2px);box-shadow:0 6px 28px #19865366}@media(max-width:640px){.match-celebration-modal{padding:24px}.celebration-header.won h1{font-size:2rem}.celebration-teams{flex-direction:column;gap:12px}.celebration-vs{padding-top:0}.match-progression{gap:20px;padding:12px 16px}.celebration-actions{flex-direction:column}.celebration-actions button{width:100%}}.seat-selection-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px;animation:fadeIn .3s ease;pointer-events:auto;position:relative;z-index:50}.seat-selection-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--text-primary)}.seat-selection-table{position:relative;width:400px;height:280px;background:radial-gradient(ellipse at center,var(--emerald) 0%,var(--emerald-dark) 100%);border-radius:140px/100px;box-shadow:inset 0 4px 30px #0000004d,0 8px 32px #0006,var(--shadow-glow-emerald);border:4px solid hsl(152 50% 25%)}.seat-slot{position:absolute;width:100px;padding:10px 8px;background:var(--bg-glass);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-md);border:2px solid var(--border-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.8rem;text-align:center;pointer-events:auto;z-index:10}.seat-slot:hover{transform:scale(1.05);border-color:var(--gold);box-shadow:var(--shadow-glow-gold)}.seat-slot.empty{border-style:dashed;opacity:.8;cursor:pointer}.seat-slot.empty:hover{opacity:1;background:#ffbf0033;transform:scale(1.08);border-color:var(--gold)}.seat-slot.occupied:not(.is-me){cursor:not-allowed;opacity:.6}.seat-slot.is-me{cursor:pointer;border-color:var(--gold);background:#ffbf0026;box-shadow:0 0 15px #ffbf004d}.seat-slot.team1{border-left:3px solid var(--team-red)}.seat-slot.team2{border-left:3px solid var(--team-blue)}.seat-slot.seat-top-left{top:-30px;left:30px}.seat-slot.seat-top-center{top:-40px;left:50%;transform:translate(-50%)}.seat-slot.seat-top-right{top:-30px;right:30px}.seat-slot.seat-bottom-right{bottom:-30px;right:30px}.seat-slot.seat-bottom-center{bottom:-40px;left:50%;transform:translate(-50%)}.seat-slot.seat-bottom-left{bottom:-30px;left:30px}.seat-slot.seat-top-center:hover,.seat-slot.seat-bottom-center:hover{transform:translate(-50%) scale(1.05)}.seat-team-badge{font-size:.9rem}.seat-number{font-family:var(--font-display);font-weight:600;color:var(--text-secondary);font-size:.7rem}.seat-empty-label{color:var(--gold);font-size:.7rem;font-weight:500}.seat-occupant{color:var(--text-primary);font-weight:500;font-size:.75rem;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-selection-info{text-align:center;color:var(--text-secondary);font-size:.85rem}.seat-selection-info .seated-count{margin-top:8px;color:var(--gold);font-weight:600}.seat-selection-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;position:relative;z-index:100;pointer-events:auto}.btn-leave{padding:10px 20px;background:linear-gradient(135deg,#b82e2e,#8f2424);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--duration-fast) ease;pointer-events:auto}.btn-leave:hover{background:linear-gradient(135deg,#c33,#a32929);transform:translateY(-2px);box-shadow:0 4px 12px #a3292966}@media(max-width:480px){.seat-selection-table{width:300px;height:210px;border-radius:105px/75px}.seat-slot{width:70px;padding:6px 4px;font-size:.7rem}.seat-slot.seat-top-left{top:-25px;left:15px}.seat-slot.seat-top-center{top:-30px}.seat-slot.seat-top-right{top:-25px;right:15px}.seat-slot.seat-bottom-right{bottom:-25px;right:15px}.seat-slot.seat-bottom-center{bottom:-30px}.seat-slot.seat-bottom-left{bottom:-25px;left:15px}.seat-selection-actions{flex-direction:column;width:100%}.seat-selection-actions button{width:100%}}.tribute-banner{position:fixed;top:70px;left:50%;transform:translate(-50%);background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid hsla(45 100% 50% / .25);border-radius:var(--radius-full);padding:10px 24px;display:flex;align-items:center;gap:16px;z-index:400;box-shadow:var(--shadow-lg),0 0 20px #ffbf001a;animation:slideDown .3s var(--ease-out);max-width:90vw}.tribute-banner-content{display:flex;align-items:center;gap:10px}.tribute-banner-title{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--gold);white-space:nowrap}.tribute-banner-subtitle{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.tribute-banner-progress{display:flex;gap:5px;align-items:center}.tribute-pip{width:8px;height:8px;border-radius:50%;background:#ffbf004d;border:1px solid hsla(45 100% 50% / .5);transition:all var(--duration-fast)}.tribute-pip.done{background:#21c45d;border-color:#3bde77;box-shadow:0 0 6px #21c45d80}@media(max-width:640px){.tribute-banner{padding:8px 16px;gap:10px}.tribute-banner-title{font-size:.8rem}.tribute-banner-subtitle{display:none}}.tribute-overlay{position:fixed;inset:0;background:#0b111eeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:900;padding:24px;animation:fadeIn .3s ease}.tribute-modal{background:linear-gradient(145deg,var(--bg-elevated),var(--bg-surface));border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:32px 40px;max-width:600px;width:100%;box-shadow:var(--shadow-xl),0 0 60px #ffbf0026;animation:slideUp .4s var(--ease-spring);text-align:center}.tribute-modal h2{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tribute-instruction{color:var(--text-secondary);margin-bottom:24px;font-size:1rem}.tribute-status{color:var(--text-secondary);margin-bottom:20px;font-size:.95rem}.tribute-progress{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:16px}.tribute-player{padding:8px 16px;border-radius:var(--radius-full);font-size:.9rem;font-weight:500}.tribute-player.done{background:#21c45d33;color:#3bde77;border:1px solid hsla(142 71% 45% / .3)}.tribute-player.waiting{background:#ffbf001a;color:var(--gold);border:1px solid hsla(45 100% 50% / .2);animation:waitingPulse 2s ease-in-out infinite}@keyframes waitingPulse{0%,to{opacity:.7}50%{opacity:1}}.tribute-cards-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:20px;margin:16px 0;background:#0003;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);max-height:400px;overflow-y:auto}.tribute-card-wrapper{cursor:pointer;transition:all var(--duration-fast) var(--ease-spring);border-radius:var(--radius-sm);padding:4px}.tribute-card-wrapper:hover{transform:translateY(-8px)}.tribute-card-wrapper.selected{transform:translateY(-12px);background:#ffbf0026;box-shadow:0 0 20px #ffbf0066}.tribute-card-wrapper.selected .card{border:3px solid var(--gold);box-shadow:0 0 0 4px #ffbf0040,var(--shadow-lg)}.btn-tribute-submit{margin-top:20px;padding:14px 40px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);color:var(--bg-deep);border:none;border-radius:var(--radius-lg);font-family:var(--font-display);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 4px 20px #ffbf004d}.btn-tribute-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #ffbf0066}.btn-tribute-submit:disabled{background:linear-gradient(135deg,#596273,#434956);color:var(--text-muted);box-shadow:none;cursor:not-allowed}@media(max-width:640px){.tribute-modal{padding:24px 20px;border-radius:var(--radius-lg)}.tribute-modal h2{font-size:1.3rem}.tribute-cards-grid{gap:8px;padding:16px;max-height:300px}.tribute-card-wrapper{padding:2px}.tribute-card-wrapper .card{width:50px;height:75px}.btn-tribute-submit{padding:12px 32px;font-size:1rem}}@media(max-width:480px){.tribute-modal{padding:20px 16px}.tribute-modal h2{font-size:1.2rem}.tribute-instruction,.tribute-status{font-size:.9rem}.tribute-cards-grid{gap:6px;padding:12px;max-height:250px}.tribute-card-wrapper .card{width:44px;height:66px}.tribute-progress{gap:10px}.tribute-player{padding:6px 12px;font-size:.8rem}}.video-bubble{position:relative;border-radius:50%;overflow:hidden;border:2px solid var(--border-medium);box-shadow:var(--shadow-md);background:var(--bg-deep);flex-shrink:0}.video-bubble-sm{width:72px;height:72px}.video-bubble-md{width:96px;height:96px}.video-bubble-local{border-color:var(--gold);box-shadow:0 0 12px #ffbf004d}.video-bubble-video{width:100%;height:100%;object-fit:cover;display:block}.video-bubble-local .video-bubble-video{transform:scaleX(-1)}.video-bubble-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-surface));color:var(--text-secondary);font-family:var(--font-display);font-weight:700;font-size:1.1rem}.video-bubble-md .video-bubble-avatar{font-size:1.4rem}.video-bubble-mic-off{position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;background:#ed2c2c;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.55rem;border:1.5px solid var(--bg-deep);z-index:2}.video-bubble-cam-off{position:absolute;top:-2px;right:-2px;width:18px;height:18px;background:#f96b06;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.5rem;border:1.5px solid var(--bg-deep);z-index:2}.player-slot-with-video{display:flex;align-items:flex-start;gap:6px}.my-video-area{display:flex;align-items:center;gap:8px}.media-controls{display:flex;align-items:center;gap:6px;padding:0 8px}.media-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-medium);background:var(--bg-surface);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex;align-items:center;justify-content:center;padding:0}.media-btn:hover{background:var(--bg-elevated);border-color:var(--gold);transform:scale(1.08)}.media-btn-on{background:#21c45d33;border-color:#21c45d66}.media-btn-off{background:#ed2c2c26;border-color:#ed2c2c4d}.media-btn-start{width:auto;border-radius:var(--radius-full);padding:8px 18px;font-size:.85rem;font-weight:600;font-family:var(--font-body);background:linear-gradient(135deg,#9956f5,#a411ee);border:none;box-shadow:0 2px 12px #9956f54d}.media-btn-start:hover{box-shadow:0 4px 18px #9956f566;transform:scale(1.05)}.media-btn-stop{background:#ed2c2c26;border-color:#ed2c2c4d;font-size:.75rem}.media-btn-stop:hover{background:#ed2c2c4d}.media-btn-settings{font-size:.8rem}.media-settings-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;animation:fadeIn .2s var(--ease-out)}.media-settings-modal{background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-base) 100%);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:32px;max-width:420px;width:100%;position:relative;box-shadow:var(--shadow-xl);animation:slideUp .3s var(--ease-out)}.media-settings-close{position:absolute;top:16px;right:16px;background:#ffffff1a;border:none;color:var(--text-secondary);width:36px;height:36px;border-radius:var(--radius-full);cursor:pointer;font-size:1.2rem;transition:all var(--duration-fast)}.media-settings-close:hover{background:#ef434333;color:var(--team-red)}.media-settings-modal h2{text-align:center;margin-bottom:24px;font-family:var(--font-display);color:var(--gold);font-size:1.4rem;font-weight:700}.media-settings-preview{width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:24px;background:var(--bg-deep);border:1px solid var(--border-subtle)}.media-settings-video{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}.media-settings-no-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.95rem}.media-settings-group{margin-bottom:20px}.media-settings-group label{display:block;color:var(--text-secondary);font-size:.9rem;font-weight:600;margin-bottom:8px}.media-settings-group select{width:100%;padding:12px 36px 12px 16px;border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:border-color var(--duration-fast);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23999' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.media-settings-group select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #ffbf0026}.audio-level-meter{margin-top:10px;width:100%;height:6px;background:var(--bg-deep);border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--border-subtle)}.audio-level-fill{height:100%;background:linear-gradient(90deg,#21c45d,#ffbf00);border-radius:var(--radius-full);transition:width .1s ease}.btn-test-speaker{width:100%;margin-top:10px;padding:10px 16px;background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.btn-test-speaker:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--gold);color:var(--gold)}.btn-test-speaker.testing{background:#21c45d26;border-color:#21c45d66;color:#3bde77;cursor:default;animation:speakerPulse .6s ease-in-out infinite}@keyframes speakerPulse{0%,to{opacity:1}50%{opacity:.7}}.btn-test-speaker:disabled{opacity:.6;cursor:not-allowed}.media-settings-hint{margin-top:8px;font-size:.8rem;color:var(--text-muted);line-height:1.4}.audio-level-label{margin-top:4px;font-size:.75rem;color:var(--text-muted);text-align:right}.match-levels{display:flex;align-items:center;gap:12px;font-size:.85rem}.team-level{padding:4px 12px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:.85rem}.team-level.team1{background:#ef434326;color:var(--team-red);border:1px solid hsla(0 84% 60% / .3)}.team-level.team2{background:#3c83f626;color:var(--team-blue);border:1px solid hsla(217 91% 60% / .3)}.banker-indicator{padding:4px 12px;background:#ffbf001f;border:1px solid hsla(45 100% 50% / .25);border-radius:var(--radius-full);color:var(--gold);font-weight:600;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.game-number{color:var(--text-muted);font-size:.8rem;font-weight:500}.player-badge.banker{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--bg-deep)}.upgrade-info{text-align:center;padding:12px 16px;background:#21c45d1a;border-radius:var(--radius-md);border:1px solid hsla(142 71% 45% / .25);margin-bottom:16px}.upgrade-info p{font-size:1.1rem;font-weight:700;font-family:var(--font-display);color:#3bde77}.upgrade-info.no-upgrade{background:#ffbf0014;border-color:#ffbf0033}.upgrade-info.no-upgrade p{color:var(--gold);font-size:.95rem;font-weight:500}.tribute-selected-count{font-size:.85rem;color:var(--gold);font-weight:600;margin-top:8px;text-align:center}.tribute-warning{font-size:.8rem;color:#f97415;margin-top:8px;text-align:center;font-weight:500}@media(max-width:768px){.match-levels{gap:8px;font-size:.8rem}.team-level{padding:3px 8px;font-size:.75rem}.banker-indicator{max-width:80px;font-size:.7rem;padding:3px 8px}}@media(max-width:480px){.match-levels{gap:6px}.team-level{padding:2px 6px;font-size:.7rem}.banker-indicator,.game-number{display:none}}.game-log-toggle{padding:8px 16px;background:#3366cc26;border:1px solid hsla(220 60% 50% / .3);color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;font-size:.85rem;font-weight:500;transition:all var(--duration-fast) var(--ease-out)}.game-log-toggle:hover{background:#3366cc40;color:var(--text-primary);border-color:var(--team-blue)}.game-log-toggle.has-new{animation:logPulse 2s ease-in-out infinite}@keyframes logPulse{0%,to{box-shadow:none}50%{box-shadow:0 0 12px #36c6}}.sfx-toggle{padding:8px 12px;background:#33995526;border:1px solid hsla(140 50% 40% / .3);color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;font-size:.85rem;transition:all var(--duration-fast) var(--ease-out)}.sfx-toggle:hover{background:#33995540;color:var(--text-primary)}.sfx-toggle.muted{background:#8080801a;border-color:#80808033;opacity:.6}.game-log-panel{position:fixed;top:0;right:0;width:340px;max-width:90vw;height:100vh;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid var(--border-medium);z-index:300;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0006;animation:slideInRight .25s var(--ease-out)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.game-log-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--border-subtle);background:#0003;flex-shrink:0}.game-log-header h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.game-log-close{width:32px;height:32px;background:#ffffff14;border:none;color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;font-size:1rem;transition:all var(--duration-fast);display:flex;align-items:center;justify-content:center}.game-log-close:hover{background:#ef434333;color:var(--team-red)}.game-log-entries{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin}.game-log-entries::-webkit-scrollbar{width:4px}.game-log-entries::-webkit-scrollbar-track{background:transparent}.game-log-entries::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:2px}.game-log-empty{display:flex;align-items:center;justify-content:center;height:120px;color:var(--text-muted);font-size:.9rem}.game-log-entry{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 16px;gap:10px;transition:background var(--duration-fast);border-bottom:1px solid hsla(0 0% 100% / .03)}.game-log-entry:hover{background:#ffffff08}.game-log-entry.game_started,.game-log-entry.game_finished{background:#ffbf000d;border-left:2px solid var(--gold)}.game-log-entry.trick_won{background:#21c45d0a;border-left:2px solid hsla(142 71% 45% / .4)}.game-log-entry.player_finished{background:#9956f50a;border-left:2px solid hsla(265 89% 65% / .4)}.game-log-entry.level_up{background:#21c45d0f;border-left:2px solid hsla(142 71% 45% / .5)}.game-log-entry.match_won{background:#ffbf0014;border-left:2px solid var(--gold)}.game-log-entry.banker_changed{background:#ffbf000a;border-left:2px solid hsla(45 100% 50% / .3)}.game-log-entry.new_game_started{background:#9956f50a;border-left:2px solid hsla(265 89% 65% / .3)}.log-entry-left{display:flex;gap:10px;align-items:flex-start;flex:1;min-width:0}.log-icon{font-size:.9rem;flex-shrink:0;margin-top:1px}.log-entry-content{display:flex;flex-direction:column;gap:4px;min-width:0}.log-entry-action{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.log-team-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.log-team-dot.team1{background:var(--team-red)}.log-team-dot.team2{background:var(--team-blue)}.log-action-text{font-size:.85rem;color:var(--text-primary);font-weight:500;line-height:1.3}.log-combo-type{font-size:.75rem;color:var(--gold);background:#ffbf001a;padding:1px 8px;border-radius:var(--radius-full);font-weight:600;white-space:nowrap}.log-cards-row{display:flex;gap:3px;flex-wrap:wrap;margin-top:2px}.log-mini-card{display:inline-flex;align-items:center;gap:1px;padding:2px 5px;border-radius:4px;font-size:.75rem;font-weight:700;font-family:var(--font-display);background:linear-gradient(145deg,#f8f7f2,#ece9df);border:1px solid hsla(0 0% 0% / .1);line-height:1}.log-mini-card.log-card-red{color:var(--red-suit)}.log-mini-card.log-card-black{color:var(--black-suit)}.log-mini-card.log-card-joker{background:linear-gradient(135deg,#f7baba,#b6eafb,#f9c8f9);color:#333}.log-mini-rank{font-size:.7rem}.log-mini-suit{font-size:.65rem}.log-time{font-size:.7rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0;margin-top:2px}@media(max-width:640px){.game-log-panel{width:100%;max-width:100vw}}@media(max-width:480px){.game-log-entry{padding:8px 12px}.log-action-text{font-size:.8rem}.log-mini-card{padding:1px 4px;font-size:.7rem}.log-mini-rank{font-size:.65rem}.log-mini-suit{font-size:.6rem}}@media(max-width:768px){.video-bubble-sm{width:48px;height:48px}.video-bubble-md{width:64px;height:64px}.media-btn{width:32px;height:32px;font-size:.8rem}.media-btn-start{padding:6px 14px;font-size:.8rem}.media-controls{gap:4px}.video-bubble-md .video-bubble-avatar{font-size:.95rem}}@media(max-width:480px){.video-bubble-sm{width:40px;height:40px}.video-bubble-md{width:52px;height:52px}.media-btn{width:28px;height:28px;font-size:.7rem}.media-btn-start{padding:5px 12px;font-size:.75rem}.video-bubble-mic-off,.video-bubble-cam-off{width:14px;height:14px;font-size:.45rem}}.landing{position:relative;z-index:1;overflow-x:hidden}.landing-lang{position:fixed;top:20px;right:24px;display:flex;gap:4px;z-index:100}.landing-floating-cards{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.landing-floating-cards .interactive-card{position:absolute;width:80px;height:120px;opacity:.08;pointer-events:auto;filter:blur(.5px);transition:opacity .4s,filter .4s,transform .1s;will-change:transform,opacity}.landing-floating-cards .interactive-card:hover{opacity:.5;filter:blur(0);z-index:10}.float-card{animation:floatStream 25s linear infinite;top:-150px}.float-card-0{left:5%;animation-duration:20s;animation-delay:0s}.float-card-1{left:15%;animation-duration:22s;animation-delay:2s}.float-card-2{left:25%;animation-duration:24s;animation-delay:4s}.float-card-3{left:35%;animation-duration:26s;animation-delay:1s}.float-card-4{left:45%;animation-duration:28s;animation-delay:3s}.float-card-5{left:55%;animation-duration:23s;animation-delay:5s}.float-card-6{left:65%;animation-duration:25s;animation-delay:.5s}.float-card-7{left:75%;animation-duration:27s;animation-delay:2.5s}.float-card-8{left:85%;animation-duration:21s;animation-delay:4.5s}.float-card-9{left:95%;animation-duration:29s;animation-delay:1.5s}@keyframes floatStream{0%{transform:translateY(0) rotate(0) translateZ(0);opacity:0}10%{opacity:.08}90%{opacity:.08}to{transform:translateY(calc(100vh + 200px)) rotate(360deg) translateZ(0);opacity:0}}.landing-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:60px 24px;position:relative}.landing-title{font-family:var(--font-display);font-size:clamp(3rem,8vw,5.5rem);font-weight:700;letter-spacing:-.03em;background:linear-gradient(135deg,var(--gold) 0%,var(--accent-orange) 25%,var(--accent-pink) 50%,var(--accent-purple) 75%,var(--accent-cyan) 100%);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1;margin-bottom:8px;text-shadow:none;filter:drop-shadow(0 4px 20px hsla(45 100% 55% / .25)) drop-shadow(0 2px 8px hsla(280 80% 65% / .15));animation:gradientShift 10s ease infinite;position:relative}.landing-title:after{content:attr(data-text);position:absolute;inset:0;background:linear-gradient(135deg,var(--gold) 0%,var(--accent-orange) 50%,var(--accent-pink) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:blur(20px) opacity(.5);z-index:-1;animation:gradientShift 10s ease infinite reverse}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.landing-subtitle-zh{font-family:var(--font-display);font-size:clamp(1.4rem,4vw,2.2rem);color:var(--text-secondary);letter-spacing:.15em;margin-bottom:16px;font-weight:500}.landing-tagline{font-size:clamp(1rem,2.5vw,1.3rem);color:var(--text-muted);max-width:500px;margin-bottom:40px;line-height:1.5}.landing-seo-text{max-width:900px;margin:0 auto;padding:0 24px 60px;color:var(--text-secondary);font-size:clamp(.9rem,1.5vw,1rem);line-height:1.8;text-align:center}.landing-hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.landing-btn-primary{display:inline-block;padding:16px 40px;background:linear-gradient(135deg,var(--gold) 0%,var(--accent-orange) 50%,var(--accent-pink) 100%);background-size:200% 200%;color:var(--bg-deep);border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-size:1.1rem;font-weight:700;text-decoration:none;cursor:pointer;transition:all var(--duration-normal) var(--ease-spring);box-shadow:0 4px 28px #ffc61a66,0 0 #ffc61a00;position:relative;overflow:hidden}.landing-btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,hsla(0 0% 100% / .3),transparent);transform:translate(-100%);transition:transform .8s}.landing-btn-primary:hover{transform:translateY(-4px) scale(1.03);background-position:100% 0%;box-shadow:0 10px 40px #ffc61a80,0 0 0 4px #ffc61a33}.landing-btn-primary:hover:before{transform:translate(100%)}.landing-btn-lg{padding:18px 48px;font-size:1.2rem}.landing-btn-outline{display:inline-block;padding:16px 36px;background:transparent;color:var(--text-primary);border:2px solid var(--border-medium);border-radius:var(--radius-md);font-family:var(--font-display);font-size:1.1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.landing-btn-outline:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--accent-purple) / .1,var(--accent-cyan) / .1);opacity:0;transition:opacity var(--duration-normal)}.landing-btn-outline:hover{border-color:var(--gold);color:var(--gold);background:#ffc61a1a;transform:translateY(-2px);box-shadow:0 4px 20px #ffc61a33}.landing-btn-outline:hover:before{opacity:1}.landing-section{max-width:960px;margin:0 auto;padding:80px 24px}.landing-section-title{font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;text-align:center;color:var(--text-primary);margin-bottom:48px;letter-spacing:-.02em}.animate-section{opacity:0;transform:translateY(30px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}.animate-section.animate-in{opacity:1;transform:translateY(0)}.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.landing-content-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.landing-feature-card{background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:36px 28px;text-align:center;box-shadow:var(--shadow-md),0 0 0 1px #ffffff0d inset;transition:all var(--duration-normal) var(--ease-spring);position:relative;overflow:hidden}.landing-feature-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsla(280 80% 65% / .08) 0%,transparent 30%,transparent 70%,hsla(190 90% 60% / .08) 100%);opacity:0;transition:opacity var(--duration-normal)}.landing-feature-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--duration-normal)}.landing-feature-card:hover{transform:translateY(-8px) scale(1.02);border-color:var(--gold);box-shadow:var(--shadow-lg),0 0 40px #ffc61a33,0 0 0 1px #ffc61a1a inset}.landing-feature-card:hover:before,.landing-feature-card:hover:after{opacity:1}.landing-feature-icon{font-size:2.8rem;display:block;margin-bottom:18px;line-height:1}.suit-spade,.suit-club{color:var(--text-primary)}.suit-heart,.suit-diamond{color:var(--team-red)}.landing-feature-card h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:10px}.landing-feature-card p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.landing-steps{display:flex;gap:24px;justify-content:center}.landing-step{flex:1;max-width:260px;text-align:center;position:relative;padding:32px 20px;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.landing-step-num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--bg-deep);font-family:var(--font-display);font-weight:800;font-size:1.2rem;border-radius:var(--radius-full);margin-bottom:16px;box-shadow:0 4px 16px #ffbf004d}.landing-step-line{display:none}.landing-step h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.landing-step p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.card-type-showcase{max-width:600px;margin:0 auto;background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:0;box-shadow:var(--shadow-xl);overflow:hidden}.card-type-tabs{display:flex;border-bottom:1px solid var(--border-subtle)}.card-type-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background:transparent;border:none;cursor:pointer;color:var(--text-muted);transition:all .25s ease;position:relative}.card-type-tab:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--gold);border-radius:1px;transform:scaleX(0);transition:transform .25s ease}.card-type-tab.active:after{transform:scaleX(1)}.card-type-tab:hover{color:var(--text-primary);background:#ffffff08}.card-type-tab.active{color:var(--gold)}.card-type-tab-count{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:800;font-size:.85rem;border:1px solid var(--border-subtle);transition:all .25s ease}.card-type-tab.active .card-type-tab-count{background:#ffbf0026;border-color:#ffbf004d;color:var(--gold)}.card-type-tab-label{font-size:.8rem;font-weight:600}.card-type-display{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:40px 20px 24px;cursor:pointer;transition:background .2s}.card-type-display:hover{background:#ffffff05}.card-type-display:active{background:#ffffff0a}.card-type-label{margin-top:20px;font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;opacity:.6;transition:opacity .2s}.card-type-display:hover .card-type-label{opacity:.9}.card-type-cards{display:flex;justify-content:center;align-items:flex-end;position:relative}.card-type-card-slot{transform-origin:bottom center;transform:rotate(var(--fan-angle, 0deg));margin:0 -12px;animation:cardTypeReveal .35s cubic-bezier(.34,1.56,.64,1) backwards;animation-delay:var(--deal-delay, 0ms)}.card-type-card-slot:first-child{margin-left:0}.card-type-card-slot:last-child{margin-right:0}.card-type-card-slot .interactive-card{width:72px;height:108px}@keyframes cardTypeReveal{0%{transform:rotate(var(--fan-angle, 0deg)) translateY(40px) scale(.7);opacity:0}to{transform:rotate(var(--fan-angle, 0deg)) translateY(0) scale(1);opacity:1}}@media(max-width:480px){.card-type-showcase{margin:0 10px}.card-type-tab{padding:12px 4px}.card-type-tab-label{font-size:.7rem}.card-type-tab-count{width:24px;height:24px;font-size:.75rem}.card-type-display{min-height:170px;padding:30px 16px 20px}.card-type-card-slot .interactive-card{width:56px;height:84px}.card-type-card-slot{margin:0 -14px}.card-type-label{margin-top:14px;font-size:.75rem}}.landing-cta{text-align:center;padding:100px 24px;background:radial-gradient(ellipse at center,hsla(45 100% 50% / .06) 0%,transparent 60%)}.landing-cta h2{font-family:var(--font-display);font-size:clamp(1.8rem,5vw,2.8rem);font-weight:700;color:var(--text-primary);margin-bottom:32px;letter-spacing:-.02em}.landing-cta-note{margin-top:20px;color:var(--text-muted);font-size:.9rem}.landing-footer{display:flex;align-items:center;justify-content:center;gap:16px;padding:32px 24px;border-top:1px solid var(--border-subtle);flex-wrap:wrap;font-size:.85rem;color:var(--text-muted)}.landing-footer-logo{font-family:var(--font-display);font-weight:700;font-size:.95rem;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-footer-divider{opacity:.3}.landing-footer-links{display:flex;gap:16px}.landing-footer-links a{color:var(--text-secondary);text-decoration:none;transition:color var(--duration-fast)}.landing-footer-links a:hover{color:var(--gold)}@media(max-width:768px){.landing-features-grid,.landing-content-grid{grid-template-columns:1fr;gap:16px}.landing-steps{flex-direction:column;align-items:center}.landing-step{max-width:100%}.landing-section{padding:60px 20px}.landing-hero{padding:40px 20px;min-height:90vh}.float-spade,.float-heart,.float-diamond,.float-club{font-size:3.5rem}}@media(max-width:480px){.landing-hero-actions{flex-direction:column;width:100%;padding:0 20px}.landing-btn-primary,.landing-btn-outline{width:100%;text-align:center}.landing-footer{flex-direction:column;gap:10px;text-align:center}}.card-type-breadcrumb{display:flex;align-items:center;gap:0;margin-bottom:24px;font-size:.9rem;color:var(--text-muted)}.card-type-breadcrumb a{color:var(--text-secondary);text-decoration:none;transition:color var(--duration-fast)}.card-type-breadcrumb a:hover{color:var(--gold)}.card-type-breadcrumb span[aria-hidden]{margin:0 8px;color:var(--text-muted);opacity:.5}.card-type-links{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-subtle)}.card-type-links h2{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--text-primary);margin-bottom:20px}.card-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.card-type-link{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--bg-glass-light);border:1px solid var(--border-subtle);border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:all var(--duration-fast)}.card-type-link:hover{background:var(--bg-glass-medium);border-color:var(--gold);transform:translateY(-1px)}.card-type-link-emoji{font-size:1.3rem;line-height:1}.card-type-link-name{font-size:.9rem;font-weight:500}.rules-cta{text-align:center;margin-top:48px;padding:40px 24px;background:radial-gradient(ellipse at center,hsla(45 100% 50% / .06) 0%,transparent 60%);border-radius:var(--radius-lg)}.rules-cta h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.rules-cta p{color:var(--text-secondary);margin-bottom:24px;font-size:1rem}.rules-cta-btn{display:inline-block;padding:12px 32px;background:linear-gradient(135deg,var(--gold),var(--gold-glow));color:var(--bg-deep);font-family:var(--font-display);font-weight:600;font-size:1rem;border-radius:var(--radius-md);text-decoration:none;cursor:pointer;transition:all var(--duration-fast)}.rules-cta-btn:hover{transform:translateY(-2px);box-shadow:0 4px 20px #ffc61a4d}.rules-cta-btn-secondary{display:inline-block;padding:12px 32px;background:var(--bg-glass-light);color:var(--text-primary);font-family:var(--font-display);font-weight:600;font-size:1rem;border-radius:var(--radius-md);text-decoration:none;cursor:pointer;border:1px solid var(--border-subtle);transition:all var(--duration-fast)}.rules-cta-btn-secondary:hover{background:var(--bg-glass-medium);border-color:var(--gold);transform:translateY(-2px)}.card-type-cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.rules-article{line-height:1.7}.rules-article h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:32px 0 16px;letter-spacing:-.01em}.rules-article h3{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:24px 0 12px}.rules-article p{color:var(--text-secondary);margin-bottom:16px}.rules-article strong{color:var(--text-primary);font-weight:600}.rules-article ul,.rules-article ol{color:var(--text-secondary);padding-left:24px;margin-bottom:16px}.rules-article li{margin-bottom:6px}.rules-article table{width:100%;border-collapse:collapse;margin:16px 0;font-size:.9rem}.rules-article th,.rules-article td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.rules-article th{color:var(--text-primary);font-weight:600;background:var(--bg-glass-light)}@media(max-width:640px){.card-type-grid{grid-template-columns:repeat(2,1fr);gap:8px}.card-type-link{padding:10px 12px}.card-type-link-name{font-size:.8rem}.card-type-cta-buttons{flex-direction:column;align-items:center}.card-type-cta-buttons a{width:100%;max-width:280px;text-align:center}}.navbar-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;background:none;border:none;cursor:pointer;z-index:1001}.navbar-hamburger span{display:block;width:20px;height:2px;background:var(--text-secondary, #b0b0c0);border-radius:2px;transition:transform .2s,opacity .2s}.navbar-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-hamburger.open span:nth-child(2){opacity:0}.navbar-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar-mobile-menu{position:absolute;top:100%;left:0;right:0;background:var(--bg-card, #1a1a2e);border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.08));padding:8px 0;display:flex;flex-direction:column;z-index:1000;box-shadow:0 8px 24px #0000004d}.navbar-mobile-link{padding:12px 24px;color:var(--text-secondary, #b0b0c0);text-decoration:none;font-size:.95rem;transition:background .15s,color .15s;cursor:pointer}.navbar-mobile-link:hover,.navbar-mobile-link.active{background:#ffffff0d;color:var(--text-primary, #fff)}@media(max-width:768px){.navbar-desktop{display:none!important}.navbar-hamburger{display:flex}.app-navbar{position:relative}}@media(min-width:769px){.navbar-mobile-menu,.navbar-hamburger{display:none!important}}.rules-article{line-height:1.8;color:var(--text-secondary, #b0b0c0);font-size:1rem}.rules-article h2{font-size:1.5rem;font-weight:700;color:var(--text-primary, #fff);margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.08));letter-spacing:-.01em}.rules-article h3{font-size:1.2rem;font-weight:600;color:var(--text-primary, #fff);margin:2rem 0 .75rem}.rules-article h4{font-size:1.05rem;font-weight:600;color:var(--text-primary, #e0e0e8);margin:1.5rem 0 .5rem}.rules-article p{color:var(--text-secondary, #b0b0c0);margin-bottom:1rem;line-height:1.8}.rules-article p:last-child{margin-bottom:0}.rules-article a{color:var(--accent, #6c5ce7);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#6c5ce74d;transition:color .15s,text-decoration-color .15s;cursor:pointer}.rules-article a:hover{color:#a29bfe;text-decoration-color:#a29bfe}.rules-article ul{list-style:disc;padding-left:1.5rem;margin-bottom:1.25rem}.rules-article ul ul{list-style:circle;margin-top:.5rem;margin-bottom:.5rem}.rules-article ol{list-style:decimal;padding-left:1.5rem;margin-bottom:1.25rem}.rules-article ol ol{list-style:lower-alpha;margin-top:.5rem;margin-bottom:.5rem}.rules-article li{margin-bottom:.5rem;line-height:1.7;color:var(--text-secondary, #b0b0c0);padding-left:.25rem}.rules-article li::marker{color:var(--accent, #6c5ce7)}.rules-article strong{color:var(--text-primary, #fff);font-weight:600}.rules-article table{width:100%;border-collapse:collapse;margin:1.25rem 0;font-size:.9rem;border-radius:8px;overflow:hidden}.rules-article thead{background:var(--bg-glass-light, rgba(255,255,255,.05))}.rules-article th{color:var(--text-primary, #fff);font-weight:600;padding:.75rem 1rem;text-align:left;border-bottom:2px solid var(--border-subtle, rgba(255,255,255,.12));white-space:nowrap}.rules-article td{padding:.625rem 1rem;border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.06));color:var(--text-secondary, #b0b0c0)}.rules-article tbody tr:hover{background:#ffffff05}.rules-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1rem 0;border-radius:8px}.rules-article blockquote{border-left:3px solid var(--accent, #6c5ce7);padding:.75rem 1rem;margin:1.25rem 0;background:#6c5ce70d;border-radius:0 6px 6px 0;color:var(--text-secondary, #b0b0c0)}.rules-article blockquote p{margin-bottom:0}.rules-article hr{border:none;border-top:1px solid var(--border-subtle, rgba(255,255,255,.08));margin:2rem 0}.rules-article code{background:#ffffff0f;padding:.15rem .4rem;border-radius:4px;font-size:.88em;color:#e0e0e8;font-family:SF Mono,Fira Code,monospace}.page-intro{color:var(--text-secondary, #b0b0c0);font-size:1rem;line-height:1.8;margin-bottom:2rem;max-width:720px}.site-footer{margin-top:3rem;padding:2rem 0 1.5rem;border-top:1px solid var(--border-subtle, rgba(255,255,255,.08))}.site-footer-inner{max-width:900px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.site-footer-brand{display:flex;flex-direction:column;gap:.25rem}.site-footer-logo{font-size:1.1rem;font-weight:700;color:var(--text-primary, #fff);letter-spacing:-.02em}.site-footer-origin{font-size:.8rem;color:var(--text-muted, #666)}.site-footer-copyright{font-size:.75rem;color:var(--text-muted, #666);margin-top:.25rem}.site-footer-nav{display:flex;gap:3rem}.site-footer-col{display:flex;flex-direction:column;gap:.4rem}.site-footer-col h4{font-size:.75rem;font-weight:600;color:var(--text-muted, #666);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem}.site-footer-col a{font-size:.85rem;color:var(--text-secondary, #b0b0c0);text-decoration:none;transition:color .15s;cursor:pointer}.site-footer-col a:hover{color:var(--text-primary, #fff)}.card-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin:1rem 0 1.5rem}.card-type-link-emoji{font-size:1.5rem;display:block;margin-bottom:.25rem}.card-type-link-name{font-weight:600;color:var(--text-primary, #fff);display:block;font-size:.95rem}.card-type-link-desc{font-size:.8rem;color:var(--text-muted, #888);display:block;margin-top:.125rem}.rules-note{background:#ffc10714;border-left:3px solid #ffc107;padding:.75rem 1rem;border-radius:0 6px 6px 0;color:var(--text-secondary, #b0b0c0);margin:1rem 0;font-size:.9rem}.breadcrumb-nav{font-size:.85rem;color:var(--text-muted, #888);margin-bottom:1rem}.breadcrumb-nav a{color:var(--text-secondary, #b0b0c0);text-decoration:none;cursor:pointer}.breadcrumb-nav a:hover{color:var(--text-primary, #fff)}.breadcrumb-separator{margin:0 .5rem;color:var(--text-muted, #555)}@media(max-width:768px){.page-content{padding:20px 16px 60px}.page-header h1{font-size:1.5rem}.page-subtitle{font-size:.9rem}.rules-article h2{font-size:1.3rem;margin:2rem 0 .75rem}.rules-article h3{font-size:1.05rem;margin:1.5rem 0 .5rem}.rules-article p,.rules-article li{font-size:.95rem}.rules-article table{font-size:.8rem}.rules-article th,.rules-article td{padding:.5rem .625rem}.site-footer-inner{flex-direction:column;gap:1.5rem;padding:0 16px}.site-footer-nav{gap:2rem}.card-type-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.card-type-links{flex-wrap:wrap}.rules-section{margin-bottom:24px;padding-bottom:20px}}@media(max-width:480px){.page-content{padding:16px 12px 48px}.page-header h1{font-size:1.3rem}.rules-article h2{font-size:1.15rem}.rules-article h3{font-size:1rem}.rules-article p,.rules-article li{font-size:.9rem}}.related-articles{margin-top:3rem;padding:2rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-medium)}.related-articles h2{margin-top:0;margin-bottom:1.5rem;font-size:1.3rem;font-weight:600;color:var(--text-primary)}.related-articles>div{display:grid;gap:1rem}.related-articles a{display:block;padding:1rem;background:var(--bg-surface);border-radius:var(--radius-sm);text-decoration:none;color:var(--text-primary);border:1px solid var(--border-subtle);transition:all var(--duration-normal)}.related-articles a:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.related-articles a>div{display:flex;align-items:flex-start;gap:.75rem}.related-articles a span:first-child{font-size:1.2rem}.related-articles a h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-accent)}.related-articles a p{margin:0;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.article-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1rem;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-secondary);border:1px solid var(--border-subtle)}.article-meta span{display:flex;align-items:center;gap:.5rem}.article-meta strong{color:var(--text-primary);font-weight:600}.key-takeaways{margin:2rem 0;padding:1.5rem;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%);border-radius:var(--radius-md);border:2px solid var(--border-accent);box-shadow:var(--shadow-md)}.key-takeaways h3{margin-top:0;margin-bottom:1rem;font-size:1.1rem;font-weight:700;color:var(--text-accent);display:flex;align-items:center;gap:.5rem}.key-takeaways ul{margin:0;padding-left:1.5rem;list-style:none;position:relative}.key-takeaways li{margin-bottom:.75rem;padding-left:1.5rem;position:relative;line-height:1.6;color:var(--text-primary)}.key-takeaways li:before{content:"•";position:absolute;left:0;color:var(--text-accent);font-weight:600}@media(max-width:768px){.related-articles{padding:1.5rem}.related-articles h2{font-size:1.1rem}.article-meta{flex-direction:column;gap:.75rem;padding:.875rem;font-size:.85rem}.key-takeaways{padding:1.25rem}.key-takeaways h3{font-size:1rem}.people-also-ask,.quick-facts{padding:1.25rem}}.people-also-ask{margin-top:3rem;padding:2rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-medium)}.people-also-ask h2{margin-top:0;margin-bottom:1.5rem;font-size:1.3rem;font-weight:600;color:var(--text-primary)}.people-also-ask>div{display:flex;flex-direction:column;gap:1rem}.people-also-ask details{padding:1rem;background:var(--bg-surface);border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.people-also-ask summary{font-weight:600;color:var(--text-primary);cursor:pointer;list-style:none;padding:.5rem 0}.people-also-ask summary::-webkit-details-marker{display:none}.people-also-ask summary span{display:flex;align-items:center;gap:.5rem}.people-also-ask details>div{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-subtle);color:var(--text-secondary);line-height:1.6}.people-also-ask details p{margin:0 0 .5rem}.people-also-ask details a{color:var(--text-accent);text-decoration:none;font-size:.9rem;font-weight:500}.people-also-ask details a:hover{text-decoration:underline}.quick-facts{margin:2rem 0;padding:1.5rem;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%);border-radius:var(--radius-md);border:1px solid var(--border-accent)}.quick-facts h3{margin-top:0;margin-bottom:1rem;font-size:1.1rem;font-weight:700;color:var(--text-accent);display:flex;align-items:center;gap:.5rem}.quick-facts dl{margin:0;display:grid;gap:.75rem}.quick-facts dt{font-weight:600;color:var(--text-primary);font-size:.9rem}.quick-facts dd{margin:0;color:var(--text-secondary);font-size:.95rem}@media(max-width:768px){.people-also-ask{padding:1.5rem}.people-also-ask h2{font-size:1.1rem}.quick-facts{padding:1.25rem}.quick-facts h3{font-size:1rem}.site-footer-nav{flex-direction:column;gap:1.25rem}.card-type-grid{grid-template-columns:repeat(2,1fr)}}.rules-cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:1rem}.rules-cta-btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;border-radius:8px;font-weight:600;font-size:1rem;text-decoration:none;background:var(--bg-glass-light, rgba(255,255,255,.08));color:var(--text-primary, #fff);border:1px solid var(--border-subtle, rgba(255,255,255,.12));transition:background .15s,border-color .15s;cursor:pointer}.rules-cta-btn-secondary:hover{background:#ffffff1f;border-color:#fff3}.landing-feature-card-link{text-decoration:none;color:inherit;cursor:pointer;display:block;border-radius:12px;transition:transform .15s,box-shadow .15s}.landing-feature-card-link:hover{transform:translateY(-2px);box-shadow:0 4px 20px #6c5ce726}.landing-feature-card-link .landing-feature-card{height:100%}
