:root{--color-bg-primary: #08090b;--color-bg-secondary: #0c0d10;--color-bg-card: #111214;--color-bg-elevated: #161719;--color-bg-hover: #1a1b1e;--color-surface-overlay: rgba(255, 255, 255, .02);--color-surface-hover: rgba(255, 255, 255, .04);--color-surface-active: rgba(255, 255, 255, .06);--color-accent: #5eaab8;--color-accent-hover: #7cc4d0;--color-accent-muted: rgba(94, 170, 184, .12);--color-accent-border: rgba(94, 170, 184, .25);--color-accent-glow: rgba(94, 170, 184, .15);--color-accent-secondary: #7c9ebd;--color-text-primary: #f4f4f5;--color-text-secondary: #a1a1aa;--color-text-muted: #71717a;--color-text-disabled: #52525b;--color-border: rgba(255, 255, 255, .06);--color-border-light: rgba(255, 255, 255, .1);--color-success: #34d399;--color-success-bg: rgba(52, 211, 153, .1);--color-success-border: rgba(52, 211, 153, .25);--color-error: #f87171;--color-error-bg: rgba(248, 113, 113, .1);--color-error-border: rgba(248, 113, 113, .25);--color-warning: #fbbf24;--color-warning-bg: rgba(251, 191, 36, .1);--color-warning-border: rgba(251, 191, 36, .25);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", system-ui, sans-serif;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .02em;--tracking-wider: .04em;--tracking-widest: .08em;--leading-tight: 1.2;--leading-snug: 1.35;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 8px -1px rgba(0, 0, 0, .35), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 20px -3px rgba(0, 0, 0, .4), 0 4px 8px -2px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 30px -5px rgba(0, 0, 0, .45), 0 10px 15px -5px rgba(0, 0, 0, .25);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .6);--shadow-glow-sm: 0 0 15px var(--color-accent-glow);--shadow-glow: 0 0 25px var(--color-accent-glow);--shadow-glow-lg: 0 0 40px var(--color-accent-glow);--gradient-subtle: linear-gradient(180deg, rgba(255, 255, 255, .03) 0%, transparent 100%);--gradient-card: linear-gradient(180deg, rgba(255, 255, 255, .02) 0%, transparent 60%);--gradient-accent: linear-gradient(135deg, var(--color-accent), var(--color-accent-secondary));--gradient-text: linear-gradient(135deg, #fff 0%, rgba(255, 255, 255, .8) 100%);--transition-micro: .1s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-slower: .4s cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-back: cubic-bezier(.34, 1.2, .64, 1);--content-max-width: 800px;--nav-height-mobile: 64px;--nav-width-desktop: 240px;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-toast: 600;--texture-noise: 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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");--gradient-mesh-accent: radial-gradient(ellipse 80% 60% at 20% 80%, rgba(94, 170, 184, .08) 0%, transparent 50%), radial-gradient(ellipse 60% 80% at 80% 20%, rgba(124, 158, 189, .06) 0%, transparent 50%);--gradient-mesh-subtle: radial-gradient(ellipse 100% 100% at 50% 0%, rgba(255, 255, 255, .015) 0%, transparent 60%);--glass-bg: rgba(17, 18, 20, .85);--glass-border: rgba(255, 255, 255, .08);--glass-blur: 20px;--shadow-premium-sm: 0 1px 2px rgba(0, 0, 0, .3), 0 2px 4px rgba(0, 0, 0, .2), 0 0 0 1px rgba(255, 255, 255, .03) inset;--shadow-premium-md: 0 4px 8px rgba(0, 0, 0, .3), 0 8px 16px rgba(0, 0, 0, .2), 0 0 0 1px rgba(255, 255, 255, .04) inset;--shadow-premium-lg: 0 8px 16px rgba(0, 0, 0, .35), 0 16px 32px rgba(0, 0, 0, .25), 0 32px 64px rgba(0, 0, 0, .15), 0 0 0 1px rgba(255, 255, 255, .05) inset;--ease-smooth: cubic-bezier(.25, .1, .25, 1);--ease-smooth-in: cubic-bezier(.4, 0, 1, 1);--ease-smooth-out: cubic-bezier(0, 0, .2, 1);--ease-bounce-subtle: cubic-bezier(.34, 1.3, .64, 1);--ease-elastic: cubic-bezier(.68, -.55, .265, 1.55);--duration-instant: 50ms;--duration-quick: .1s;--duration-normal: .2s;--duration-slow: .35s;--duration-slower: .5s}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-weight:var(--font-weight-normal);line-height:1.5;color:var(--color-text-secondary);background-color:var(--color-bg-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);line-height:1.25}h1{font-size:1.75rem}h2{font-size:1.375rem}h3{font-size:1.125rem}@media(min-width:640px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}p{margin:0}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}button:disabled{cursor:not-allowed;opacity:.5}input,textarea,select{font-family:inherit;font-size:16px}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}::selection{background:var(--color-accent-muted);color:var(--color-text-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--color-border-light) var(--color-bg-secondary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.focus-trap{position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes exit-depth{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(8px) scale(.98)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes glow-pulse{0%,to{box-shadow:var(--shadow-glow-sm)}50%{box-shadow:var(--shadow-glow)}}@keyframes scale-subtle{0%{opacity:0;transform:scale(.98) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}@keyframes border-glow{0%,to{border-color:var(--color-accent-border)}50%{border-color:var(--color-accent)}}@keyframes shimmer-premium{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float-premium{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes scale-elastic{0%{transform:scale(1)}50%{transform:scale(.97)}to{transform:scale(1)}}@keyframes pulse-glow-premium{0%,to{box-shadow:0 0 #5eaab866}50%{box-shadow:0 0 0 8px #5eaab800}}@keyframes focus-ring-expand{0%{box-shadow:0 0 0 0 var(--color-accent-muted)}to{box-shadow:0 0 0 4px var(--color-accent-muted)}}@keyframes entrance-depth{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slide-up-stagger{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes success-pulse{0%{transform:scale(1);box-shadow:0 0 #34d39966}50%{transform:scale(1.02);box-shadow:0 0 0 12px #34d39900}to{transform:scale(1);box-shadow:0 0 #34d39900}}@keyframes shake-gentle{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@supports (padding: max(0px)){body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}.auth-modal-overlay{position:fixed;inset:0;background-color:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal-backdrop);animation:fadeIn .25s var(--ease-smooth-out)}.auth-modal-overlay.closing{animation:fadeOut .2s var(--ease-smooth-out) forwards}.auth-modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:400px;position:relative;box-shadow:var(--shadow-premium-lg);animation:entrance-depth .3s var(--ease-smooth-out)}.auth-modal.closing{animation:exit-depth .2s var(--ease-smooth-out) forwards}.auth-modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.5rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.auth-modal-close:hover{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.auth-modal h2{margin:0 0 var(--space-6) 0;color:var(--color-text-primary);font-size:1.5rem;font-weight:var(--font-weight-semibold);padding-right:var(--space-8)}.auth-discord-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;padding:var(--space-3);background:#5865f2;border:none;border-radius:var(--radius-md);color:#fff;font-size:1rem;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background var(--duration-normal) var(--ease-smooth),transform var(--duration-quick) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth);min-height:48px;box-shadow:var(--shadow-premium-sm)}.auth-discord-btn:hover:not(:disabled){background:#4752c4;transform:translateY(-2px);box-shadow:var(--shadow-premium-md),0 0 24px #5865f240}.auth-discord-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.auth-discord-btn:disabled{opacity:.6;cursor:not-allowed}.auth-discord-btn .discord-icon{width:20px;height:20px}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-5) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{color:var(--color-text-muted);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{color:var(--color-text-secondary);font-weight:var(--font-weight-semibold);font-size:.875rem}.form-group input{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);color:var(--color-text-primary);font-size:16px;transition:all var(--transition-base)}.form-group input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-muted)}.form-group input::placeholder{color:var(--color-text-disabled)}.form-group small{color:var(--color-text-muted);font-size:.8125rem}.auth-error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error);padding:var(--space-3);border-radius:var(--radius-md);font-size:.875rem}.auth-success{background:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-success);padding:var(--space-3);border-radius:var(--radius-md);font-size:.875rem}.auth-submit-btn{background:var(--color-accent);border:none;color:var(--color-bg-primary);padding:var(--space-3);border-radius:var(--radius-md);font-size:1rem;font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-2);min-height:48px}.auth-submit-btn:hover:not(:disabled){background:var(--color-accent-hover)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-switch{margin-top:var(--space-5);text-align:center;padding-top:var(--space-5);border-top:1px solid var(--color-border)}.auth-switch p{color:var(--color-text-muted);margin:0;font-size:.875rem}.auth-switch button{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:.875rem;padding:0;text-decoration:underline;transition:color var(--transition-fast)}.auth-switch button:hover{color:var(--color-accent-hover)}@media(min-width:640px){.auth-modal{padding:var(--space-8)}.auth-modal h2{font-size:1.75rem}}@media(max-width:480px){.auth-modal-overlay{align-items:flex-start;padding-top:var(--space-10)}.auth-modal{padding:var(--space-5)}.auth-modal h2{font-size:1.25rem;margin-bottom:var(--space-5)}.auth-form{gap:var(--space-3)}.auth-switch{margin-top:var(--space-4);padding-top:var(--space-4)}}.settings-overlay{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4);animation:fadeIn .25s var(--ease-smooth-out)}.settings-overlay.closing{animation:fadeOut .2s var(--ease-smooth-out) forwards}.settings-modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-2xl);width:100%;max-width:420px;animation:entrance-depth .3s var(--ease-smooth-out);box-shadow:var(--shadow-premium-lg)}.settings-modal.closing{animation:exit-depth .2s var(--ease-smooth-out) forwards}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-border)}.settings-header h2{font-size:1.125rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;letter-spacing:var(--tracking-tight)}.settings-header .close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-text-muted);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-quick) var(--ease-smooth),color var(--duration-quick) var(--ease-smooth),transform var(--duration-quick) var(--ease-smooth)}.settings-header .close-btn:hover{color:var(--color-text-primary);background:var(--color-surface-hover);transform:scale(1.05)}.settings-header .close-btn:active{transform:scale(.95)}.settings-content{padding:24px;display:flex;flex-direction:column;gap:20px}.setting-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:14px 16px;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.setting-item:hover{background:var(--color-surface-hover);border-color:var(--color-border-light)}.setting-info{display:flex;flex-direction:column;gap:4px}.setting-label{font-size:.9375rem;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.setting-desc{font-size:.8125rem;color:var(--color-text-muted);line-height:var(--leading-normal)}.toggle-btn{position:relative;width:52px;height:28px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:14px;cursor:pointer;transition:background var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth);flex-shrink:0}.toggle-btn:hover{border-color:var(--color-border-light)}.toggle-btn:active .toggle-slider{transform:scale(1.15)}.toggle-btn.active{background:var(--gradient-accent);border-color:transparent;box-shadow:var(--shadow-glow)}.toggle-slider{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--color-text-muted);border-radius:50%;transition:left .3s var(--ease-bounce-subtle),transform .15s var(--ease-smooth),background .2s var(--ease-smooth);box-shadow:var(--shadow-premium-sm)}.toggle-btn.active .toggle-slider{left:27px;background:#fff}.settings-footer{padding:16px 24px;border-top:1px solid var(--color-border);text-align:center}.version{font-size:.75rem;color:var(--color-text-disabled);letter-spacing:var(--tracking-wide)}@media(max-width:360px){.settings-modal{border-radius:var(--radius-xl)}.settings-header,.settings-content,.settings-footer{padding:16px 18px}.setting-item{padding:12px 14px}}.layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background-color:var(--color-bg-primary)}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#0c0d10d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:var(--z-sticky)}.header-left{display:flex;align-items:center;gap:var(--space-3)}.logo{font-size:1.125rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--tracking-widest);background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{display:none}.header-right{display:flex;align-items:center;gap:var(--space-3)}.score-widget{display:flex;align-items:center;gap:var(--space-2);padding:8px 12px;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md);position:relative;transition:all var(--transition-base)}.score-widget.clickable{cursor:pointer}.score-widget.clickable:hover{background:var(--color-surface-hover);border-color:var(--color-accent-border);box-shadow:var(--shadow-glow-sm)}.score-widget.copied{background:var(--color-accent-muted);border-color:var(--color-accent-border)}.score-widget.animating{animation:scoreFlash .3s var(--ease-out-expo)}.score-content{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}.score-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-medium)}.score-value{font-size:.9375rem;font-weight:var(--font-weight-semibold);color:var(--color-accent);font-variant-numeric:tabular-nums}.score-widget.animating .score-value{animation:scoreGlow .8s var(--ease-out-expo)}.score-max{font-size:10px;color:var(--color-text-disabled);font-variant-numeric:tabular-nums}.share-hint{font-size:9px;color:var(--color-accent);margin-top:2px;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide);animation:pulse 2.5s ease-in-out infinite}.copied-message{font-size:10px;color:var(--color-accent);font-weight:var(--font-weight-semibold);animation:fadeIn .2s var(--ease-out-expo)}.score-widget.just-celebrated{animation:celebrateAttention 1.2s ease-out forwards}.score-widget.just-celebrated .share-hint{animation:shareHintPop .8s ease-out .3s forwards;opacity:0}@keyframes celebrateAttention{0%{transform:scale(1);box-shadow:var(--shadow-sm);border-color:var(--color-border)}20%{transform:scale(1.08);box-shadow:0 0 24px var(--color-accent-glow),var(--shadow-glow);border-color:var(--color-accent);background:var(--color-accent-muted)}40%{transform:scale(.98)}60%{transform:scale(1.03)}to{transform:scale(1);box-shadow:var(--shadow-glow-sm);border-color:var(--color-accent-border);background:var(--color-accent-muted)}}@keyframes shareHintPop{0%{opacity:0;transform:translateY(4px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.score-popup{position:absolute;top:-10px;right:var(--space-2);font-size:.875rem;font-weight:var(--font-weight-bold);color:var(--color-success);text-shadow:0 0 12px var(--color-success);animation:scorePopup 1.5s var(--ease-out-expo) forwards;pointer-events:none}@keyframes scoreFlash{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes scoreGlow{0%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 16px var(--color-accent)}to{text-shadow:0 0 0 transparent}}@keyframes scorePopup{0%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0;transform:translateY(-24px)}}.login-btn{padding:8px 16px;background:var(--gradient-accent);color:var(--color-bg-primary);font-size:.8125rem;font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-wide);border-radius:var(--radius-md);transition:all var(--transition-base);box-shadow:var(--shadow-sm),var(--shadow-glow-sm)}.login-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.login-btn:active{transform:translateY(0)}.user-info{display:flex;align-items:center;gap:var(--space-2)}.user-username-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:none;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.user-username-btn:hover{background:var(--color-accent-muted);border-color:var(--color-accent-border)}.user-username-btn:hover .username-arrow{opacity:1;transform:translate(2px)}.user-username{font-size:.8125rem;font-weight:var(--font-weight-semibold);color:var(--color-accent)}.username-arrow{font-size:1rem;color:var(--color-accent);opacity:.4;transition:all var(--transition-fast);font-weight:300}.logout-btn{padding:6px 10px;font-size:.75rem;color:var(--color-text-muted);background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-base);font-weight:var(--font-weight-medium)}.logout-btn:hover{background:var(--color-surface-hover);color:var(--color-text-secondary);border-color:var(--color-border-light)}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--nav-height-mobile) + env(safe-area-inset-bottom,0px))}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:stretch;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-top:1px solid var(--glass-border);padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom,0px));z-index:var(--z-fixed);box-shadow:0 -1px #ffffff08 inset}.bottom-nav .nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:10px 4px;color:var(--color-text-muted);text-decoration:none;transition:color var(--duration-quick) var(--ease-smooth),transform var(--duration-instant) var(--ease-smooth);position:relative;min-height:54px;background:transparent;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.bottom-nav .nav-item:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%) scaleX(0);width:24px;height:3px;background:var(--gradient-accent);border-radius:3px;transition:transform var(--duration-normal) var(--ease-bounce-subtle);box-shadow:0 0 8px var(--color-accent-glow)}.bottom-nav .nav-item:active{transform:scale(.92);opacity:.85}.bottom-nav .nav-item.active{color:var(--color-accent)}.bottom-nav .nav-item.active:after{transform:translate(-50%) scaleX(1)}.bottom-nav .nav-icon{width:22px;height:22px;stroke-width:1.75;transition:transform var(--duration-quick) var(--ease-smooth),stroke-width var(--duration-quick) var(--ease-smooth)}.bottom-nav .nav-item.active .nav-icon{stroke-width:2.25;transform:scale(1.05)}.bottom-nav .nav-label{font-size:10px;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide);transition:opacity var(--duration-quick) var(--ease-smooth)}.bottom-nav .nav-item.active .nav-label{font-weight:var(--font-weight-semibold)}.footer-links,.sidebar{display:none}@media(min-width:640px){.mobile-header{padding:14px 24px}.logo{font-size:1.25rem}.score-widget{padding:10px 16px}.score-value{font-size:1rem}.bottom-nav .nav-label{font-size:11px}}@media(min-width:1024px){.layout{flex-direction:row}.mobile-header,.bottom-nav{display:none}.sidebar{display:flex;flex-direction:column;width:var(--nav-width-desktop);height:100vh;height:100dvh;position:fixed;left:0;top:0;background:linear-gradient(180deg,var(--color-bg-secondary) 0%,var(--color-bg-primary) 100%);background-image:var(--gradient-mesh-accent),linear-gradient(180deg,var(--color-bg-secondary) 0%,var(--color-bg-primary) 100%);border-right:1px solid var(--color-border);z-index:var(--z-fixed);overflow-y:auto;box-shadow:1px 0 #ffffff05 inset}.sidebar-header{padding:28px 24px 24px;border-bottom:1px solid var(--color-border)}.sidebar .logo{font-size:1.375rem;margin-bottom:var(--space-2);display:block;-webkit-text-fill-color:initial;background:none;color:var(--color-text-primary);letter-spacing:var(--tracking-widest)}.sidebar .tagline{display:block;font-size:.75rem;color:var(--color-text-muted);line-height:var(--leading-relaxed);letter-spacing:var(--tracking-wide)}.nav-menu{flex:1;display:flex;flex-direction:column;padding:16px 12px;gap:4px}.nav-menu .nav-item{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:var(--space-3);padding:12px 16px;margin:0;border-radius:var(--radius-md);color:var(--color-text-muted);background:transparent;border:none;cursor:pointer;transition:background var(--duration-normal) var(--ease-smooth),color var(--duration-quick) var(--ease-smooth),transform var(--duration-quick) var(--ease-smooth);position:relative;min-height:auto}.nav-menu .nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--gradient-accent);border-radius:3px;transition:height var(--duration-normal) var(--ease-bounce-subtle);box-shadow:0 0 8px var(--color-accent-glow)}.nav-menu .nav-item:hover{background:var(--color-surface-hover);color:var(--color-text-secondary);transform:translate(3px)}.nav-menu .nav-item.active{background:var(--color-surface-active);color:var(--color-accent)}.nav-menu .nav-item.active:before{height:55%}.nav-menu .nav-icon{width:20px;height:20px;stroke-width:1.75;flex-shrink:0;transition:all var(--transition-fast)}.nav-menu .nav-item:hover .nav-icon{transform:scale(1.05)}.nav-menu .nav-item.active .nav-icon{stroke-width:2}.nav-menu .nav-label{font-size:.875rem;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-normal)}.sidebar-footer{padding:20px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:16px}.sidebar .user-info{flex-direction:column;align-items:stretch;gap:10px;padding:14px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.sidebar .user-username-btn{justify-content:center;padding:8px 12px;width:100%}.sidebar .user-username{text-align:center}.sidebar .logout-btn{width:100%;padding:8px 12px;text-align:center}.sidebar .login-btn{width:100%;padding:12px 16px;text-align:center}.sidebar .score-widget{flex-direction:column;align-items:center;padding:18px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.sidebar .score-widget.clickable:hover{border-color:var(--color-accent-border);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.sidebar .score-content{align-items:center}.sidebar .score-label{font-size:11px;margin-bottom:4px}.sidebar .score-value{font-size:1.625rem;font-weight:var(--font-weight-bold)}.sidebar .score-max{font-size:12px;margin-top:2px}.footer-links{display:flex;justify-content:center;gap:var(--space-5)}.footer-link{font-size:.8125rem;color:var(--color-text-muted);background:none;border:none;cursor:pointer;padding:4px 0;transition:color var(--transition-base);font-weight:var(--font-weight-medium)}.footer-link:hover{color:var(--color-accent)}.main-content{margin-left:var(--nav-width-desktop);padding-bottom:0;height:100vh;height:100dvh}}@media(min-width:1440px){:root{--nav-width-desktop: 280px}.sidebar-header{padding:32px 28px 28px}.nav-menu{padding:20px 16px;gap:6px}.nav-menu .nav-item{padding:14px 18px}.sidebar .score-value{font-size:1.875rem}}@media(max-width:360px){.mobile-header{padding:10px 12px}.logo{font-size:1rem}.score-widget{padding:6px 10px}.score-value{font-size:.875rem}.bottom-nav .nav-icon{width:20px;height:20px}.bottom-nav .nav-label{font-size:9px}}.home{max-width:var(--content-max-width);margin:0 auto;padding:var(--space-3) var(--space-4) var(--space-2);display:flex;flex-direction:column;animation:entrance-depth .4s var(--ease-smooth-out)}.home-hero{text-align:center;margin-bottom:var(--space-2);padding-top:0}.home-date{font-size:.6875rem;color:var(--color-text-muted);margin-bottom:var(--space-1);letter-spacing:var(--tracking-wider);font-weight:var(--font-weight-medium);text-transform:uppercase}.home-title,.home-tagline{display:none}.home-title{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-tagline{font-size:.875rem;color:var(--color-text-muted);letter-spacing:var(--tracking-wide);font-weight:var(--font-weight-normal)}.progress-section{margin-bottom:var(--space-3);animation:slideUp .5s var(--ease-out-expo) .1s both}.progress-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.progress-label{font-size:.8125rem;color:var(--color-text-muted);font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide)}.progress-score{font-size:.875rem;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.progress-bar{height:5px;background:var(--color-bg-elevated);border-radius:var(--radius-full);overflow:visible;position:relative}.progress-fill{height:100%;background:var(--gradient-accent);border-radius:var(--radius-full);transition:width .6s var(--ease-smooth-out);position:relative;box-shadow:0 0 20px var(--color-accent-glow)}.progress-fill:after{content:"";position:absolute;right:-4px;top:50%;transform:translateY(-50%);width:11px;height:11px;background:#fff;border-radius:50%;box-shadow:0 0 12px var(--color-accent),0 0 24px var(--color-accent-glow);opacity:0;transition:opacity .3s var(--ease-smooth-out);animation:pulse-glow-premium 2s infinite var(--ease-smooth)}.progress-fill:not([style*="width: 0%"]):after{opacity:1}.game-modes{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-2)}.game-card{position:relative;display:flex;flex-direction:column;gap:var(--space-2);padding:14px 16px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth);text-align:left;width:100%;overflow:hidden;animation:slide-up-stagger .5s var(--ease-smooth-out) both;-webkit-tap-highlight-color:transparent}.game-card:nth-child(1){animation-delay:.1s}.game-card:nth-child(2){animation-delay:.18s}.game-card:nth-child(3){animation-delay:.26s}.game-card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);padding:1px;background:linear-gradient(135deg,transparent 20%,rgba(255,255,255,.1) 50%,transparent 80%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth);pointer-events:none}.game-card:hover{transform:translateY(-4px);border-color:var(--color-border-light);box-shadow:var(--shadow-premium-lg)}.game-card:hover:before{opacity:1}.game-card:active{transform:translateY(-2px) scale(.99)}.game-card.completed{border-color:var(--color-border-light)}.game-card.completed:hover{border-color:var(--color-text-muted)}.game-card-content{flex:1;min-width:0}.game-name{font-size:1.125rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:6px;letter-spacing:var(--tracking-tight)}.game-description{font-size:.8125rem;color:var(--color-text-muted);line-height:var(--leading-snug);display:-webkit-box;line-clamp:1;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.game-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--color-border)}.game-points{font-size:.8125rem;color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-weight:var(--font-weight-medium)}.game-complete-badge{display:flex;align-items:center;gap:4px;font-size:.6875rem;color:var(--color-success);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.08em;margin-left:auto}.game-complete-badge:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:10px;font-weight:700;background:linear-gradient(135deg,var(--color-success),rgba(52,211,153,.7));color:#0a0f14;border-radius:50%}.home-footer{text-align:center;padding-top:var(--space-2);display:flex;flex-direction:column;align-items:center;gap:4px;animation:fadeIn .6s var(--ease-out-expo) .5s both}.countdown-label{font-size:.75rem;color:var(--color-text-disabled);letter-spacing:var(--tracking-wider);text-transform:uppercase;font-weight:var(--font-weight-medium)}.countdown-timer{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);font-variant-numeric:tabular-nums;letter-spacing:.12em}@media(min-width:640px){.home{padding:var(--space-10) var(--space-6)}.home-hero{padding-top:var(--space-6);margin-bottom:var(--space-12)}.home-title{font-size:3.25rem}.home-tagline{font-size:1.125rem}.game-card{flex-direction:row;align-items:center;padding:24px 28px}.game-card-footer{flex-direction:column;align-items:flex-end;gap:8px;padding-top:0;border-top:none;flex-shrink:0;margin-left:var(--space-4)}.game-name{font-size:1.1875rem}.game-description{font-size:.9375rem}.countdown-timer{font-size:1.75rem}}@media(min-width:1024px){.home{padding:var(--space-12) var(--space-6)}.home-hero{margin-bottom:var(--space-12)}.home-title,.home-tagline{display:block}.home-title{font-size:3.5rem;margin-bottom:var(--space-3)}.progress-section{margin-bottom:var(--space-12)}.game-modes{gap:18px}.game-card{padding:26px 32px}.countdown-timer{font-size:2rem}}@media(max-width:360px){.home{padding:var(--space-4) var(--space-3)}.home-title{font-size:2rem}.home-tagline{font-size:.9375rem}.game-card{padding:16px 18px;border-radius:var(--radius-lg)}.game-name{font-size:1rem}.game-description{font-size:.8125rem;-webkit-line-clamp:3;line-clamp:3}.game-points{font-size:.75rem}.game-complete-badge{font-size:.625rem}.game-complete-badge:before{width:14px;height:14px;font-size:9px}.countdown-timer{font-size:1.25rem}}.about-page{padding:var(--space-6) var(--space-4);max-width:720px;margin:0 auto;animation:scale-subtle .4s var(--ease-out-expo)}.about-container{display:flex;flex-direction:column;gap:var(--space-10)}.about-header{text-align:center;padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border)}.about-header h1{font-size:1.875rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-3);letter-spacing:var(--tracking-tight)}.about-tagline{font-size:1.0625rem;color:var(--color-text-muted);letter-spacing:var(--tracking-wide)}.about-section h2{font-size:1.1875rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-5);letter-spacing:var(--tracking-tight)}.about-section p{font-size:.9375rem;color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.about-section p:last-child{margin-bottom:0}.about-section a{color:var(--color-accent);text-decoration:none;transition:opacity var(--transition-fast);font-weight:var(--font-weight-medium)}.about-section a:hover{opacity:.75}.about-game-modes{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.mode-card{background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-base)}.mode-card:hover{border-color:var(--color-border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.mode-icon{font-size:1.625rem;margin-bottom:var(--space-3);display:block}.mode-card h3{font-size:1rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:var(--tracking-tight)}.mode-card p{font-size:.875rem;color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}.attribution-card{background:linear-gradient(135deg,var(--color-accent-muted),rgba(94,170,184,.04));border:1px solid var(--color-accent-border);border-radius:var(--radius-lg);padding:22px}.attribution-card p{font-size:.9375rem;margin-bottom:var(--space-4)}.attribution-note{font-size:.8125rem;color:var(--color-text-muted);font-style:italic;margin-bottom:0}.info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.info-list li{font-size:.9375rem;color:var(--color-text-secondary);padding-left:var(--space-5);position:relative;line-height:var(--leading-relaxed)}.info-list li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--color-accent);border-radius:50%}.about-footer{text-align:center;padding-top:var(--space-8);border-top:1px solid var(--color-border)}.about-footer p{font-size:.9375rem;color:var(--color-text-muted);margin-bottom:var(--space-3)}.copyright{font-size:.8125rem;color:var(--color-text-disabled);letter-spacing:var(--tracking-wide)}.support-coffee-link{display:inline-flex;align-items:center;justify-content:center;margin:var(--space-3) 0;padding:8px;border-radius:var(--radius-md);transition:all var(--transition-fast);opacity:.5}.support-coffee-link:hover{opacity:1;background:var(--color-surface-hover)}.support-coffee-link svg{width:20px;height:20px;stroke:var(--color-text-muted);transition:stroke var(--transition-fast)}.support-coffee-link:hover svg{stroke:var(--color-accent)}@media(min-width:640px){.about-page{padding:var(--space-10) var(--space-6)}.about-header h1{font-size:2.25rem}.about-game-modes{grid-template-columns:repeat(3,1fr)}.mode-card{text-align:center;padding:24px}}@media(min-width:1024px){.about-page{padding:var(--space-12) var(--space-6)}}@media(max-width:360px){.about-page{padding:var(--space-4) var(--space-3)}.about-header h1{font-size:1.5rem}.mode-card{padding:16px}}.search-container{position:relative;width:100%;max-width:520px;margin:0 auto}.search-input{width:100%;padding:14px 18px;font-size:16px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);color:var(--color-text-primary);outline:none;transition:border-color var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth);font-weight:var(--font-weight-normal);-webkit-tap-highlight-color:transparent}.search-input:focus{border-color:var(--color-accent);background:var(--color-bg-elevated);box-shadow:0 0 0 4px var(--color-accent-muted),var(--shadow-premium-md);animation:focus-ring-expand .2s var(--ease-smooth)}.search-input:disabled{opacity:.5;cursor:not-allowed}.search-input::placeholder{color:var(--color-text-disabled);font-weight:var(--font-weight-normal);transition:color var(--duration-quick) var(--ease-smooth)}.search-input:focus::placeholder{color:var(--color-text-muted)}.search-results{position:absolute;top:calc(100% + 10px);left:0;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-height:340px;overflow-y:auto;z-index:var(--z-dropdown);box-shadow:var(--shadow-premium-lg);animation:entrance-depth .25s var(--ease-smooth-out);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.search-loading,.search-empty{padding:20px;text-align:center;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:.9375rem}.search-loading-overlay{position:absolute;top:8px;right:8px;z-index:10;background:var(--color-bg-card);border-radius:50%;padding:4px;box-shadow:var(--shadow-premium-sm)}.search-results-list{list-style:none;padding:6px;margin:0}.search-result-item{display:flex;align-items:center;gap:var(--space-3);padding:12px 14px;cursor:pointer;transition:background var(--duration-quick) var(--ease-smooth),transform var(--duration-quick) var(--ease-smooth);border-radius:var(--radius-md);margin-bottom:2px}.search-result-item:last-child{margin-bottom:0}.search-result-item:hover,.search-result-item.selected{background:var(--color-surface-hover);transform:translate(4px)}.search-result-item.selected .search-result-title{color:var(--color-accent)}.search-result-item:active{background:var(--color-surface-active);transform:translate(2px) scale(.99)}.search-result-image{width:44px;height:62px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;border:1px solid var(--color-border);background:var(--color-bg-elevated)}.search-result-info{flex:1;min-width:0}.search-result-title{font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;font-size:.9375rem}.search-result-meta{font-size:.8125rem;color:var(--color-text-muted);display:flex;align-items:center;gap:var(--space-2)}.separator{color:var(--color-text-disabled);font-size:.625rem}.spinner-small{width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@media(min-width:640px){.search-container{max-width:560px}.search-input{padding:16px 20px;font-size:1rem;border-radius:var(--radius-xl)}.search-results{max-height:400px;border-radius:var(--radius-xl);top:calc(100% + 10px)}.search-results-list{padding:8px}.search-result-item{padding:14px 16px}.search-result-image{width:50px;height:70px}}@media(min-width:1024px){.search-results{max-height:440px}}@media(max-width:360px){.search-input{padding:12px 14px;font-size:16px;border-radius:var(--radius-md)}.search-results{max-height:280px;border-radius:var(--radius-md);top:calc(100% + 6px)}.search-results-list{padding:4px}.search-result-item{padding:10px 12px;gap:var(--space-2)}.search-result-image{width:36px;height:50px}.search-result-title{font-size:.875rem}.search-result-meta{font-size:.75rem}.search-loading,.search-empty{padding:16px;font-size:.8125rem}}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:12px 20px;border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide);cursor:pointer;transition:transform var(--duration-quick) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth);min-height:44px;text-decoration:none;white-space:nowrap;overflow:hidden;-webkit-tap-highlight-color:transparent}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 40%);opacity:0;transition:opacity var(--duration-quick) var(--ease-smooth);pointer-events:none;border-radius:inherit}.btn:hover:before{opacity:1}.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-bg-primary),0 0 0 4px var(--color-accent)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn:disabled:before{display:none}.btn-primary{background:var(--gradient-accent);color:var(--color-bg-primary);box-shadow:var(--shadow-premium-sm),var(--shadow-glow-sm)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-premium-md),var(--shadow-glow)}.btn-primary:active:not(:disabled){transform:translateY(0) scale(.98);box-shadow:var(--shadow-xs),var(--shadow-glow-sm)}.btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border-light)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-light);color:var(--color-text-primary)}.btn-secondary:active:not(:disabled){background:var(--color-surface-active)}.btn-success{background:linear-gradient(135deg,var(--color-success),#22a06b);color:var(--color-bg-primary);box-shadow:var(--shadow-premium-sm)}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-premium-md),0 0 24px #34d39940}.btn-success:active:not(:disabled){transform:translateY(0) scale(.98)}.btn-success.success-animate{animation:success-pulse .6s var(--ease-smooth)}.btn-danger{background:linear-gradient(135deg,var(--color-error),#dc2626);color:#fff;box-shadow:var(--shadow-premium-sm)}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-premium-md),0 0 24px #f8717140}.btn-danger:active:not(:disabled){transform:translateY(0) scale(.98)}.btn-danger.error-animate{animation:shake-gentle .4s var(--ease-smooth)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text-primary)}.btn-ghost:active:not(:disabled){background:var(--color-surface-active)}.btn-sm{padding:8px 14px;font-size:.8125rem;min-height:36px;border-radius:var(--radius-sm)}.btn-lg{padding:16px 28px;font-size:1rem;min-height:52px;border-radius:var(--radius-lg)}.btn-block{width:100%}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10);gap:var(--space-5)}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:22px;height:22px;border-width:2px}.spinner-medium{width:44px;height:44px;border-width:3px}.spinner-large{width:60px;height:60px;border-width:4px}.loading-message{color:var(--color-text-muted);font-size:.9375rem;margin:0;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide)}.vndle-game{max-width:var(--content-max-width);margin:0 auto;padding:var(--space-4);padding-bottom:calc(var(--space-8) + var(--nav-height-mobile) + env(safe-area-inset-bottom,0px));min-height:100%;animation:entrance-depth .4s var(--ease-smooth-out)}.game-header{text-align:center;margin-bottom:var(--space-8)}.game-header h1{font-size:1.625rem;color:var(--color-text-primary);margin-bottom:var(--space-5);letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-bold)}.game-stats{display:flex;justify-content:center;gap:var(--space-8)}.stat{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-medium)}.stat-value{font-size:1.375rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.search-section{margin:var(--space-6) 0;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.next-clue-hint{color:var(--color-text-muted);font-size:.8125rem;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide)}.skip-clue-btn{margin-top:var(--space-2)}.constraints-panel{width:100%;max-width:400px;margin:var(--space-3) auto 0;animation:fadeSlideUp .3s var(--ease-smooth-out)}.constraints-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.constraints-toggle:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.constraints-count{font-size:.875rem;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);font-variant-numeric:tabular-nums}.constraints-toggle-icon{font-size:.625rem;color:var(--color-text-muted)}.constraints-summary{margin-top:var(--space-2);padding:var(--space-3);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);animation:fadeSlideUp .2s var(--ease-smooth-out)}.constraints-title{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-widest);margin-bottom:var(--space-2);font-weight:var(--font-weight-medium)}.constraint-item{display:flex;align-items:baseline;gap:var(--space-2);padding:var(--space-1) 0;font-size:.8125rem}.constraint-item:not(:last-child){border-bottom:1px solid var(--color-border)}.constraint-label{color:var(--color-text-muted);font-weight:var(--font-weight-medium);flex-shrink:0}.constraint-value{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.constraint-value.constraint-match{color:var(--color-success)}.constraint-value.constraint-exclude{color:var(--color-text-muted);font-style:italic}.constraint-none{color:var(--color-text-disabled);font-style:italic;justify-content:center}.constraint-tags-section{flex-direction:column;align-items:flex-start}.constraint-tags-list{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.constraint-tags-inline{color:var(--color-text-primary)}.constraint-view-all{background:transparent;border:none;color:var(--color-link, #60a5fa);font-size:inherit;cursor:pointer;text-decoration:none;padding:0;transition:color var(--transition-fast)}.constraint-view-all:hover{color:var(--color-link-hover, #93c5fd)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.clues-section{margin:var(--space-6) 0;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:24px;min-height:480px;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.clues-title{margin:0 0 var(--space-6) 0;color:var(--color-text-primary);font-size:1.25rem;text-align:center;font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-tight)}.clues-container{display:flex;flex-direction:column;gap:var(--space-6)}.clue-item{display:flex;flex-direction:column;align-items:center}.clue-image{width:100%;max-width:200px;height:auto;border-radius:var(--radius-lg);transition:filter .8s var(--ease-smooth),transform .4s var(--ease-smooth);opacity:1;border:1px solid var(--color-border);box-shadow:var(--shadow-premium-sm)}.clue-image.blurred{filter:blur(10px) saturate(.85)}.clue-image.revealed{filter:none;animation:entrance-depth .6s var(--ease-smooth-out)}.clue-text-container{display:flex;flex-direction:column;gap:var(--space-6);width:100%}.clue-info h3,.clue-locked h3{margin:0 0 var(--space-3) 0;color:var(--color-text-primary);font-size:1rem;font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-tight)}.vndb-title-link{color:var(--color-accent);text-decoration:none;transition:opacity var(--transition-fast);cursor:pointer}.vndb-title-link:hover{opacity:.75}.clue-synopsis{color:var(--color-text-secondary);line-height:var(--leading-relaxed);font-size:.9375rem;max-height:200px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:8;line-clamp:8;-webkit-box-orient:vertical}.vndle-game .character-image{width:120px;height:auto;border-radius:var(--radius-lg);margin-bottom:var(--space-3);object-fit:cover;border:1px solid var(--color-border)}.character-name{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.locked-text{color:var(--color-text-disabled);font-style:italic;font-size:.875rem}.guesses-section{margin:var(--space-8) 0;animation:slideUp .5s var(--ease-out-expo) .2s both}.guesses-section h2{margin:0 0 var(--space-5) 0;color:var(--color-text-primary);font-size:1.125rem;font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-tight)}.comparison-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-4));padding:0 var(--space-4)}.comparison-table{width:100%;min-width:620px;border-collapse:collapse;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-premium-sm)}.comparison-table th{background:var(--color-surface-overlay);color:var(--color-text-muted);padding:14px 12px;text-align:left;font-weight:var(--font-weight-medium);font-size:11px;text-transform:uppercase;letter-spacing:var(--tracking-widest);white-space:nowrap;border-bottom:1px solid var(--color-border)}.comparison-table td{padding:14px 12px;color:var(--color-text-primary);font-size:.8125rem;border-bottom:1px solid var(--color-border);vertical-align:middle;transition:background var(--duration-quick) var(--ease-smooth)}.comparison-table tbody tr:last-child td{border-bottom:none}.comparison-table tbody tr{transition:background var(--duration-quick) var(--ease-smooth)}.comparison-table tbody tr:hover{background:var(--color-surface-hover)}.comparison-table tbody tr:hover td{background:transparent}.comparison-table td.match-exact{color:var(--color-success)}.comparison-table td.match-partial{color:var(--color-warning)}.comparison-table td.match-none,.comparison-table td.match-higher,.comparison-table td.match-lower{color:var(--color-text-secondary)}.tags-cell{max-width:260px}.tags-list{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--space-2)}.tag{display:inline-block;padding:3px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:var(--font-weight-medium)}.tag-match{background:linear-gradient(135deg,var(--color-success),#22a06b);color:var(--color-bg-primary)}.tag-no-match{background:var(--color-surface-active);color:var(--color-text-muted)}.tag-spoiler{cursor:help}.tag-actions{display:flex;align-items:center;margin-top:var(--space-2)}.tag-count{font-size:11px;color:var(--color-text-muted);font-weight:var(--font-weight-medium);display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;transition:color var(--transition-fast)}.tag-count:hover{color:var(--color-text-secondary)}.tag-view-all-link{color:var(--color-accent);font-weight:var(--font-weight-medium);white-space:nowrap}.tag-view-all-link:before{content:"·";margin-right:var(--space-2);color:var(--color-text-disabled)}.game-over-message{color:var(--color-text-secondary);font-size:.9375rem;margin:var(--space-2) 0}.final-score{font-size:1.25rem;font-weight:var(--font-weight-bold);margin:var(--space-5) 0;color:var(--color-accent)}.final-score.won{color:var(--color-accent)}.final-score.lost{color:var(--color-error)}.play-again-container{display:flex;flex-direction:column;gap:var(--space-3);align-items:flex-start;margin-top:var(--space-5)}.character-info-small{color:var(--color-text-secondary);font-size:.875rem}.character-label{color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.character-info-small .character-name{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.error-state{text-align:center;padding:var(--space-12)}.error-state h2{color:var(--color-error);margin:0 0 var(--space-3) 0;font-weight:var(--font-weight-semibold)}.error-state p{color:var(--color-text-secondary);margin:0 0 var(--space-6) 0}.modal-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4);animation:fadeIn .2s var(--ease-out-expo)}.modal-overlay.closing{animation:fadeOut .2s var(--ease-smooth-out) forwards}.modal-content{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-2xl);max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-2xl);animation:scale-subtle .25s var(--ease-out-expo)}.modal-content.closing{animation:exit-depth .2s var(--ease-smooth-out) forwards}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-bg-card);z-index:1}.modal-header h3{margin:0;color:var(--color-text-primary);font-size:1.0625rem;font-weight:var(--font-weight-semibold);padding-right:var(--space-4);letter-spacing:var(--tracking-tight)}.modal-close{color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:4px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0;background:transparent;border:none}.modal-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.modal-body{padding:24px}.modal-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:var(--space-4)}.modal-stat{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-size:.9375rem}.spoiler-toggle{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-size:.8125rem;cursor:pointer;font-weight:var(--font-weight-medium)}.spoiler-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--color-accent)}.modal-tags-grid{display:flex;flex-wrap:wrap;gap:6px}.modal-tags-grid .tag{font-size:12px;padding:5px 12px}@media(min-width:640px){.vndle-game{padding:var(--space-6)}.game-header h1{font-size:1.875rem}.stat-value{font-size:1.5rem}.clues-section{padding:28px}.clues-container{flex-direction:row;gap:var(--space-8)}.clue-item{flex-shrink:0}.clue-image{max-width:220px}.clue-text-container{flex:1}.comparison-table-container{margin:0;padding:0}.tags-cell{max-width:360px}.modal-header h3{font-size:1.125rem}}@media(min-width:1024px){.vndle-game{padding:var(--space-8);padding-bottom:var(--space-8)}.game-header h1{font-size:2rem}.clue-image{max-width:260px}.clue-info h3,.clue-locked h3{font-size:1.125rem}.tags-cell{max-width:420px}}@media(max-width:360px){.vndle-game{padding:var(--space-3)}.game-header h1{font-size:1.375rem}.stat-value{font-size:1.125rem}.clues-section{padding:18px;min-height:420px}.clue-image{max-width:160px}.comparison-table th{font-size:10px;padding:10px 8px}.comparison-table td{font-size:.75rem;padding:10px 8px}.tag{font-size:10px;padding:2px 6px}.modal-content{max-height:90vh;border-radius:var(--radius-xl)}.modal-header,.modal-body{padding:18px}}.screenshot-game{max-width:var(--content-max-width);margin:0 auto;padding:var(--space-4);padding-bottom:calc(var(--space-8) + var(--nav-height-mobile) + env(safe-area-inset-bottom,0px));text-align:center;min-height:100%;animation:entrance-depth .4s var(--ease-smooth-out)}.screenshot-game .game-header{margin-bottom:var(--space-6)}.screenshot-game .game-header h1{font-size:1.625rem;margin-bottom:var(--space-4);color:var(--color-text-primary);letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-bold)}.round-info{display:flex;gap:var(--space-3);justify-content:center;align-items:center;flex-wrap:wrap}.round-label,.stat-item{font-size:.75rem;color:var(--color-text-muted);padding:8px 14px;background:var(--color-surface-overlay);border-radius:var(--radius-md);border:1px solid var(--color-border);font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide)}.screenshot-display{margin:var(--space-6) 0;display:flex;justify-content:center;align-items:center}.screenshot-display img{max-width:100%;max-height:360px;object-fit:contain;display:block;margin:0 auto;border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-premium-lg);transition:filter .6s var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth)}.clue-buttons{display:flex;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-6);flex-wrap:wrap}.clue-buttons button{min-width:110px;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 16px;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:background var(--duration-quick) var(--ease-smooth),border-color var(--duration-quick) var(--ease-smooth),color var(--duration-quick) var(--ease-smooth),transform var(--duration-quick) var(--ease-smooth);cursor:pointer;-webkit-tap-highlight-color:transparent}.clue-buttons button:hover{background:var(--color-surface-hover);border-color:var(--color-border-light);color:var(--color-text-primary);transform:translateY(-1px)}.clue-buttons button:active{transform:translateY(0) scale(.98)}.clue-buttons button:disabled{opacity:.5;cursor:not-allowed;transform:none}.score-and-search{max-width:520px;margin:0 auto}.game-over-section{text-align:center;padding:28px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);min-height:580px;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:var(--shadow-md);animation:slideUp .5s var(--ease-out-expo)}.screenshot-game .error-state{text-align:center;padding:var(--space-10) var(--space-4);background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}@media(min-width:640px){.screenshot-game{padding:var(--space-6)}.screenshot-game .game-header h1{font-size:1.875rem}.screenshot-display img{max-height:460px}.clue-buttons{gap:var(--space-4)}.score-and-search{max-width:560px}.game-over-section{padding:32px}}@media(min-width:1024px){.screenshot-game{padding:var(--space-8);padding-bottom:var(--space-8)}.screenshot-game .game-header h1{font-size:2rem}.screenshot-display img{max-height:520px}}@media(max-width:360px){.screenshot-game{padding:var(--space-3)}.screenshot-game .game-header{margin-bottom:var(--space-4)}.screenshot-game .game-header h1{font-size:1.375rem}.round-info{gap:var(--space-2)}.round-label,.stat-item{font-size:11px;padding:6px 10px}.screenshot-display{margin:var(--space-4) 0}.screenshot-display img{max-height:280px;border-radius:var(--radius-md)}.clue-buttons{flex-direction:column;gap:var(--space-2)}.clue-buttons button{width:100%}.game-over-section{padding:20px;min-height:400px}}.screenshot-game .search-container .search-results,.screenshot-game .search-input-wrapper .search-results{top:auto;bottom:calc(100% + 8px);max-height:280px}.character-game{max-width:var(--content-max-width);margin:0 auto;padding:var(--space-4);padding-bottom:calc(140px + var(--nav-height-mobile) + env(safe-area-inset-bottom,0px));min-height:100%}.character-game .game-header{text-align:center;margin-bottom:var(--space-6);animation:entrance-depth .4s var(--ease-smooth-out)}.character-game .game-header h1{font-size:1.625rem;margin-bottom:var(--space-4);color:var(--color-text-primary);letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-bold)}.character-game .round-info{display:flex;gap:var(--space-3);justify-content:center;align-items:center;flex-wrap:wrap}.round-label,.difficulty-label{font-size:.75rem;color:var(--color-text-muted);padding:8px 14px;background:var(--color-surface-overlay);border-radius:var(--radius-md);border:1px solid var(--color-border);text-transform:uppercase;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wider)}.characters-grid{display:flex;gap:var(--space-4);margin-bottom:var(--space-4);justify-content:center;flex-wrap:wrap;animation:scale-subtle .4s var(--ease-out-expo) .05s both}.character-card{width:140px;height:200px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);transition:transform var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth);box-shadow:var(--shadow-premium-sm)}.character-card:hover{box-shadow:var(--shadow-premium-lg);transform:translateY(-4px) scale(1.02);border-color:var(--color-border-light)}.character-game .character-image{width:100%;height:100%;object-fit:cover}.inputs-grid{display:flex;gap:var(--space-4);margin-bottom:var(--space-6);justify-content:center;flex-wrap:wrap;animation:scale-subtle .4s var(--ease-out-expo) .1s both}.input-column{width:140px;display:flex;flex-direction:column;gap:var(--space-3)}.input-wrapper{position:relative}.character-input{width:100%;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 14px;color:var(--color-text-primary);font-size:15px;transition:border-color var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth);-webkit-tap-highlight-color:transparent}.character-input:focus{outline:none;border-color:var(--color-accent);background:var(--color-bg-elevated);box-shadow:0 0 0 4px var(--color-accent-muted),var(--shadow-premium-sm)}.character-input::placeholder{color:var(--color-text-disabled)}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:6px;max-height:220px;overflow-y:auto;z-index:var(--z-dropdown);box-shadow:var(--shadow-xl);animation:scale-subtle .2s var(--ease-out-expo)}.search-item{padding:12px 14px;cursor:pointer;border-bottom:1px solid var(--color-border);font-size:.875rem;color:var(--color-text-secondary);transition:all var(--transition-fast);min-height:44px;display:flex;align-items:center}.search-item:last-child{border-bottom:none}.search-item:hover,.search-item.selected{background:var(--color-surface-hover)}.search-item.selected{color:var(--color-accent)}.vn-item{display:flex;align-items:center;gap:var(--space-3)}.vn-thumbnail{width:36px;height:52px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--color-border);flex-shrink:0}.result-display{width:100%;padding:12px 14px;font-size:.875rem;font-weight:var(--font-weight-medium);text-align:center;border-radius:var(--radius-md)}.result-display.correct{color:var(--color-success);background:linear-gradient(135deg,var(--color-success-bg),rgba(52,211,153,.06));border:1px solid var(--color-success-border)}.result-display.incorrect{color:var(--color-error);background:var(--color-error-bg);border:1px solid var(--color-error-border)}.vn-name-expandable{cursor:help;border-bottom:1px dotted currentColor;position:relative}.vn-name-expandable:hover{opacity:.8}.action-bar{position:fixed;bottom:calc(var(--nav-height-mobile) + env(safe-area-inset-bottom,0px));left:0;right:0;width:100%;box-sizing:border-box;background:#0c0d10eb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--color-border);padding:16px 20px;display:flex;justify-content:center;align-items:center;z-index:var(--z-sticky);min-height:72px}.results-section{text-align:center}.score-display{margin-bottom:var(--space-5)}.round-score{color:var(--color-accent);font-size:1.375rem;font-weight:var(--font-weight-bold);margin-bottom:var(--space-3)}.session-score{color:var(--color-text-muted);font-size:.9375rem;font-weight:var(--font-weight-medium)}.character-game .final-score{color:var(--color-accent);font-size:1.625rem;font-weight:var(--font-weight-bold);margin-top:var(--space-5)}.completion-message{color:var(--color-success);font-size:1.125rem;font-weight:var(--font-weight-semibold);margin-top:var(--space-5)}.character-game .error-state{text-align:center;padding:var(--space-10) var(--space-4);background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}@media(min-width:640px){.character-game{padding:var(--space-6);padding-bottom:calc(140px + var(--nav-height-mobile) + env(safe-area-inset-bottom,0px))}.character-game .game-header h1{font-size:1.875rem}.characters-grid,.inputs-grid{flex-wrap:nowrap;gap:var(--space-5)}.character-card{width:160px;height:230px}.input-column{width:160px}.round-score{font-size:1.5rem}.character-game .final-score{font-size:1.875rem}}@media(min-width:1024px){.character-game{padding:var(--space-8);padding-bottom:calc(80px + var(--space-8));max-width:920px}.character-game .game-header h1{font-size:2rem}.action-bar{left:var(--nav-width-desktop);bottom:0;padding:18px 24px}.characters-grid,.inputs-grid{gap:var(--space-6)}.character-card{width:180px;height:260px}.input-column{width:180px}}@media(max-width:360px){.character-game{padding:var(--space-3);padding-bottom:calc(120px + var(--nav-height-mobile) + env(safe-area-inset-bottom,0px))}.character-game .game-header{margin-bottom:var(--space-4)}.character-game .game-header h1{font-size:1.375rem}.round-label,.difficulty-label{font-size:11px;padding:6px 10px}.characters-grid,.inputs-grid{flex-direction:column;align-items:center;gap:var(--space-3)}.character-card{width:100%;max-width:240px;height:320px}.input-column{width:100%;max-width:240px;gap:var(--space-2)}.character-input{padding:12px;font-size:16px}.search-dropdown{max-height:180px;border-radius:var(--radius-md)}.search-item{padding:12px;min-height:48px}.action-bar{padding:14px 16px}.round-score{font-size:1.125rem}.session-score{font-size:.8125rem}.character-game .final-score{font-size:1.375rem}.completion-message{font-size:1rem}}@media(min-width:1024px){.action-bar{left:var(--nav-width-desktop);bottom:0;width:calc(100% - var(--nav-width-desktop))}}.leaderboard-container{padding:var(--space-6) var(--space-4);max-width:640px;margin:0 auto;animation:entrance-depth .4s var(--ease-smooth-out)}.leaderboard-header-section{text-align:center;margin-bottom:var(--space-8)}.leaderboard-header-section h1{color:var(--color-text-primary);margin:0 0 var(--space-2) 0;font-size:1.625rem;font-weight:var(--font-weight-bold);letter-spacing:var(--tracking-tight)}.leaderboard-date{color:var(--color-text-muted);margin:0;font-size:.875rem;font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide)}.login-notice{background:linear-gradient(135deg,var(--color-accent-muted),rgba(94,170,184,.06));border:1px solid var(--color-accent-border);border-radius:var(--radius-lg);padding:14px 18px;margin-bottom:var(--space-6);text-align:center}.login-notice p{margin:0;color:var(--color-text-secondary);font-size:.875rem;font-weight:var(--font-weight-medium)}.user-rank-card{background:linear-gradient(135deg,var(--color-accent-muted),rgba(94,170,184,.04));border:1px solid var(--color-accent-border);border-radius:var(--radius-xl);padding:20px 24px;margin-bottom:var(--space-6);display:flex;justify-content:center;align-items:center;gap:var(--space-8);animation:slideUp .5s var(--ease-out-expo) .1s both}.rank-item{display:flex;flex-direction:column;align-items:center;gap:4px}.rank-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-medium)}.rank-value{font-size:1.375rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.rank-divider{width:1px;height:40px;background:var(--color-accent-border)}.leaderboard-table{background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-premium-md);animation:slide-up-stagger .5s var(--ease-smooth-out) .2s both}.leaderboard-header{display:grid;grid-template-columns:56px 1fr 90px;gap:var(--space-3);padding:14px 18px;background:var(--color-surface-overlay);border-bottom:1px solid var(--color-border);font-weight:var(--font-weight-medium);color:var(--color-text-muted);font-size:11px;text-transform:uppercase;letter-spacing:var(--tracking-widest)}.leaderboard-body{max-height:420px;overflow-y:auto}.leaderboard-row{display:grid;grid-template-columns:56px 1fr 90px;gap:var(--space-3);padding:14px 18px;border-bottom:1px solid var(--color-border);align-items:center;transition:background var(--duration-quick) var(--ease-smooth)}.leaderboard-row:last-child{border-bottom:none}.leaderboard-row:hover{background:var(--color-surface-hover)}.leaderboard-row.current-user{background:linear-gradient(90deg,rgba(94,170,184,.15),transparent);border-left:3px solid var(--color-accent);padding-left:15px;box-shadow:inset 0 0 20px #5eaab80d}.leaderboard-row.current-user:hover{background:linear-gradient(90deg,rgba(94,170,184,.2),var(--color-surface-hover))}.leaderboard-row.top-1 .col-rank{background:linear-gradient(135deg,#fcd34d,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-weight-bold)}.leaderboard-row.top-2 .col-rank{background:linear-gradient(135deg,#e5e7eb,#9ca3af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-weight-bold)}.leaderboard-row.top-3 .col-rank{background:linear-gradient(135deg,#f59e0b,#b45309);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-weight-bold)}.col-rank{font-size:.875rem;font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-align:center;font-variant-numeric:tabular-nums}.col-username{color:var(--color-text-primary);font-weight:var(--font-weight-medium);font-size:.875rem;display:flex;align-items:center;gap:var(--space-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.you-badge{background:var(--gradient-accent);color:var(--color-bg-primary);padding:3px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:var(--font-weight-bold);letter-spacing:var(--tracking-wider);flex-shrink:0}.col-score{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-size:.875rem;text-align:right;font-variant-numeric:tabular-nums}.no-data{padding:var(--space-10) var(--space-4);text-align:center}.no-data p{color:var(--color-text-muted);font-size:1rem;margin:0 0 var(--space-2) 0;font-weight:var(--font-weight-medium)}.no-data span{color:var(--color-text-disabled);font-size:.875rem}.loading-state,.error-state{padding:var(--space-10);text-align:center}.loading-state .spinner{width:36px;height:36px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto var(--space-4)}.loading-state p,.error-state p{color:var(--color-text-muted);margin:0;font-size:.9375rem}.error-state button{margin-top:var(--space-5);background:var(--color-surface-overlay);border:1px solid var(--color-border);color:var(--color-text-primary);padding:10px 18px;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:var(--font-weight-medium);transition:all var(--transition-base)}.error-state button:hover{background:var(--color-surface-hover);border-color:var(--color-border-light)}@media(min-width:640px){.leaderboard-container{padding:var(--space-10) var(--space-6)}.leaderboard-header-section h1{font-size:1.875rem}.leaderboard-header,.leaderboard-row{grid-template-columns:64px 1fr 110px;gap:var(--space-4);padding:16px 22px}.user-rank-card{padding:24px 32px}.rank-value{font-size:1.5rem}.leaderboard-body{max-height:480px}}@media(min-width:1024px){.leaderboard-container{padding:var(--space-12) var(--space-6)}.leaderboard-body{max-height:540px}}@media(max-width:360px){.leaderboard-container{padding:var(--space-4) var(--space-3)}.leaderboard-header-section{margin-bottom:var(--space-5)}.leaderboard-header-section h1{font-size:1.375rem}.leaderboard-date{font-size:.8125rem}.login-notice{padding:12px 14px;margin-bottom:var(--space-4)}.login-notice p{font-size:.8125rem}.user-rank-card{gap:var(--space-4);padding:16px}.rank-value{font-size:1.125rem}.rank-label{font-size:10px}.rank-divider{height:32px}.leaderboard-header,.leaderboard-row{grid-template-columns:44px 1fr 64px;gap:var(--space-2);padding:12px 14px}.leaderboard-header{font-size:10px}.col-rank,.col-username,.col-score{font-size:.8125rem}.you-badge{font-size:9px;padding:2px 6px}.leaderboard-body{max-height:340px}}.profile-container{padding:var(--space-6) var(--space-4);max-width:920px;margin:0 auto;animation:entrance-depth .4s var(--ease-smooth-out)}.profile-login-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:420px;text-align:center;color:var(--color-text-secondary);padding:var(--space-8)}.profile-login-prompt .prompt-icon{font-size:4rem;margin-bottom:var(--space-5);opacity:.4}.profile-login-prompt h2{color:var(--color-text-primary);margin-bottom:var(--space-3);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-tight)}.profile-login-prompt p{color:var(--color-text-muted);font-size:.9375rem}.profile-loading,.profile-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:320px;gap:var(--space-5);color:var(--color-text-secondary)}.profile-error button{padding:10px 20px;background:var(--gradient-accent);color:var(--color-bg-primary);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-medium);transition:all var(--transition-base);box-shadow:var(--shadow-sm),var(--shadow-glow-sm)}.profile-error button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.profile-header{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-10);padding:24px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-premium-md);animation:slide-up-stagger .5s var(--ease-smooth-out) .1s both}.profile-avatar{width:72px;height:72px;border-radius:var(--radius-full);background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:1.875rem;font-weight:var(--font-weight-bold);color:var(--color-bg-primary);flex-shrink:0;box-shadow:var(--shadow-glow)}.profile-info{min-width:0}.profile-username{font-size:1.625rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:var(--tracking-tight)}.profile-joined{color:var(--color-text-muted);font-size:.875rem;margin:0;font-weight:var(--font-weight-medium)}.profile-section{margin-bottom:var(--space-10);animation:slideUp .5s var(--ease-out-expo) both}.profile-section:nth-child(2){animation-delay:.15s}.profile-section:nth-child(3){animation-delay:.2s}.profile-section:nth-child(4){animation-delay:.25s}.profile-section:nth-child(5){animation-delay:.3s}.section-title{display:flex;align-items:center;gap:var(--space-3);font-size:1.125rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-5) 0;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);letter-spacing:var(--tracking-tight)}.section-icon{font-size:1.25rem}.streak-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.streak-stat{display:flex;flex-direction:column;align-items:center;padding:20px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;transition:border-color var(--duration-normal) var(--ease-smooth),transform var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth)}.streak-stat:hover{border-color:var(--color-accent-border);transform:translateY(-3px);box-shadow:var(--shadow-premium-md)}.streak-stat.current{border-color:var(--color-accent);background:linear-gradient(135deg,#5eaab826,#5eaab80d);box-shadow:var(--shadow-glow-sm)}.streak-value{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.streak-stat.current .streak-value{color:var(--color-accent)}.streak-label{font-size:.75rem;color:var(--color-text-muted);margin-top:8px;text-transform:uppercase;letter-spacing:var(--tracking-widest);font-weight:var(--font-weight-medium)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.stat-card{padding:20px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base)}.stat-card:hover{border-color:var(--color-border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-widest);margin-bottom:8px;font-weight:var(--font-weight-medium)}.stat-card-value{font-size:1.625rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.stat-card-sub{font-size:.8125rem;color:var(--color-text-muted);margin-top:6px}.game-mode-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-top:var(--space-5)}.game-mode-card{padding:18px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-base)}.game-mode-card:hover{border-color:var(--color-border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.game-mode-icon{font-size:1.125rem;margin-bottom:var(--space-3)}.game-mode-name{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-2);font-weight:var(--font-weight-medium)}.game-mode-value{font-size:1.375rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.game-mode-label{font-size:.6875rem;color:var(--color-text-muted);margin-top:6px}.calendar-container{background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.calendar-header{display:flex;justify-content:center;margin-bottom:var(--space-4)}.calendar-month{font-size:.9375rem;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);letter-spacing:var(--tracking-wide)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.calendar-day{aspect-ratio:1;width:100%;border-radius:var(--radius-sm);background:#1a1d22;position:relative;cursor:default;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.04)}.calendar-day .day-number{font-size:.625rem;color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.calendar-day:hover{transform:scale(1.15);z-index:1;box-shadow:0 0 12px var(--color-accent-glow)}.calendar-day.played .day-number{color:var(--color-text-primary)}.calendar-day.future{opacity:.3;background:#141619}.calendar-day.level-1{background:#5eaab814;border-color:#5eaab81f}.calendar-day.level-2{background:#5eaab82e;border-color:#5eaab838}.calendar-day.level-3{background:#5eaab852;border-color:#5eaab861}.calendar-day.level-4{background:#5eaab885;border-color:#5eaab899}.calendar-day.level-5{background:var(--gradient-accent);border-color:var(--color-accent);box-shadow:0 0 12px var(--color-accent-glow)}.calendar-day.level-5 .day-number{color:var(--color-bg-primary);font-weight:var(--font-weight-semibold)}.calendar-day.today{box-shadow:0 0 0 2px var(--color-accent)}.calendar-tooltip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--color-bg-primary);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:8px 12px;font-size:.75rem;white-space:nowrap;z-index:var(--z-tooltip, 50);pointer-events:none;opacity:0;transition:opacity var(--transition-fast);box-shadow:var(--shadow-lg)}.calendar-day:hover .calendar-tooltip{opacity:1}.calendar-legend{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-4);font-size:.6875rem;color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.legend-scale{display:flex;gap:3px}.legend-box{width:14px;height:14px;border-radius:3px}.legend-box.empty{background:#1a1d22;border:1px solid rgba(255,255,255,.04)}.legend-box.level-1{background:#5eaab814}.legend-box.level-2{background:#5eaab82e}.legend-box.level-3{background:#5eaab852}.legend-box.level-4{background:#5eaab885}.legend-box.level-5{background:var(--gradient-accent)}.chart-container{background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.chart-bars{display:flex;align-items:flex-end;gap:4px;height:130px;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.chart-bar-spacer{width:100%}.chart-bar{width:100%;max-width:28px;background:var(--gradient-accent);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:all var(--transition-fast)}.chart-bar:hover{opacity:.85;transform:scaleY(1.02)}.chart-bar.empty{background:var(--color-bg-elevated);min-height:4px}.chart-labels{display:flex;justify-content:space-between;margin-top:var(--space-3);font-size:.6875rem;color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.chart-empty{display:flex;align-items:center;justify-content:center;height:130px;color:var(--color-text-muted);font-size:.9375rem}.achievements-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.achievement-card{display:flex;flex-direction:column;align-items:center;padding:20px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-base)}.achievement-card.locked{opacity:.35;filter:grayscale(1)}.achievement-card.unlocked{border-color:var(--color-accent-border)}.achievement-card.unlocked:hover{border-color:var(--color-accent);box-shadow:var(--shadow-glow),var(--shadow-premium-md);transform:translateY(-3px)}.achievement-icon{font-size:2.25rem;margin-bottom:var(--space-3)}.achievement-name{font-size:.9375rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:6px;letter-spacing:var(--tracking-tight)}.achievement-card.locked .achievement-name{color:var(--color-text-muted)}.achievement-description{font-size:.8125rem;color:var(--color-text-muted);line-height:var(--leading-relaxed)}.achievement-requirement{font-size:.6875rem;color:var(--color-text-disabled);margin-top:8px;font-style:italic}.achievement-card.unlocked .achievement-requirement{color:var(--color-accent);font-style:normal;font-weight:var(--font-weight-medium)}.achievement-date{font-size:.6875rem;color:var(--color-accent);margin-top:var(--space-3);font-weight:var(--font-weight-medium)}.achievements-summary{display:flex;align-items:baseline;gap:6px;margin-bottom:var(--space-5);padding:14px 18px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.unlocked-count{font-size:1.625rem;font-weight:var(--font-weight-bold);color:var(--color-accent)}.total-count{font-size:.9375rem;color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.achievement-category{margin-bottom:var(--space-8)}.achievement-category:last-child{margin-bottom:0}.category-title{font-size:.8125rem;font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-widest);margin-bottom:var(--space-4)}@media(min-width:640px){.profile-container{padding:var(--space-8) var(--space-6)}.profile-header{padding:28px}.profile-avatar{width:88px;height:88px;font-size:2.25rem}.profile-username{font-size:1.875rem}.stats-grid,.achievements-grid{grid-template-columns:repeat(4,1fr)}.calendar-grid{gap:6px}}@media(min-width:1024px){.profile-container{padding:var(--space-10) var(--space-6)}.achievements-grid{grid-template-columns:repeat(5,1fr)}.chart-bars{height:160px}}@media(max-width:360px){.profile-container{padding:var(--space-4) var(--space-3)}.profile-header{padding:18px;gap:var(--space-3)}.profile-avatar{width:56px;height:56px;font-size:1.5rem}.profile-username{font-size:1.25rem}.streak-overview,.game-mode-stats{grid-template-columns:1fr;gap:var(--space-3)}.achievements-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.achievement-card,.stat-card,.streak-stat,.game-mode-card{padding:16px}}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.achievement-toast{position:fixed;top:var(--space-5);left:50%;transform:translate(-50%) translateY(-120%);z-index:var(--z-toast, 600);display:flex;align-items:center;gap:var(--space-4);padding:18px 22px;background:var(--gradient-card),var(--color-bg-card);border:1px solid var(--color-accent-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl),var(--shadow-glow-lg);opacity:0;transition:all .4s var(--ease-spring)}.achievement-toast.visible{transform:translate(-50%) translateY(0);opacity:1}.toast-icon{font-size:2.75rem;animation:iconBounce .6s var(--ease-spring) .3s}@keyframes iconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.toast-content{display:flex;flex-direction:column;gap:4px}.toast-title{font-size:10px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--color-accent)}.toast-name{font-size:1.125rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--tracking-tight)}.toast-description{font-size:.875rem;color:var(--color-text-secondary);line-height:var(--leading-normal)}.achievement-toast:before{content:"";position:absolute;inset:-1px;border-radius:var(--radius-xl);background:linear-gradient(90deg,transparent,var(--color-accent),transparent);background-size:200% 100%;animation:shimmer 2.5s linear infinite;z-index:-1;opacity:.4}@media(max-width:640px){.achievement-toast{left:var(--space-4);right:var(--space-4);transform:translateY(-120%);max-width:calc(100vw - var(--space-8));padding:16px 18px;gap:var(--space-3);border-radius:var(--radius-lg)}.achievement-toast.visible{transform:translateY(0)}.toast-icon{font-size:2.25rem}.toast-name{font-size:1rem}.toast-description{font-size:.8125rem}}@media(max-width:360px){.achievement-toast{padding:14px 16px}.toast-icon{font-size:2rem}.toast-title{font-size:9px}.toast-name{font-size:.9375rem}.toast-description{font-size:.75rem}}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2);max-width:360px;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-premium-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:toast-slide-in .35s var(--ease-smooth-out);pointer-events:auto}@keyframes toast-slide-in{0%{opacity:0;transform:translate(120%) scale(.95)}60%{opacity:1;transform:translate(-8px) scale(1)}to{opacity:1;transform:translate(0) scale(1)}}.toast-success{border-color:var(--color-success);background:linear-gradient(135deg,rgba(52,211,153,.1),var(--color-bg-card))}.toast-error{border-color:var(--color-error);background:linear-gradient(135deg,rgba(248,113,113,.1),var(--color-bg-card))}.toast-warning{border-color:var(--color-warning);background:linear-gradient(135deg,rgba(251,191,36,.1),var(--color-bg-card))}.toast-info{border-color:var(--color-accent);background:linear-gradient(135deg,rgba(94,170,184,.1),var(--color-bg-card))}.toast-message{font-size:var(--text-sm);color:var(--color-text-primary);line-height:var(--leading-snug)}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-quick) var(--ease-smooth),color var(--duration-quick) var(--ease-smooth),transform var(--duration-quick) var(--ease-smooth)}.toast-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary);transform:scale(1.1)}.toast-close:active{transform:scale(.95)}@media(max-width:480px){.toast-container{top:auto;bottom:calc(70px + var(--space-4));left:var(--space-4);right:var(--space-4);max-width:none}}
