:root{--primary-color: #f59e0b;--primary-color-hover: #e59107;--secondary-color: #ef4444;--secondary-color-hover: #dc2626;--secondary-color-dark: #b91c1c;--accent-color: #d97706;--success-color: #22c55e;--success-color-light: #4ade80;--success-color-hover: #16a34a;--warning-color: #f59e0b;--error-color: #ef4444;--primary-color-5: rgba(245, 158, 11, .05);--primary-color-10: rgba(245, 158, 11, .1);--primary-color-15: rgba(245, 158, 11, .15);--primary-color-20: rgba(245, 158, 11, .2);--primary-color-30: rgba(245, 158, 11, .3);--primary-color-50: rgba(245, 158, 11, .5);--secondary-color-5: rgba(239, 68, 68, .05);--secondary-color-10: rgba(239, 68, 68, .1);--secondary-color-20: rgba(239, 68, 68, .2);--secondary-color-30: rgba(239, 68, 68, .3);--success-color-10: rgba(34, 197, 94, .1);--success-color-15: rgba(74, 222, 128, .15);--success-color-20: rgba(34, 197, 94, .2);--success-color-30: rgba(34, 197, 94, .3);--completion-main: #4ade80;--completion-main-plus: #60a5fa;--completion-100: #fbbf24;--star-color: #fbbf24;--warning-color-10: rgba(251, 191, 36, .1);--warning-color-30: rgba(251, 191, 36, .3);--gradient-primary: linear-gradient(135deg, var(--primary-color), var(--secondary-color));--gradient-primary-hover: linear-gradient(135deg, var(--primary-color-hover), var(--secondary-color-hover));--gradient-danger: linear-gradient(135deg, var(--secondary-color), var(--secondary-color-hover));--gradient-danger-hover: linear-gradient(135deg, var(--secondary-color-hover), var(--secondary-color-dark));--bg-primary: #0f0f1e;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--card-bg: rgba(26, 26, 46, .8);--card-hover: rgba(26, 26, 46, .9);--text-primary: #e2e8f0;--text-secondary: #e5e5e5;--text-muted: #a0a0a0;--border-color: var(--primary-color-20);--shadow-color: var(--primary-color-10);--focus-ring: 0 0 0 3px var(--primary-color-10);--focus-ring-strong: 0 0 0 3px var(--primary-color-20);--btn-shadow: 0 4px 16px var(--primary-color-30);--danger-focus-ring: 0 0 0 3px var(--secondary-color-20);--danger-shadow: 0 4px 16px var(--secondary-color-30);--btn-secondary-hover-bg: var(--primary-color-15);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--verification-bg: linear-gradient(135deg, var(--primary-color-10), rgba(255, 165, 0, .05));--verification-border: var(--primary-color-30)}[data-theme=cosmic-green]{--primary-color: #10b981;--primary-color-hover: #059669;--secondary-color: #06b6d4;--secondary-color-hover: #0891b2;--secondary-color-dark: #0e7490;--accent-color: #14b8a6;--success-color: #22c55e;--success-color-light: #4ade80;--success-color-hover: #16a34a;--warning-color: #f59e0b;--error-color: #ef4444;--primary-color-5: rgba(16, 185, 129, .05);--primary-color-10: rgba(16, 185, 129, .1);--primary-color-15: rgba(16, 185, 129, .15);--primary-color-20: rgba(16, 185, 129, .2);--primary-color-30: rgba(16, 185, 129, .3);--primary-color-50: rgba(16, 185, 129, .5);--secondary-color-5: rgba(6, 182, 212, .05);--secondary-color-10: rgba(6, 182, 212, .1);--secondary-color-20: rgba(6, 182, 212, .2);--secondary-color-30: rgba(6, 182, 212, .3);--success-color-10: rgba(34, 197, 94, .1);--success-color-15: rgba(74, 222, 128, .15);--success-color-20: rgba(34, 197, 94, .2);--success-color-30: rgba(34, 197, 94, .3);--warning-color-10: rgba(251, 191, 36, .1);--warning-color-30: rgba(251, 191, 36, .3);--completion-main: #16a34a;--completion-main-plus: #2563eb;--completion-100: #d97706;--star-color: #d97706;--bg-primary: #f0fdf4;--bg-secondary: #dcfce7;--bg-tertiary: #bbf7d0;--card-bg: rgba(220, 252, 231, .9);--card-hover: rgba(187, 247, 208, .95);--text-primary: #064e3b;--text-secondary: #065f46;--text-muted: #6b7280;--border-color: rgba(16, 185, 129, .25);--shadow-color: rgba(16, 185, 129, .15);--focus-ring: 0 0 0 3px rgba(16, 185, 129, .2);--focus-ring-strong: 0 0 0 3px rgba(16, 185, 129, .3);--btn-shadow: 0 4px 16px rgba(16, 185, 129, .25);--danger-focus-ring: 0 0 0 3px rgba(239, 68, 68, .2);--danger-shadow: 0 4px 16px rgba(239, 68, 68, .2);--btn-secondary-hover-bg: rgba(16, 185, 129, .15);--gradient-primary: linear-gradient(135deg, var(--primary-color), var(--secondary-color));--gradient-primary-hover: linear-gradient(135deg, var(--primary-color-hover), var(--secondary-color-hover));--gradient-danger: linear-gradient(135deg, #ef4444, #dc2626);--gradient-danger-hover: linear-gradient(135deg, #dc2626, #b91c1c);--verification-bg: linear-gradient(135deg, var(--primary-color-10), rgba(16, 185, 129, .05));--verification-border: var(--primary-color-30)}[data-theme=nebula-purple]{--primary-color: #a855f7;--primary-color-hover: #9333ea;--secondary-color: #ec4899;--secondary-color-hover: #db2777;--secondary-color-dark: #be185d;--accent-color: #c084fc;--success-color: #22c55e;--success-color-light: #4ade80;--success-color-hover: #16a34a;--warning-color: #fbbf24;--error-color: #f43f5e;--primary-color-5: rgba(168, 85, 247, .05);--primary-color-10: rgba(168, 85, 247, .1);--primary-color-15: rgba(168, 85, 247, .15);--primary-color-20: rgba(168, 85, 247, .2);--primary-color-30: rgba(168, 85, 247, .3);--primary-color-50: rgba(168, 85, 247, .5);--secondary-color-5: rgba(236, 72, 153, .05);--secondary-color-10: rgba(236, 72, 153, .1);--secondary-color-20: rgba(236, 72, 153, .2);--secondary-color-30: rgba(236, 72, 153, .3);--success-color-10: rgba(34, 197, 94, .1);--success-color-15: rgba(74, 222, 128, .15);--success-color-20: rgba(34, 197, 94, .2);--success-color-30: rgba(34, 197, 94, .3);--warning-color-10: rgba(251, 191, 36, .1);--warning-color-30: rgba(251, 191, 36, .3);--completion-main: #4ade80;--completion-main-plus: #60a5fa;--completion-100: #fbbf24;--star-color: #fbbf24;--bg-primary: #1e1b2e;--bg-secondary: #2d2640;--bg-tertiary: #3d3555;--card-bg: rgba(45, 38, 64, .9);--card-hover: rgba(61, 53, 85, .95);--text-primary: #f3e8ff;--text-secondary: #e9d5ff;--text-muted: #a78bfa;--border-color: rgba(168, 85, 247, .25);--shadow-color: rgba(168, 85, 247, .15);--focus-ring: 0 0 0 3px rgba(168, 85, 247, .2);--focus-ring-strong: 0 0 0 3px rgba(168, 85, 247, .3);--btn-shadow: 0 4px 16px rgba(168, 85, 247, .3);--danger-focus-ring: 0 0 0 3px rgba(244, 63, 94, .2);--danger-shadow: 0 4px 16px rgba(244, 63, 94, .25);--btn-secondary-hover-bg: rgba(168, 85, 247, .15);--gradient-primary: linear-gradient(135deg, var(--primary-color), var(--secondary-color));--gradient-primary-hover: linear-gradient(135deg, var(--primary-color-hover), var(--secondary-color-hover));--gradient-danger: linear-gradient(135deg, #f43f5e, #e11d48);--gradient-danger-hover: linear-gradient(135deg, #e11d48, #be123c);--verification-bg: linear-gradient(135deg, var(--primary-color-10), rgba(168, 85, 247, .05));--verification-border: var(--primary-color-30)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.1rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md);color:var(--text-secondary)}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-color)}.app-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.main-app{flex:1;display:flex;flex-direction:column}.splash-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity var(--transition-slow)}.splash-screen.fade-out{opacity:0;pointer-events:none}.splash-content{text-align:center}.logo-container{margin-bottom:var(--spacing-xl)}.logo{animation:rotate 20s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.splash-title{font-size:3rem;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:var(--spacing-xl)}.loading-bar{width:200px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin:0 auto}.loading-progress{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));animation:loading 2s ease-in-out infinite}@keyframes loading{0%{width:0%}50%{width:100%}to{width:0%}}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);max-width:1400px;margin:0 auto}.menu-toggle,.search-toggle{background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.menu-toggle:hover,.search-toggle:hover{background:var(--primary-color-10);color:var(--primary-color)}.app-title{font-size:1.5rem;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.nav-drawer{position:fixed;top:0;left:0;width:200px;height:100%;background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:200;overflow-y:auto;display:flex;flex-direction:column}.nav-brand{padding:var(--spacing-lg) var(--spacing-md);border-bottom:1px solid var(--border-color)}.nav-brand .app-title{font-size:1.25rem;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.nav-header{padding:var(--spacing-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm)}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-primary);flex-shrink:0}.user-details h3{font-size:1rem;margin-bottom:var(--spacing-xs)}.user-stats{font-size:.875rem;color:var(--text-muted)}.nav-menu{padding:var(--spacing-sm);list-style:none;flex:1}.nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);border-radius:var(--border-radius-sm);transition:all var(--transition-fast);margin-bottom:var(--spacing-xs)}.nav-link:hover{background:var(--primary-color-10);color:var(--primary-color)}.nav-link.active{background:var(--primary-color-20);color:var(--primary-color)}.nav-icon{font-size:1.25rem}.nav-footer{border-top:1px solid var(--border-color);padding:var(--spacing-sm);margin-top:auto}.main-content{flex:1;padding:var(--spacing-lg);max-width:1400px;margin:0 auto;width:100%}.dashboard{animation:fadeIn .5s ease}.page-title{font-size:2rem;margin-bottom:var(--spacing-xl);background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.stat-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--spacing-sm);text-align:center;transition:all var(--transition-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-color);border-color:var(--primary-color)}.stat-icon{font-size:1.25rem;margin-bottom:var(--spacing-xs)}.stat-value{font-size:1.1rem;font-weight:700;color:var(--primary-color);margin-bottom:2px}.stat-label{color:var(--text-primary);font-size:.65rem;text-transform:uppercase;letter-spacing:.5px}.recent-activity,.recently-added,.released-today,.upcoming-releases,.upcoming-all,.new-listings{margin-top:var(--spacing-xl)}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.games-scroll-container{display:flex;gap:var(--spacing-md);overflow-x:auto;overflow-y:hidden;padding-bottom:var(--spacing-sm);scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.games-scroll-container::-webkit-scrollbar{height:6px}.games-scroll-container::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.games-scroll-container::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:3px}.games-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}.games-scroll-container .game-card{flex:0 0 200px;min-width:200px}.page-footer{margin-top:var(--spacing-xl);padding-top:var(--spacing-md);border-top:1px solid var(--border-color);text-align:center}.data-attribution{font-size:.75rem;color:var(--text-muted)}.data-attribution a{color:var(--primary-color);text-decoration:none}.data-attribution a:hover{text-decoration:underline}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-lg)}.game-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;transition:all var(--transition-base);cursor:pointer}.game-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow-color)}.game-cover{position:relative;padding-top:133.33%;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--border-color) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}.game-cover:has(img[src]:not([src=""])){animation:none;background:var(--bg-tertiary)}.game-cover img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center}.steam-game .game-cover img{object-fit:cover;object-position:center}.game-platform{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--primary-color);color:var(--bg-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:.75rem;font-weight:600}.game-platform-badges{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;flex-direction:column;gap:4px;align-items:flex-end}.game-platform-badge{background:var(--primary-color);color:var(--bg-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:.75rem;font-weight:600}.game-wishlist-badge{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);background:#0009;color:gold;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000004d}.game-completed-badge{position:absolute;bottom:var(--spacing-sm);left:var(--spacing-sm);background:#000000bf;color:var(--completion-main);padding:3px 8px;border-radius:var(--border-radius-sm);display:flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;box-shadow:0 2px 4px #0000004d}.game-completed-badge svg{flex-shrink:0}.game-completed-badge.completed-main{color:var(--completion-main)}.game-completed-badge.completed-main-plus{color:var(--completion-main-plus)}.game-completed-badge.completed-100{color:var(--completion-100);background:#000000d9}.game-info{padding:var(--spacing-md)}.game-title{font-size:1rem;margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.game-year,.game-release-date{font-size:.875rem;color:var(--text-muted)}.game-genres{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--spacing-sm)}.genre-tag{background:var(--primary-color);color:var(--bg-primary);font-size:.7rem;padding:2px 6px;border-radius:10px;font-weight:700}.game-type-labels{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;margin-bottom:var(--spacing-sm)}.game-type-tag{background:var(--secondary-color);color:var(--bg-primary);font-size:.7rem;padding:2px 6px;border-radius:10px;font-weight:700}.genre-more{background:var(--text-muted);color:var(--bg-primary);font-size:.7rem;padding:2px 6px;border-radius:10px;font-weight:500}.game-rating{color:var(--primary-color)}.game-progress{display:flex;align-items:center;gap:var(--spacing-sm)}.progress-bar{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));transition:width var(--transition-base)}.progress-text{font-size:.75rem;color:var(--text-muted)}.game-card.steam-game{border-left:3px solid #1b2838}.steam-indicator{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);background:linear-gradient(135deg,#1b2838,#2a475e);color:#fff;padding:4px 6px;border-radius:var(--border-radius-sm);font-size:.7rem}.game-platform.steam-platform,.game-platform-badge.steam-platform{background:linear-gradient(135deg,#1b2838,#2a475e);color:#fff}.game-platform-badge.xbox-platform{background:linear-gradient(135deg,#107c10,#0e6b0e);color:#fff}.game-platform-badge.playstation-platform{background:linear-gradient(135deg,#003791,#0070cc);color:#fff}.game-platform-badge.nintendo-platform{background:linear-gradient(135deg,#e60012,#ff4655);color:#fff}.game-platform-badge.epic-platform{background:linear-gradient(135deg,#0d0d0d,#2a2a2a);color:#fff}.game-platform-badge.gog-platform{background:linear-gradient(135deg,#86328a,#b642ba);color:#fff}.game-developer{font-size:.875rem;color:var(--text-muted)}.game-stats{margin-top:var(--spacing-sm)}.game-playtime,.game-achievements{font-size:.75rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.game-playtime{font-weight:600;color:var(--primary-color)}.game-playtime-inline{font-size:.75rem;font-weight:600;color:var(--primary-color);background:rgba(var(--primary-rgb, 99, 102, 241),.15);padding:2px 6px;border-radius:4px}.game-achievements{color:var(--primary-color)}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.library-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.steam-sync-status{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex;align-items:center;justify-content:space-between}.sync-info{display:flex;align-items:center;gap:var(--spacing-sm)}.sync-status-text{font-size:.9rem;color:var(--text-secondary)}@media(max-width:768px){.library-header{flex-direction:column;align-items:flex-start}.library-actions{width:100%;justify-content:flex-start}.steam-sync-status{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);color:var(--text-muted)}.empty-icon{font-size:4rem;opacity:.3;margin-bottom:var(--spacing-md)}.empty-title{font-size:1.25rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.empty-text{color:var(--text-muted)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);color:var(--text-secondary);font-weight:500}.form-input{width:100%;padding:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:1rem;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.form-input::placeholder{color:var(--text-muted)}.form-select{width:100%;padding:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:1rem;cursor:pointer;transition:all var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.form-select:hover{border-color:var(--primary-color)}.form-select option{background:var(--bg-secondary);color:var(--text-primary);padding:var(--spacing-sm)}.language-settings,.theme-settings{text-align:left}.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.theme-card{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);overflow:hidden;cursor:pointer;transition:all var(--transition-fast)}.theme-card:hover{border-color:var(--primary-color);transform:translateY(-2px)}.theme-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color-30)}.theme-preview{position:relative;height:60px}.theme-color-bar{height:20px;width:100%}.theme-bg-preview{height:40px;width:100%}.theme-info{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-secondary)}.theme-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.theme-selected-icon{color:var(--primary-color);font-size:.9rem}@media(max-width:480px){.theme-grid{grid-template-columns:1fr}}.input-group{position:relative;display:flex;align-items:center}.input-group .form-input{padding-right:3rem}.input-icon{position:absolute;right:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:1.2rem;color:var(--text-muted);transition:color var(--transition-fast);background:none;border:none;padding:0;line-height:1}.form-error{margin-top:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--secondary-color-10);border:1px solid var(--secondary-color-30);border-radius:var(--border-radius-sm);color:var(--error-color);font-size:.875rem;font-weight:500}.password-strength{margin-top:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-sm)}.strength-bar{flex:1;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.strength-fill{height:100%;width:0%;transition:width .3s ease,background-color .3s ease;border-radius:2px}.strength-text{font-size:.75rem;font-weight:500;min-width:50px;text-align:right;transition:color .3s ease}.btn,button.btn,a.btn,.btn-primary,button.btn-primary,a.btn-primary,.btn-secondary,button.btn-secondary,a.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s ease;outline:none}.btn:focus,button.btn:focus,.btn-primary:focus,button.btn-primary:focus{outline:none;box-shadow:0 0 0 3px var(--primary-color-20)}.btn-secondary:focus,button.btn-secondary:focus{outline:none;box-shadow:0 0 0 3px #6b728033}.btn,button.btn,a.btn,.btn-primary,button.btn-primary,a.btn-primary{background:var(--gradient-primary);color:var(--bg-primary)}.btn:hover,button.btn:hover,a.btn:hover,.btn-primary:hover,button.btn-primary:hover,a.btn-primary:hover{background:var(--gradient-primary-hover);color:var(--bg-primary);transform:translateY(-2px);box-shadow:0 4px 16px var(--primary-color-30)}.btn:active,button.btn:active,a.btn:active,.btn-primary:active,button.btn-primary:active,a.btn-primary:active{transform:translateY(0)}.btn-secondary,button.btn-secondary,a.btn-secondary{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover,button.btn-secondary:hover,a.btn-secondary:hover{background:var(--btn-secondary-hover-bg);color:var(--primary-color);transform:translateY(-1px)}.btn-danger,button.btn-danger{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s ease;background:var(--error-color);color:#fff;outline:none}.btn-danger:hover,button.btn-danger:hover{background:var(--secondary-color-hover);transform:translateY(-2px);box-shadow:0 4px 16px var(--secondary-color-30)}.btn-danger:active,button.btn-danger:active{transform:translateY(0)}.btn-danger:focus,button.btn-danger:focus{outline:none;box-shadow:0 0 0 3px var(--secondary-color-20)}.btn-submit,button.btn-submit,a.btn-submit{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s ease;width:100%;justify-content:center;background:var(--gradient-primary);color:var(--bg-primary)}.btn-submit:hover,button.btn-submit:hover,a.btn-submit:hover{background:var(--gradient-primary-hover);transform:translateY(-2px);box-shadow:0 4px 16px var(--primary-color-30);color:var(--bg-primary);text-decoration:none}.btn-submit:active,button.btn-submit:active,a.btn-submit:active{transform:translateY(0)}.logout-link{color:var(--error-color)!important;padding-top:var(--spacing-md)!important;margin-top:var(--spacing-md)}.logout-link:hover{background:var(--secondary-color-10)!important;color:var(--secondary-color-hover)!important}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.auth-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);width:100%;max-width:400px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.auth-logo{text-align:center;margin-bottom:var(--spacing-xl)}.logo-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-md)}.auth-logo h1{font-size:2rem;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:var(--spacing-sm)}.auth-logo p{color:var(--text-muted)}.auth-form{margin-bottom:var(--spacing-lg)}.auth-form .form-group{margin-bottom:var(--spacing-md)}.form-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.form-checkbox label{color:var(--text-secondary);font-size:.9rem;cursor:pointer}.auth-footer{text-align:center;padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.auth-footer p{color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-size:.9rem}.auth-footer a{color:var(--primary-color);font-weight:500}.auth-footer a:hover{color:var(--accent-color);text-decoration:underline}.auth-footer a.btn-primary,.auth-footer a.btn-primary:hover{color:var(--bg-primary);text-decoration:none}.auth-footer a.btn-secondary,.auth-footer a.btn-secondary:hover{color:var(--primary-color);text-decoration:none}.auth-footer a.btn-submit,.auth-footer a.btn-submit:hover{color:var(--bg-primary);text-decoration:none;font-weight:600}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--spacing-sm) 0;z-index:100}.bottom-nav-item{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);margin:0 var(--spacing-xs);color:var(--text-muted);transition:all var(--transition-fast);background:none;border:none;border-radius:var(--border-radius-sm);cursor:pointer}.bottom-nav-icon{font-size:1.5rem}.bottom-nav-item:hover{background:var(--primary-color-10);color:var(--primary-color)}.bottom-nav-item.active{background:var(--primary-color-20);color:var(--primary-color)}.bottom-nav-menu-toggle svg{width:24px;height:24px}.bottom-nav-menu{position:fixed;bottom:70px;right:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-sm) 0;z-index:101;box-shadow:0 -5px 20px #0000004d;min-width:180px}.bottom-nav-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);transition:all var(--transition-fast)}.bottom-nav-menu-item:hover{background:var(--primary-color-10);color:var(--primary-color)}.bottom-nav-menu-item.active{background:var(--primary-color-20);color:var(--primary-color)}.bottom-nav-menu-item.logout{color:var(--error-color)}.bottom-nav-menu-item.logout:hover{background:var(--secondary-color-10);color:var(--error-color)}.sidebar-ad-container{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-xs);min-height:200px;margin-top:var(--spacing-md)}.sidebar-ad-container ins{max-width:100%}@media(max-width:1760px){.sidebar-ad-container{display:none!important}}.bottom-ad-container{position:fixed;bottom:60px;left:0;right:0;display:flex;justify-content:center;align-items:center;z-index:99;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:5px 0;min-height:50px}@media(min-width:1761px){.bottom-ad-container{display:none!important}}body.ads-active .main-content{padding-bottom:130px}@media(min-width:1761px){body.ads-active .main-content{padding-bottom:var(--spacing-lg)}}.notification{position:fixed;bottom:var(--spacing-lg);left:50%;transform:translate(-50%) translateY(100px);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md) var(--spacing-lg);box-shadow:0 10px 30px #00000080;z-index:1000;transition:transform var(--transition-base)}.notification.show{transform:translate(-50%) translateY(0)}.notification-success{border-color:var(--success-color);background:var(--bg-secondary)}.notification-error{border-color:var(--error-color);background:var(--bg-secondary)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.modal.active{opacity:1;pointer-events:all}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;transform:scale(.9);transition:transform var(--transition-base)}.modal.active .modal-content{transform:scale(1)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.25rem;margin:0}.btn-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:var(--spacing-sm);transition:color var(--transition-fast)}.btn-close:hover{color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.hidden{display:none!important}.text-muted{color:var(--text-muted)}@media(max-width:1760px){.bottom-nav{display:flex}.nav-drawer{display:none}.main-content{padding-bottom:80px}}@media(max-width:768px){.quick-stats,.games-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1760px){.app-container{padding-bottom:70px}.nav-link{flex-direction:column;padding:.5rem;font-size:.75rem}.nav-link i{font-size:1.5rem;margin-right:0;margin-bottom:.25rem}.dashboard h1{font-size:1.75rem}.quick-stats{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.auth-card{padding:2rem 1.5rem}.code-inputs{gap:.25rem}.code-input{width:40px;height:50px}.game-stats{padding:1rem}.stats-overview{grid-template-columns:1fr}.modal-content{margin:1rem;padding:1.5rem}.notification{left:1rem;right:1rem;bottom:5rem;transform:translateY(100px);max-width:calc(100% - 2rem)}.notification.show{transform:translateY(0)}}@media(max-width:480px){.notification{left:.5rem;right:.5rem;bottom:4.5rem;padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;text-align:center;word-wrap:break-word}.games-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.game-info{padding:1rem}.game-title{font-size:.9rem}.platform-stat{flex-direction:column;align-items:start;gap:.5rem}.platform-progress{width:100%;margin:0}}@media(min-width:769px)and (max-width:1024px){.games-grid{grid-template-columns:repeat(3,1fr)}.quick-stats,.stats-overview{grid-template-columns:repeat(2,1fr)}}@media(min-width:1440px){.dashboard,.game-stats{max-width:1400px;margin:0 auto}.games-grid{grid-template-columns:repeat(5,1fr)}.quick-stats{grid-template-columns:repeat(4,1fr)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.fade-in{animation:fadeIn .5s ease forwards}.slide-in{animation:slideIn .3s ease forwards}.pulse{animation:pulse 2s ease infinite}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.pt-1{padding-top:.5rem}.pt-2{padding-top:1rem}.pt-3{padding-top:1.5rem}.pt-4{padding-top:2rem}.pb-1{padding-bottom:.5rem}.pb-2{padding-bottom:1rem}.pb-3{padding-bottom:1.5rem}.pb-4{padding-bottom:2rem}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--primary-color-30);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary-color-50)}@media print{.nav-menu,.btn-add,.game-actions,.notification{display:none!important}body{background:#fff;color:#000}.card{border:1px solid #ccc;box-shadow:none}}.game-stats{padding:2rem;max-width:1200px;margin:0 auto}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.chart-container{background:var(--card-bg);border-radius:var(--border-radius);padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--primary-color-20)}.chart-container h3{color:var(--primary-color);margin-bottom:1.5rem;font-size:1.2rem}.platform-breakdown{display:grid;gap:1rem}.platform-stat{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#ffffff0d;border-radius:12px}.platform-info{display:flex;align-items:center;gap:1rem}.platform-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;background:var(--primary-color);color:var(--bg-primary)}.platform-progress{flex:1;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin:0 1rem}.platform-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:4px;transition:width .5s ease}.offline-notice{position:fixed;top:60px;left:50%;transform:translate(-50%);background:var(--warning-color);color:var(--bg-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius);font-weight:600;z-index:150;transition:all var(--transition-base)}.install-prompt{position:fixed;bottom:var(--spacing-lg);left:var(--spacing-lg);right:var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-lg);box-shadow:0 10px 30px #00000080;z-index:150;max-width:400px;margin:0 auto}.install-content h3{margin-bottom:var(--spacing-sm);color:var(--primary-color)}.install-content p{margin-bottom:var(--spacing-lg);color:var(--text-secondary)}.install-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;visibility:hidden;transition:all var(--transition-base)}.modal-overlay.show{opacity:1;visibility:visible}.modal-container{background:var(--bg-secondary);border-radius:var(--border-radius-lg);border:none;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;transform:translateY(20px);transition:all var(--transition-base)}.modal-overlay.show .modal-container{transform:translateY(0)}.modal-content{padding:2rem}.modal-header{text-align:center;margin-bottom:2rem}.modal-header h2{font-size:1.5rem;margin-bottom:.5rem;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-header p{color:var(--text-secondary);margin-bottom:0}.modal-body{margin-bottom:2rem}.security-benefits{display:grid;gap:1rem}.benefit-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--primary-color-10)}.benefit-item span:last-child{color:var(--text-primary)}.benefit-icon{font-size:1.5rem;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--primary-color-20);border-radius:50%}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.2fa-setup-content{max-width:600px;margin:0 auto}.setup-step{text-align:center;padding:2rem 0}.setup-step.hidden{display:none}.setup-step h3{color:var(--primary-color);margin-bottom:1rem;font-size:1.3rem}.setup-step p{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.authenticator-apps{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.app-option{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--primary-color-20);transition:all var(--transition-base);color:var(--text-primary)}.app-option:hover{background:var(--primary-color-10);border-color:var(--primary-color)}.app-icon{font-size:1.5rem}.qr-code-container{margin:2rem 0;display:flex;justify-content:center}.qr-placeholder{width:200px;height:200px;background:var(--bg-tertiary);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;border:2px dashed var(--primary-color-30)}.qr-code-image{max-width:100%;max-height:100%;border-radius:var(--border-radius-sm)}.loading-spinner{color:var(--text-secondary);font-style:italic}.manual-entry{margin-top:1.5rem;text-align:left}.manual-entry summary{color:var(--primary-color);cursor:pointer;margin-bottom:1rem}.manual-key{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--border-radius);margin-top:1rem}.manual-key p{color:var(--text-secondary);margin:0}.manual-key code{flex:1;background:var(--bg-secondary);padding:.5rem;border-radius:4px;font-family:Courier New,monospace;word-break:break-all;color:var(--primary-color)}.btn-copy{background:var(--gradient-primary);color:var(--bg-primary);border:none;padding:.5rem 1rem;border-radius:var(--border-radius-sm);cursor:pointer;font-weight:500;transition:all var(--transition-fast)}.btn-copy:hover{background:var(--gradient-primary-hover)}.code-input{text-align:center;font-size:1.5rem;font-family:Courier New,monospace;letter-spacing:.5rem;width:200px;margin:0 auto}.backup-codes{background:var(--bg-tertiary);border-radius:var(--border-radius);padding:1.5rem;margin:2rem 0;border:1px solid var(--primary-color-20)}.backup-codes h4{color:var(--primary-color);margin-bottom:.5rem;font-size:1.1rem}.backup-codes p{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.backup-codes-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;margin-bottom:1rem}.backup-code{background:var(--bg-secondary);padding:.5rem;border-radius:4px;font-family:Courier New,monospace;text-align:center;color:var(--primary-color);font-size:.9rem}.method-options{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.method-option{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-tertiary);border-radius:var(--border-radius);border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-base);text-align:left}.method-option:hover{background:var(--primary-color-5);border-color:var(--primary-color-30)}.method-option.selected{background:var(--primary-color-10);border-color:var(--primary-color)}.method-icon{font-size:2rem;flex-shrink:0}.method-info{flex:1}.method-info h4{color:var(--text-primary);margin:0 0 .25rem;font-size:1.1rem}.method-info p{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.4}.method-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;margin-top:.5rem}.method-badge.recommended{background:var(--success-color-20);color:var(--success-color)}.email-display{background:var(--bg-tertiary);padding:1rem 1.5rem;border-radius:var(--border-radius);margin:1rem 0;font-size:1.1rem;color:var(--primary-color)}.info-text{font-size:.9rem;color:var(--text-muted)}.resend-text{margin-top:1rem;font-size:.9rem;color:var(--text-secondary)}.resend-text a{color:var(--primary-color)}.back-link{color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.back-link:hover{color:var(--primary-color)}.twofa-status{margin-top:1rem}.twofa-enabled,.twofa-disabled{display:flex;flex-direction:column;gap:1rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;width:fit-content}.status-badge.enabled{background:var(--success-color-20);color:var(--success-color);border:1px solid var(--success-color-30)}.status-badge.disabled{background:var(--secondary-color-20);color:var(--error-color);border:1px solid var(--secondary-color-30)}.twofa-info{font-size:.9rem}.twofa-info p{margin:.25rem 0;color:var(--text-secondary)}.twofa-description{color:var(--text-secondary);font-size:.9rem;margin:0}.twofa-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-danger{background:var(--gradient-danger);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:all .2s ease}.btn-danger:hover{background:var(--gradient-danger-hover);transform:translateY(-1px)}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.warning-box{display:flex;align-items:flex-start;gap:.75rem;background:var(--primary-color-10);border:1px solid var(--primary-color-30);border-radius:var(--border-radius);padding:1rem;color:var(--primary-color)}.warning-box i{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}.warning-box p{margin:0;font-size:.9rem}.error-state{text-align:center;padding:1rem;color:var(--text-secondary)}.error-state p{margin-bottom:.5rem}.code-input{font-size:1.5rem;text-align:center;letter-spacing:.5rem;font-family:Courier New,monospace}.qr-code-image{max-width:200px;height:auto;display:block;margin:0 auto;border-radius:8px}.error-text{color:var(--error-color);text-align:center;padding:1rem}.no-codes{color:var(--text-secondary);text-align:center;padding:1rem}@media(max-width:768px){.modal-container{width:95%;margin:1rem}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.btn-secondary,.btn-primary{width:100%;justify-content:center}.authenticator-apps{grid-template-columns:1fr}.manual-key{flex-direction:column;text-align:center}.backup-codes-list{grid-template-columns:repeat(2,1fr)}.code-input{width:100%;max-width:200px}}.email-verification-banner{background:var(--verification-bg);border:1px solid var(--verification-border);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-lg);overflow:hidden;animation:slideDown .3s ease-out;position:relative}.banner-content{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md)}.banner-icon{font-size:2rem;line-height:1;opacity:.9}.banner-text{flex:1;min-width:0}.banner-text h3{color:var(--primary-color);font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.banner-text p{color:var(--text-secondary);font-size:.9rem;margin:0}.banner-text strong{color:var(--text-primary)}.banner-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-resend{background:var(--gradient-primary);color:var(--bg-primary);border:none;padding:.5rem 1rem;border-radius:var(--border-radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn-resend:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translateY(-1px);box-shadow:0 4px 8px var(--primary-color-30)}.btn-resend:disabled{opacity:.6;cursor:not-allowed;transform:none}.verify-confirm-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:var(--border-radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;box-shadow:0 2px 4px #10b98133}.verify-confirm-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.verify-confirm-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.verification-success-message{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #10b981;border-radius:var(--border-radius-md);margin-bottom:1rem;padding:1rem;animation:slideDown .3s ease-out;transition:opacity .3s ease}.verification-success-message .success-content{display:flex;align-items:center;gap:1rem}.verification-success-message .success-icon{font-size:2rem;line-height:1}.verification-success-message .success-main h3{margin:0 0 .25rem;color:#065f46;font-size:1.1rem;font-weight:600}.verification-success-message .success-main p{margin:0;color:#047857;font-size:.9rem}.verification-success-message .success-close{background:transparent;border:none;color:#059669;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin-left:auto;transition:background .2s ease}.verification-success-message .success-close:hover{background:#10b9811a}.verification-steps{margin:1rem 0}.step-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--border-radius-md);border-left:3px solid var(--primary-color)}.step-number{background:var(--primary-color);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0}.step-content h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1rem;font-weight:600}.step-content p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.4}.email-tips{margin-top:1.5rem;padding:1rem;background:var(--primary-color-10);border:1px solid var(--primary-color);border-radius:var(--border-radius-sm)}.email-tips h4{margin:0 0 .75rem;color:var(--primary-color);font-size:1rem;font-weight:600}.email-tips ul{margin:0;padding-left:1.2rem;color:var(--text-primary)}.email-tips li{margin-bottom:.5rem;font-size:.9rem;line-height:1.4}.email-tips li:last-child{margin-bottom:0}.btn-dismiss{background:transparent;color:var(--text-muted);border:none;font-size:1.2rem;line-height:1;cursor:pointer;padding:.25rem;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-dismiss:hover{background:#ffffff1a;color:var(--text-primary)}.banner-progress{height:3px;background:var(--verification-border);position:relative;overflow:hidden}.banner-progress:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--primary-color);animation:progress 2s ease-in-out infinite}.stat-card.restricted{position:relative;opacity:.7;cursor:not-allowed}.restriction-overlay{position:absolute;top:.5rem;right:.5rem;background:#000c;color:var(--primary-color);padding:.25rem;border-radius:50%;font-size:.8rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;z-index:1}.verify-prompt{color:var(--primary-color);font-size:.9rem;margin-top:.5rem;font-style:italic}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@keyframes progress{0%{left:-100%}50%{left:0}to{left:100%}}@media(max-width:768px){.banner-content{flex-direction:column;text-align:center;gap:var(--spacing-sm)}.banner-actions{width:100%;justify-content:center}.btn-resend{flex:1;max-width:200px}}@media(max-width:480px){.banner-content{padding:var(--spacing-sm)}.banner-text h3{font-size:1rem}.banner-text p{font-size:.8rem}.btn-resend{font-size:.8rem;padding:.4rem .8rem}}.verification-required-state{max-width:600px;margin:2rem auto;text-align:center;padding:2rem;background:var(--card-bg);border-radius:var(--border-radius);border:1px solid var(--border-color)}.verification-required-state .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.8}.verification-required-state h3{color:var(--primary-color);font-size:1.5rem;margin-bottom:1rem}.verification-required-state p{color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.feature-list{text-align:left;max-width:300px;margin:1.5rem auto;color:var(--text-secondary)}.feature-list li{margin-bottom:.5rem;padding-left:.5rem}.verify-instruction{background:var(--primary-color-10);border:1px solid var(--verification-border);border-radius:var(--border-radius-sm);padding:1rem;margin:1.5rem 0;color:var(--text-primary)}.verify-instruction strong{color:var(--primary-color)}.email-highlight{color:var(--primary-color);font-weight:600;font-size:1.1rem;margin:1rem 0}.restricted-btn{opacity:.6;cursor:not-allowed;position:relative}.restricted-btn:hover{background:var(--primary-color);transform:none;box-shadow:none}.library-filters.restricted{opacity:.5;pointer-events:none}.filter-select:disabled,.search-input:disabled{background:#ffffff0d;color:var(--text-muted);cursor:not-allowed}.modal-header h2{display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.verification-required-state{margin:1rem;padding:1.5rem}.verification-required-state .empty-icon{font-size:3rem}.verification-required-state h3{font-size:1.3rem}.feature-list{max-width:100%}}.verification-success-message{background:linear-gradient(135deg,#d4af371a,#d4af370d);border:1px solid rgba(212,175,55,.3);border-radius:12px;padding:16px;margin-bottom:20px;opacity:1;transition:opacity .3s ease}.verification-success-message .success-content{display:flex;align-items:center;gap:12px}.verification-success-message .success-icon{font-size:20px;flex-shrink:0}.verification-success-message .success-text{color:var(--primary-color);font-weight:500;flex:1}.verification-success-message .success-close{background:none;border:none;color:var(--primary-color);opacity:.8;cursor:pointer;font-size:18px;padding:4px;line-height:1;transition:opacity .2s ease}.verification-success-message .success-close:hover{opacity:1}.verification-success-content{text-align:center;padding:20px 0}.success-animation{margin:30px 0}.checkmark-circle{width:80px;height:80px;border-radius:50%;background:var(--gradient-primary);margin:0 auto;display:flex;align-items:center;justify-content:center;animation:checkmarkBounce .6s ease-out}.checkmark{width:30px;height:30px;border:none;border-radius:0;background:transparent;position:relative}.checkmark:after{content:"";display:block;width:6px;height:12px;border:solid white;border-width:0 3px 3px 0;transform:rotate(45deg);position:absolute;top:8px;left:11px;animation:checkmarkDraw .3s ease-out .2s forwards;opacity:0}@keyframes checkmarkBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes checkmarkDraw{to{opacity:1}}.feature-unlock-list{background:var(--primary-color-5);border:1px solid var(--primary-color-20);border-radius:12px;padding:20px;margin:20px 0;text-align:left}.feature-item{display:flex;align-items:center;gap:12px;padding:8px 0;color:var(--text-primary)}.feature-item .feature-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.redirect-info{margin-top:30px;padding:20px;background:var(--bg-tertiary);border-radius:12px;border:1px solid var(--border-color)}.redirect-info p{margin-bottom:15px;color:var(--text-secondary)}.redirect-info #countdown{color:var(--primary-color);font-weight:600}.success-icon{animation:successPulse 2s ease-in-out infinite}@keyframes successPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.auth-logo.error,.auth-logo.error .logo-icon{color:var(--error-color)}.error-actions{text-align:center;padding:20px 0}.error-actions p{margin-bottom:20px;color:var(--text-secondary)}.error-actions .btn-primary{margin-right:10px;margin-bottom:10px}.error-actions .btn-secondary{margin-bottom:10px}@media(max-width:768px){.checkmark-circle{width:60px;height:60px}.checkmark{width:20px;height:20px}.checkmark:after{width:4px;height:8px;border-width:0 2px 2px 0;top:5px;left:7px}.feature-unlock-list{padding:15px}.feature-item{padding:6px 0}.error-actions .btn-primary,.error-actions .btn-secondary{display:block;width:100%;margin:10px 0}}.form-help{display:block;margin-top:4px;font-size:.75rem;color:var(--text-muted);line-height:1.4}.form-group{position:relative}.char-counter{display:block;text-align:right;margin-top:4px;font-size:.75rem;font-family:Courier New,monospace;transition:color .3s ease}.char-counter.warning{color:var(--warning-color)}.char-counter.danger{color:var(--error-color)}.char-counter.success{color:var(--success-color)}.username-input{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;letter-spacing:.025em}.form-input[data-type=email]{border-left:3px solid var(--success-color)}.form-input[data-type=username]{border-left:3px solid var(--accent-color)}.username-display{word-break:break-word;overflow-wrap:break-word;max-width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.navbar .username-display,.header .username-display,.user-info .username-display{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help}.navbar .username-display:hover,.header .username-display:hover,.user-info .username-display:hover{overflow:visible;white-space:normal;word-break:break-all;position:relative;background:#000000e6;padding:6px 10px;border-radius:var(--border-radius-sm);z-index:1000;box-shadow:0 4px 12px var(--shadow-color);border:1px solid var(--border-color);min-width:200px}.username-compact{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.username-compact:hover{overflow:visible;white-space:normal;word-break:break-all}.auth-form .input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;right:12px;color:var(--text-muted);z-index:2;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:1rem;transition:color var(--transition-fast);background:none;border:none;padding:0;line-height:1}.input-icon:hover{color:var(--primary-color)}.login-identifier{position:relative}.login-identifier:before{content:"";position:absolute;left:-2px;top:0;bottom:0;width:2px;background:var(--text-muted);opacity:0;transition:opacity var(--transition-fast)}.login-identifier.has-email:before{background:var(--success-color);opacity:1}.login-identifier.has-username:before{background:var(--accent-color);opacity:1}.form-input.invalid{border-color:var(--error-color);background-color:var(--secondary-color-5)}.form-input.valid{border-color:var(--success-color);background-color:var(--success-color-10)}.field-error{color:var(--error-color);font-size:.75rem;margin-top:4px;display:flex;align-items:center;gap:4px}.field-error:before{content:"⚠️";font-size:.875rem}@media(max-width:768px){.username-display{font-size:.9rem;line-height:1.2}.auth-form .form-input{font-size:16px}.char-counter,.form-help{font-size:.7rem}.navbar .username-display:hover,.header .username-display:hover,.user-info .username-display:hover{min-width:180px;font-size:.85rem}}.username-input:focus{box-shadow:0 0 0 2px #d977061a;border-color:var(--accent-color)}.username-help{position:absolute;top:100%;left:0;right:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:8px 12px;font-size:.75rem;color:var(--text-muted);z-index:10;display:none;animation:slideDown .2s ease}.username-help.show{display:block}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.library-pagination{margin:30px 0;display:flex;flex-direction:column;gap:20px;align-items:center;transition:opacity .3s ease}.library-pagination.loading{opacity:.6;pointer-events:none}.pagination-controls{display:flex;align-items:center;gap:15px;flex-wrap:wrap;justify-content:center}.pagination-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;min-width:80px;justify-content:center}.pagination-btn:hover:not(:disabled){background:var(--accent-color);color:var(--background-color);border-color:var(--accent-color);transform:translateY(-2px)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--card-bg);color:var(--text-muted)}.pagination-numbers{display:flex;align-items:center;gap:5px;flex-wrap:wrap;justify-content:center}.pagination-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.pagination-number:hover:not(:disabled):not(.active){background:var(--accent-color);color:var(--background-color);border-color:var(--accent-color);transform:translateY(-2px)}.pagination-number.active{background:var(--accent-color);color:var(--background-color);border-color:var(--accent-color);font-weight:600}.pagination-number:disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px;font-weight:500}.pagination-info{display:flex;align-items:center;gap:30px;font-size:14px;color:var(--text-muted);flex-wrap:wrap;justify-content:center}.page-info{font-weight:500}.items-per-page{display:flex;align-items:center;gap:10px}.items-per-page label{font-weight:500}.items-per-page select{padding:6px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:border-color .2s ease}.items-per-page select:hover:not(:disabled){border-color:var(--accent-color)}.items-per-page select:disabled{opacity:.5;cursor:not-allowed}.library-stats{margin:10px 0 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.games-count{font-size:14px;color:var(--text-muted);font-weight:500}.igdb-attribution{font-size:12px;color:var(--text-muted)}.igdb-attribution a{color:var(--primary-color);text-decoration:none}.igdb-attribution a:hover{text-decoration:underline}@media(max-width:768px){.library-pagination{margin:20px 0;gap:15px}.pagination-controls{gap:10px}.pagination-btn{padding:8px 12px;font-size:13px;min-width:70px}.pagination-number{width:35px;height:35px;font-size:13px}.pagination-info{gap:20px;flex-direction:column;align-items:center}.items-per-page{gap:8px}.items-per-page select{padding:5px 8px;font-size:13px}}@media(max-width:480px){.pagination-numbers{gap:3px}.pagination-number{width:32px;height:32px;font-size:12px}.pagination-btn{padding:6px 10px;font-size:12px;min-width:60px}.pagination-btn i{font-size:11px}}.library-controls{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);display:flex;gap:var(--spacing-lg);align-items:center;flex-wrap:wrap;justify-content:flex-end}.sort-section{display:flex;align-items:center;gap:12px;flex-shrink:0}.sort-label{color:var(--text-primary);font-weight:500;display:flex;align-items:center;gap:8px;margin:0}.sort-select{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:16px;cursor:pointer;transition:all var(--transition-base)}.sort-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.filter-section{display:flex;align-items:center;gap:12px;flex-shrink:0}.filter-label{color:var(--text-primary);font-weight:500;display:flex;align-items:center;gap:8px;margin:0}.filter-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:16px;width:250px;transition:all var(--transition-base)}.filter-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.filter-input::placeholder{color:var(--text-muted)}.year-filter-container{display:flex;align-items:center;gap:8px}.year-filter-select{min-width:130px}.year-filter-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:16px;width:100px;transition:all var(--transition-base)}.year-filter-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.year-filter-input::placeholder{color:var(--text-muted)}@media(max-width:768px){.library-controls{justify-content:center;flex-direction:column;gap:var(--spacing-md)}.filter-section,.sort-section{flex-direction:column;align-items:center;gap:8px}.filter-input{width:100%;max-width:300px}}.searchable-select{position:relative;width:250px}.searchable-select-trigger{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px;transition:all var(--transition-base);-webkit-user-select:none;user-select:none}.searchable-select-trigger:hover{border-color:var(--primary-color);background:var(--bg-secondary)}.searchable-select.open .searchable-select-trigger{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.searchable-select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.searchable-select-arrow{font-size:12px;transition:transform var(--transition-base)}.searchable-select.open .searchable-select-arrow{transform:rotate(180deg)}.searchable-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:0 4px 12px #0003;z-index:1000;display:none;max-height:350px;overflow:hidden;flex-direction:column}.searchable-select-dropdown.open{display:flex}.searchable-select-search{padding:12px;border-bottom:1px solid var(--border-color)}.searchable-select-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;outline:none;transition:all var(--transition-base)}.searchable-select-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color-10)}.searchable-select-input::placeholder{color:var(--text-muted)}.searchable-select-input.loading{background-image:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.searchable-select-options{overflow-y:auto;overflow-x:hidden;max-height:280px}.searchable-select-option{padding:10px 16px;cursor:pointer;transition:all var(--transition-base);color:var(--text-primary);-webkit-user-select:none;user-select:none}.searchable-select-option:hover{background:var(--bg-tertiary)}.searchable-select-option.selected{background:var(--primary-color);color:#fff;font-weight:500}.searchable-select-option.selected:hover{background:#d97706}.searchable-select-options::-webkit-scrollbar{width:8px}.searchable-select-options::-webkit-scrollbar-track{background:var(--bg-tertiary)}.searchable-select-options::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}.searchable-select-options::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.multi-select-genres .multi-select-option{display:flex;align-items:center;gap:10px;padding:8px 16px}.multi-select-genres .multi-select-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color);flex-shrink:0}.multi-select-genres .multi-select-option.selected{background:var(--primary-color-10);color:var(--text-primary)}.multi-select-genres .multi-select-option.selected:hover{background:var(--primary-color-20)}.multi-select-actions{padding:8px 16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:flex-end}.multi-select-clear-btn{background:transparent;color:var(--danger-color);border:1px solid var(--danger-color);padding:6px 12px;border-radius:var(--border-radius-sm);font-size:14px;cursor:pointer;transition:all var(--transition-base)}.multi-select-clear-btn:hover{background:var(--danger-color);color:#fff}@media(max-width:768px){.searchable-select{width:100%;max-width:300px}.searchable-select-dropdown{max-height:300px}.searchable-select-options{max-height:230px}}.discovery-page .discovery-filters{margin-bottom:20px}.discovery-page .discovery-filters .filters-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;align-items:flex-start}.discovery-page .discovery-filters .search-box{flex:1;min-width:250px}.discovery-page .discovery-filters .search-input{width:100%;padding:10px 16px;border-radius:8px;border:1px solid var(--border-color, rgba(255, 255, 255, .1));background:var(--bg-tertiary);color:var(--text-primary);font-size:.95rem;height:42px;box-sizing:border-box}.discovery-page .discovery-filters .search-input:focus{outline:none;border-color:var(--primary-color)}.discovery-page .discovery-filters .filter-container{flex:1 1 auto;min-width:200px}.discovery-page .discovery-filters .sort-filter-container{display:flex;align-items:center;gap:8px;flex:0 0 auto}.discovery-page .discovery-filters .sort-label{color:var(--text-muted);font-size:.875rem;white-space:nowrap}.discovery-page .discovery-filters .searchable-select{flex:1 1 180px;min-width:180px}.discovery-page .discovery-filters .searchable-select-trigger{height:42px;box-sizing:border-box}.discovery-page .discovery-filters .year-select{flex:1 1 100px;min-width:100px}.discovery-page .discovery-filters .platform-select{flex:1 1 140px;min-width:140px}.discovery-page .discovery-filters .sort-filter-dropdown{flex:1 1 200px;min-width:200px}.discovery-page .discovery-filters .sort-filter-container{flex:1 1 auto;min-width:200px}.discovery-page .discovery-filters .checkbox-filter-container{flex:0 0 auto;display:flex;align-items:center}.checkbox-filter{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color);transition:background-color .2s,border-color .2s;white-space:nowrap}.checkbox-filter:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.checkbox-filter input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-color)}.checkbox-filter-label{font-size:.875rem;color:var(--text-secondary)}.checkbox-filter input[type=checkbox]:checked+.checkbox-filter-label{color:var(--text-primary)}.discovery-page .discovery-filters .year-custom-input-container{padding:8px 12px;border-top:1px solid var(--border-color)}.discovery-page .discovery-filters .year-custom-input{width:100%;padding:8px 12px}.discovery-page .multi-select-option{display:flex;align-items:center;gap:10px;padding:8px 16px}.discovery-page .multi-select-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color);flex-shrink:0}.discovery-page .multi-select-option.selected{background:var(--primary-color-10);color:var(--text-primary)}.discovery-page .multi-select-option.selected:hover{background:var(--primary-color-20)}.discovery-page .loading-state,.library .loading-state{grid-column:1 / -1;text-align:center;padding:60px 20px}.discovery-page .loading-state .spinner,.library .loading-state .spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.page-loading{display:flex;justify-content:center;align-items:center;min-height:60vh}.page-loading .spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.loading-state{text-align:center;padding:20px}.loading-state .spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 12px}.loading-state p{color:var(--text-secondary);margin:0;font-size:.875rem}@media(max-width:768px){.discovery-page .discovery-filters .filters-row{flex-direction:column}.discovery-page .discovery-filters .search-box{min-width:100%}.discovery-page .discovery-filters .filter-container{width:100%;min-width:100%}.discovery-page .discovery-filters .searchable-select,.discovery-page .discovery-filters .year-select,.discovery-page .discovery-filters .platform-select,.discovery-page .discovery-filters .sort-filter-dropdown{min-width:100%;max-width:100%}.discovery-page .discovery-filters .sort-filter-container{width:100%;flex-direction:column;align-items:stretch}.discovery-page .discovery-filters .checkbox-filter-container{width:100%}.checkbox-filter{width:100%;justify-content:flex-start}}.filters-row-search{display:flex;align-items:center;gap:12px}.filters-row-search .search-box{flex:1}.btn-filter-toggle{display:none;align-items:center;gap:8px;padding:10px 16px;height:42px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-filter-toggle:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--text-primary)}.btn-filter-toggle i.fa-filter{color:var(--primary-color)}.filter-toggle-arrow{font-size:.75rem;transition:transform var(--transition-base)}.filter-toggle-arrow.rotated{transform:rotate(180deg)}.filters-collapsible{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;align-items:flex-start;overflow:visible;position:relative;z-index:10}.filters-collapsible.collapsed{opacity:1;margin-bottom:12px;pointer-events:auto}@media(max-width:1760px){.btn-filter-toggle{display:flex}.filters-collapsible.collapsed{opacity:0;margin-bottom:0;pointer-events:none;visibility:hidden;height:0}}@media(max-width:768px){.filters-row-search{flex-direction:row;flex-wrap:nowrap}.filters-row-search .search-box{flex:1;min-width:0}.btn-filter-toggle{flex-shrink:0}.filters-collapsible{flex-direction:column}}.filter-action-buttons{display:flex;gap:8px;width:100%;justify-content:flex-end;margin-top:4px}.btn-apply-filters,.btn-reset-filters{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;outline:none}.btn-apply-filters{background:var(--gradient-primary);color:var(--bg-primary)}.btn-apply-filters:hover{background:var(--gradient-primary-hover);color:var(--bg-primary);transform:translateY(-2px);box-shadow:0 4px 16px var(--primary-color-30)}.btn-apply-filters:active{transform:translateY(0)}.btn-reset-filters{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-reset-filters:hover{background:var(--btn-secondary-hover-bg);color:var(--primary-color);transform:translateY(-1px)}@media(max-width:768px){.filter-action-buttons{flex-direction:column}.btn-apply-filters,.btn-reset-filters{width:100%;text-align:center}}.game-detail-modal-overlay{position:fixed;inset:0;background:#0000;z-index:1000;display:flex;align-items:flex-end;justify-content:center;transition:background .3s ease}.game-detail-modal-overlay.active{background:#000000b3}.game-detail-modal{width:100%;max-width:800px;max-height:90vh;background:var(--bg-secondary);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;overflow:hidden;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1)}.game-detail-modal.active{transform:translateY(0)}.game-modal-actions{position:absolute;top:var(--spacing-md);right:var(--spacing-md);display:flex;gap:var(--spacing-sm);z-index:10}.game-modal-close{background:#00000080;border:none;color:var(--secondary-color);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all var(--transition-fast)}.game-modal-close:hover{background:#000000b3;color:#ff6b6b;transform:scale(1.1)}.game-modal-wishlist{background:#00000080;border:none;color:gold;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.game-modal-wishlist:hover{background:#000000b3;transform:scale(1.1)}.game-modal-wishlist.active{color:gold}.game-modal-wishlist.loading{opacity:.5;pointer-events:none}.game-modal-share{background:#00000080;border:none;color:var(--secondary-color);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.game-modal-share:hover{background:#000000b3;color:var(--accent-color);transform:scale(1.1)}.game-modal-share.copied{background:#000000b3;transform:scale(1.1)}.wishlist-confirm-modal{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease}.wishlist-confirm-content{background:var(--bg-secondary);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);max-width:320px;text-align:center;box-shadow:0 8px 32px #0006}.wishlist-confirm-content h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1.2rem}.wishlist-confirm-content p{margin:0 0 var(--spacing-lg) 0;color:var(--text-secondary);font-size:.95rem}.wishlist-confirm-actions{display:flex;gap:var(--spacing-md);justify-content:center}.wishlist-confirm-actions button{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary{background:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-secondary:hover{background:var(--btn-secondary-hover-bg)}.btn-danger{background:var(--secondary-color);border:none;color:#fff}.btn-danger:hover{filter:brightness(1.1)}.wishlist-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--bg-secondary);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius-lg);box-shadow:0 4px 20px #0000004d;display:flex;align-items:center;gap:var(--spacing-sm);z-index:9999;animation:slideUp .3s ease}.wishlist-toast.success{border-left:3px solid var(--primary-color)}.wishlist-toast.success svg{color:var(--primary-color)}.wishlist-toast.error{border-left:3px solid var(--secondary-color)}.wishlist-toast.fade-out{animation:fadeOut .3s ease forwards}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.game-modal-header{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);padding-right:60px;align-items:center;background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.game-modal-cover{flex-shrink:0;width:80px;border-radius:var(--border-radius);overflow:hidden;box-shadow:0 4px 16px #0000004d}.game-modal-cover img{width:100%;height:auto;display:block}.game-modal-title-section{flex:1;min-width:0}.game-modal-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 4px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.game-modal-developer{font-size:.9rem;color:var(--text-muted)}.game-modal-rating{display:flex;gap:2px;margin-top:4px}.game-modal-rating .rating-star{color:var(--text-muted)}.game-modal-rating .rating-star.filled{color:var(--star-color);fill:var(--star-color)}.game-modal-video{background:#000}.game-modal-video .video-container{position:relative;width:100%;padding-bottom:56.25%;background:#000}.game-modal-video .video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.game-modal-video.no-video{display:flex;justify-content:center;padding:var(--spacing-md);background:var(--bg-tertiary)}.game-modal-cover-large{max-width:300px;border-radius:var(--border-radius);overflow:hidden;box-shadow:0 4px 16px #0000004d}.game-modal-cover-large img{width:100%;height:auto;display:block}.game-modal-subtitle{text-align:center;padding:var(--spacing-md);font-size:.85rem;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.game-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.game-modal-accordion{background:var(--bg-primary);border-radius:var(--border-radius);margin-bottom:var(--spacing-md);overflow:hidden;border:1px solid var(--border-color)}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.accordion-header:hover{background:#ffffff0d}.accordion-title{font-size:1rem;font-weight:600}.accordion-icon{font-size:.85rem;transition:transform var(--transition-base)}.accordion-content{max-height:0;overflow:hidden;transition:max-height var(--transition-base)}.accordion-content.expanded{max-height:2000px}.accordion-content.expanded~.accordion-header .accordion-icon,.game-modal-accordion:has(.accordion-content.expanded) .accordion-icon{transform:rotate(180deg)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);padding:0 var(--spacing-lg) var(--spacing-lg)}.info-item{display:flex;flex-direction:column;gap:4px}.info-item.info-full{grid-column:1 / -1}.info-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:.9rem;color:var(--text-primary);line-height:1.4}.info-summary{margin:0;font-size:.85rem;line-height:1.6;color:var(--text-secondary)}@media(max-width:768px){.game-detail-modal{max-height:95vh}.game-modal-header{padding:var(--spacing-md);padding-right:50px}.game-modal-cover{width:60px}.game-modal-title{font-size:1.1rem}.game-modal-developer{font-size:.8rem}.info-grid{grid-template-columns:1fr;padding:0 var(--spacing-md) var(--spacing-md)}.accordion-header{padding:var(--spacing-sm) var(--spacing-md)}}.platforms-section-content{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg)}.platforms-badges-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.platform-badge{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;border:2px solid var(--platform-color);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.platform-badge:hover{background:#ffffff0d;color:var(--text-primary)}.platform-badge.selected{background:var(--platform-color);color:#fff}.platform-badge-name{white-space:nowrap}.platform-badge-time{font-size:.75rem;opacity:.7}.platform-badge.selected .platform-badge-time{opacity:.9}.platforms-info-panels{min-height:60px}.platform-info-panel{display:none;animation:fadeIn .2s ease}.platform-info-panel.active{display:block}.platform-info-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px;margin-bottom:12px}.platform-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:16px 12px;background:#ffffff0d;border-radius:12px;border:1px solid var(--border-color)}.platform-stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-color);line-height:1}.platform-stat-label{font-size:.75rem;color:var(--text-primary);margin-top:6px;font-weight:500}.platform-info-actions{display:flex;flex-wrap:wrap;gap:8px}.btn-platform-action{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;border:none;background:var(--gradient-primary);color:var(--bg-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-platform-action:hover{background:var(--gradient-primary-hover);color:var(--bg-primary);transform:translateY(-2px);box-shadow:0 4px 16px var(--primary-color-30)}.btn-platform-action i{font-size:.9rem}.btn-platform-action.btn-in-library{background:var(--success-color-15);border:1px solid var(--success-color-light);color:var(--success-color-light);font-weight:500;cursor:default}.btn-platform-action.btn-in-library:hover{background:var(--success-color-15);color:var(--success-color-light);transform:none;box-shadow:none}.btn-platform-action.btn-in-library i{color:var(--success-color-light)}.duration-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px;padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg)}.duration-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:16px 12px;background:#ffffff0d;border-radius:12px;border:1px solid var(--border-color)}.duration-stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-color);line-height:1}.duration-stat-label{font-size:.75rem;color:var(--text-primary);margin-top:6px;font-weight:500}.external-links-list{display:flex;flex-direction:column;gap:10px;padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg)}.external-links-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px;font-size:.9rem;line-height:1.5}.external-links-label{color:var(--text-secondary)}.external-links-values{color:var(--text-primary)}.external-link-text{color:var(--primary-color);text-decoration:none;transition:opacity .2s ease}.external-link-text:hover{text-decoration:underline;opacity:.8}.prompt-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1200;animation:fadeIn .2s ease;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.prompt-modal.show{opacity:1;visibility:visible}.prompt-modal-content{background:var(--bg-secondary);border-radius:16px;padding:24px;width:90%;max-width:380px;box-shadow:0 20px 40px #0006;transform:translateY(20px);transition:transform .2s ease}.prompt-modal.show .prompt-modal-content{transform:translateY(0)}.prompt-modal-header{text-align:center;margin-bottom:20px}.prompt-modal-header h3{font-size:1.25rem;font-weight:600;margin:0 0 8px;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.prompt-modal-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.prompt-modal-body{margin-bottom:24px}.prompt-modal-benefits{display:flex;flex-direction:column;gap:12px}.prompt-modal-benefit{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff08;border-radius:8px;border:1px solid var(--border-color)}.prompt-modal-benefit-icon{font-size:1.25rem;flex-shrink:0}.prompt-modal-benefit-text{color:var(--text-primary);font-size:.9rem}.prompt-modal-actions{display:flex;gap:12px;justify-content:flex-end}.prompt-modal-actions .btn-primary:disabled,.prompt-modal-actions .btn-secondary:disabled,.prompt-modal-actions .btn-danger:disabled{opacity:.6;cursor:not-allowed}.prompt-modal-danger{border:1px solid var(--secondary-color-30)}.prompt-modal-icon-danger,.prompt-modal-icon-info{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.5rem}.prompt-modal-icon-danger{background:var(--secondary-color-10);color:var(--error-color)}.prompt-modal-icon-info{background:var(--primary-color-10);color:var(--primary-color)}.prompt-modal-warning-box,.prompt-modal-info-box{background:#ffffff08;border-radius:var(--border-radius-sm);padding:16px;margin-bottom:16px;text-align:center}.prompt-modal-warning-box{border:1px solid var(--secondary-color-20)}.prompt-modal-info-box{border:1px solid var(--border-color)}.prompt-modal-warning-box p,.prompt-modal-info-box p{margin:0 0 8px;color:var(--text-secondary);font-size:.9rem}.prompt-modal-warning-box p:last-child,.prompt-modal-info-box p:last-child{margin-bottom:0}.prompt-modal-email{color:var(--text-primary)!important;font-size:1rem!important;word-break:break-all}.prompt-modal-warning-text{color:var(--star-color)!important;margin-top:12px!important}.prompt-modal-warning-text i{margin-right:6px}.prompt-modal-form-group{margin-bottom:0}.prompt-modal-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.prompt-modal-input{width:100%;padding:12px 14px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.95rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.prompt-modal-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-20)}.prompt-modal-input::placeholder{color:var(--text-muted)}.playtime-modal{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}.playtime-modal-content{background:var(--bg-secondary);border-radius:16px;padding:24px;width:90%;max-width:340px;box-shadow:0 20px 40px #0006}.playtime-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.playtime-modal-header h3{font-size:1.1rem;font-weight:600;margin:0;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.playtime-platform-badge{padding:4px 10px;border-radius:6px;color:#fff;font-size:.75rem;font-weight:500}.playtime-game-title{font-size:.9rem;color:var(--text-secondary);margin:0 0 20px;line-height:1.4}.playtime-form{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.playtime-field{display:flex;flex-direction:column;gap:6px}.playtime-field label{font-size:.8rem;font-weight:500;color:var(--text-muted)}.playtime-field input[type=date],.playtime-field input[type=number]{padding:10px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;transition:border-color .2s ease}.playtime-field input[type=date]:focus,.playtime-field input[type=number]:focus{outline:none;border-color:var(--primary-color)}.playtime-time-input{display:flex;gap:16px}.playtime-time-group{display:flex;flex-direction:column;gap:4px;flex:1}.playtime-time-group input{width:100%;text-align:center}.playtime-time-label{font-size:.75rem;color:var(--text-muted);text-align:center}.playtime-form.form-disabled{opacity:.5;pointer-events:none}.playtime-form.form-disabled input:disabled{background:var(--bg-tertiary);cursor:not-allowed}.playtime-modal-actions{display:flex;gap:12px;justify-content:flex-end}.playtime-modal-actions .btn-primary:disabled,.playtime-modal-actions .btn-secondary:disabled{opacity:.6;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.session-start-section{display:flex;flex-direction:column;align-items:center;padding:16px 0}.btn-session-start{display:flex;align-items:center;gap:10px;padding:14px 28px;border-radius:12px;border:2px solid var(--primary-color);background:var(--primary-color-10);color:var(--primary-color);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-session-start:hover{background:var(--primary-color-20);transform:scale(1.02)}.btn-session-start i{font-size:1.1rem}.session-hint{font-size:.75rem;color:var(--text-muted);margin:10px 0 0}.session-active-section{display:flex;flex-direction:column;align-items:center;padding:20px 0;background:var(--success-color-10);border-radius:12px;border:1px solid var(--success-color-30);margin-bottom:8px}.session-timer{display:flex;align-items:center;gap:12px;color:var(--success-color-light)}.session-timer i{font-size:1.5rem;animation:pulse 2s ease-in-out infinite}.session-elapsed{font-size:2rem;font-weight:700;font-variant-numeric:tabular-nums}.session-status{font-size:.8rem;color:var(--text-muted);margin:8px 0 16px}.session-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.session-actions .btn-danger{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;border:none;background:var(--error-color);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.session-actions .btn-danger:hover{background:var(--secondary-color-hover)}.session-actions .btn-small{padding:8px 14px;font-size:.8rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.session-warning-section{display:flex;flex-direction:column;align-items:center;padding:16px;background:var(--warning-color-10);border-radius:12px;border:1px solid var(--warning-color-30);margin-bottom:8px}.session-warning{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--star-color);margin:0 0 12px}.session-warning i{font-size:1rem}.session-divider{display:flex;align-items:center;margin:16px 0}.session-divider:before,.session-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.session-divider span{padding:0 12px;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.session-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);animation:slideDownBanner .3s ease}.session-banner-content{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;max-width:1200px;margin:0 auto}.session-banner-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.session-banner-icon{font-size:1.5rem;color:var(--success-color);animation:pulse 2s ease-in-out infinite}.session-banner-text{display:flex;flex-direction:column;gap:2px;min-width:0}.session-banner-text strong{font-size:.9rem;color:var(--text-primary)}.session-banner-game{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-banner-time{font-size:1.25rem;font-weight:700;color:var(--primary-color);font-variant-numeric:tabular-nums;margin-left:auto;padding:0 16px}.session-banner-actions{display:flex;gap:8px;flex-shrink:0}.btn-session-complete{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:none;background:var(--gradient-primary);color:var(--bg-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-session-complete:hover{background:var(--gradient-primary-hover)}.btn-session-cancel{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:2px solid var(--primary-color);background:transparent;color:var(--primary-color);font-size:.85rem;cursor:pointer;transition:all .2s ease}.btn-session-cancel:hover{background:var(--btn-secondary-hover-bg);color:var(--primary-color)}@keyframes slideDownBanner{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){.session-banner-content{flex-wrap:wrap;gap:12px;padding:10px 16px}.session-banner-info{width:100%}.session-banner-time{margin-left:0;padding:0}.session-banner-actions{width:100%;justify-content:stretch}.btn-session-complete,.btn-session-cancel{flex:1;justify-content:center}}.completion-modal{position:absolute;inset:0;background:#000000b3;display:flex;align-items:flex-start;justify-content:center;z-index:1100;animation:fadeIn .2s ease;overflow-y:auto;padding:20px 0}.completion-modal-content{background:var(--bg-secondary);border-radius:16px;padding:24px;width:90%;max-width:420px;box-shadow:0 20px 40px #0006;margin:auto}.completion-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.completion-modal-header h3{font-size:1.1rem;font-weight:600;margin:0;background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.completion-platform-badge{padding:4px 10px;border-radius:6px;color:#fff;font-size:.75rem;font-weight:500}.completion-game-title{font-size:.9rem;color:var(--text-secondary);margin:0 0 20px;line-height:1.4}.completion-form{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.completion-section{display:flex;flex-direction:column;gap:10px}.completion-label{font-size:.85rem;font-weight:600;color:var(--text-primary)}.completion-status-select{width:100%;padding:12px 36px 12px 16px;border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all var(--transition-base);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.completion-status-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-10)}.completion-status-select option{background:var(--bg-tertiary);color:var(--text-primary);padding:8px}.completion-hours-input{display:flex;align-items:center;gap:8px}.completion-hours-input input{padding:10px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;width:100px;transition:border-color .2s ease}.completion-hours-input input:focus{outline:none;border-color:var(--primary-color)}.completion-hours-suffix{color:var(--text-muted);font-size:.9rem}.completion-hours-hint{font-size:.75rem;color:var(--text-muted)}.rating-container{display:flex;flex-direction:column;gap:8px}.star-rating{display:flex;justify-content:space-between;max-width:240px;gap:8px}.star-btn{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-muted);transition:all .15s ease}.star-btn:hover{transform:scale(1.15)}.star-btn.filled{color:var(--star-color)}.star-btn svg{display:block}.rating-labels{display:flex;max-width:240px;font-size:.7rem;color:var(--text-muted);margin-top:4px}.rating-label-1{flex:1;text-align:left}.rating-label-3{flex:1;text-align:center}.rating-label-5{flex:1;text-align:right}.emotions-grid{display:flex;flex-wrap:wrap;gap:8px}.emotion-btn{padding:8px 14px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.emotion-btn:hover{border-color:var(--primary-color);color:var(--text-primary)}.emotion-btn.selected{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb, 99, 102, 241),.15);color:var(--primary-color);font-weight:500}.completion-modal-actions{display:flex;gap:12px;justify-content:flex-end}.completion-modal-actions .btn-primary:disabled,.completion-modal-actions .btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.completion-modal-content{padding:20px;width:95%}.completion-status-btn{padding:10px 14px;font-size:.85rem}.star-btn svg{width:28px;height:28px}.emotion-btn{padding:6px 12px;font-size:.75rem}}@media(max-width:480px){.platforms-section-content{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md)}.platforms-badges-row{gap:6px}.platform-badge{padding:6px 12px;font-size:.8rem}.platform-info-stats{gap:8px}.platform-stat{padding:12px 8px}.platform-stat-value{font-size:1.25rem}.btn-platform-action{padding:8px 12px;font-size:.8rem}.playtime-modal-content{padding:20px;width:95%}}.settings-grid{display:grid;gap:20px;grid-template-columns:1fr}@media(min-width:768px){.settings-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.settings-grid{grid-template-columns:repeat(3,1fr)}}.settings-card{background:var(--card-bg);border-radius:12px;padding:24px;box-shadow:0 2px 12px #0000004d;border:1px solid var(--border-color);text-align:center}.settings-card h3{margin:0 0 12px;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:8px}.settings-card p{color:#666;margin:0 0 20px;font-size:14px}.profile-settings{text-align:left}.profile-info{display:flex;flex-direction:column;gap:16px}.profile-field{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.profile-field label{font-weight:600;color:var(--text-secondary);min-width:80px}.profile-value{color:var(--text-primary);flex:1}.username-change-form{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.username-change-form .form-group{margin-bottom:16px;text-align:left}.username-change-form label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-primary)}.username-change-form .form-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:14px}.username-change-form .form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #f59e0b1a}.form-hint{display:block;margin-top:4px;font-size:12px;color:var(--text-muted)}.username-change-form .form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.settings-card.danger-zone{border:1px solid var(--secondary-color-30);background:var(--secondary-color-5)}.settings-card.danger-zone h3,.settings-card.danger-zone h3 i{color:var(--error-color)}.danger-warning{background:var(--secondary-color-10);border:1px solid var(--secondary-color-20);border-radius:var(--border-radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.danger-warning i{color:var(--error-color);font-size:1.5rem;margin-bottom:var(--spacing-sm);display:block}.danger-warning p{color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.danger-warning ul{margin:var(--spacing-sm) 0;padding-left:var(--spacing-lg);color:var(--text-muted)}.danger-warning ul li{margin-bottom:var(--spacing-xs)}#delete-account-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md)}.modal-header.danger{border-bottom:1px solid var(--secondary-color-20)}.modal-header.danger h2{color:var(--error-color)}.modal-header.danger h2 i{margin-right:var(--spacing-sm)}.danger-warning-modal{background:var(--secondary-color-10);border:1px solid var(--secondary-color-20);border-radius:var(--border-radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-md);text-align:center}.danger-warning-modal .account-email{color:var(--primary-color);font-size:1.1rem;margin:var(--spacing-sm) 0}.email-sent-message{text-align:center;padding:var(--spacing-md) 0}.email-sent-message .email-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.email-sent-message .account-email{color:var(--primary-color);font-size:1.1rem;margin:var(--spacing-sm) 0}.email-sent-message .warning-text{color:var(--warning-color);margin-top:var(--spacing-md);font-size:.9rem}.auth-card.deletion-confirmation{max-width:500px}.auth-logo.danger .logo-icon,.auth-logo.danger h1{color:var(--error-color)}.deletion-warning-box{background:var(--secondary-color-10);border:1px solid var(--secondary-color-30);border-radius:var(--border-radius);padding:var(--spacing-lg);margin:var(--spacing-lg) 0;display:flex;gap:var(--spacing-md);text-align:left}.deletion-warning-box>i{color:var(--error-color);font-size:1.5rem;flex-shrink:0}.deletion-warning-box p{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}.deletion-warning-box ul{margin:var(--spacing-sm) 0 0;padding-left:var(--spacing-lg);color:var(--text-muted)}.deletion-warning-box ul li{margin-bottom:var(--spacing-xs)}.deletion-actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.deletion-actions .btn-large{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem;justify-content:center}.deletion-actions .btn-secondary{background:#6464644d}.goodbye-message{text-align:center;padding:var(--spacing-lg);color:var(--text-muted)}.goodbye-message p{margin-bottom:var(--spacing-sm)}.auth-logo.success .logo-icon{color:var(--success-color)}.btn-large{padding:var(--spacing-md) var(--spacing-xl);font-size:1rem}@media(max-width:480px){.deletion-warning-box{flex-direction:column;text-align:center}.deletion-warning-box>i{margin-bottom:var(--spacing-sm)}.deletion-warning-box ul{text-align:left}.deletion-actions{gap:var(--spacing-sm)}.deletion-actions .btn-large{padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem}}.legal-page{max-width:800px;margin:0 auto;padding:var(--spacing-lg) var(--spacing-md)}.legal-header{margin-bottom:var(--spacing-xl)}.legal-back-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--primary-color);text-decoration:none;margin-bottom:var(--spacing-md);font-size:.9rem}.legal-back-link:hover{text-decoration:underline}.legal-updated{color:var(--text-muted);font-size:.85rem;margin-top:var(--spacing-xs)}.legal-content section{margin-bottom:var(--spacing-xl)}.legal-content h2{color:var(--text-primary);font-size:1.25rem;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-color)}.legal-content p{color:var(--text-secondary);line-height:1.7}.legal-links{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.legal-links a{text-decoration:none}.form-checkbox a{color:var(--primary-color);text-decoration:underline}.form-checkbox a:hover{color:var(--primary-hover)}.premium-page{padding:var(--spacing-xl);max-width:900px;margin:0 auto}.premium-back-link{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--text-muted);text-decoration:none;margin-bottom:var(--spacing-lg);transition:color var(--transition-fast)}.premium-back-link:hover{color:var(--primary-color)}.premium-hero{text-align:center;margin-bottom:var(--spacing-xl)}.premium-hero h1{font-size:2rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm)}.premium-hero-subtitle{color:var(--text-muted);font-size:1.1rem}.premium-subscriber-hero{text-align:center;margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);background:var(--card-bg);border:1px solid var(--primary-color-20);border-radius:var(--border-radius-lg)}.premium-subscriber-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.premium-subscriber-hero h1{color:var(--primary-color);margin-bottom:var(--spacing-sm)}.premium-subscriber-text{color:var(--text-muted);margin-bottom:var(--spacing-lg)}.premium-manage-btn{display:inline-block;text-decoration:none}.premium-benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.premium-benefit-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-lg);text-align:center;transition:border-color var(--transition-base)}.premium-benefit-card:hover{border-color:var(--primary-color-50)}.benefit-icon{font-size:2.5rem;margin-bottom:var(--spacing-md)}.premium-benefit-card h3{color:var(--text-primary);margin-bottom:var(--spacing-sm);font-size:1.1rem}.premium-benefit-card p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.premium-section-title{text-align:center;color:var(--text-primary);margin-bottom:var(--spacing-lg);font-size:1.5rem}.premium-pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);max-width:600px;margin-left:auto;margin-right:auto}.pricing-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);text-align:center;position:relative;transition:border-color var(--transition-base),transform var(--transition-base)}.pricing-card:hover{border-color:var(--primary-color-50);transform:translateY(-2px)}.pricing-card-recommended{border-color:var(--primary-color);box-shadow:0 0 20px var(--primary-color-20)}.pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--gradient-primary);color:#fff;padding:4px 16px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap}.pricing-card-header h3{color:var(--text-primary);margin-bottom:var(--spacing-md)}.pricing-card-price{margin-bottom:var(--spacing-md)}.price-amount{font-size:2.5rem;font-weight:700;color:var(--primary-color)}.price-period{color:var(--text-muted);font-size:.9rem}.pricing-card-savings{color:var(--success-color);font-size:.85rem;font-weight:600;margin-bottom:var(--spacing-md)}.pricing-subscribe-btn{width:100%}.premium-auto-renewal{text-align:center;margin-top:var(--spacing-md)}.premium-toggle-label{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--text-primary);cursor:pointer}.premium-auto-renewal-hint{color:var(--text-muted);font-size:.8rem;margin-top:var(--spacing-xs)}.stats-page{padding:var(--spacing-xl);max-width:1200px;margin:0 auto}.stats-loading{text-align:center;padding:var(--spacing-xl) 0}.stats-loading .spinner{margin:0 auto var(--spacing-md)}.stats-error{text-align:center;padding:var(--spacing-xl) 0}.stats-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.stats-charts-grid .chart-container{min-height:300px}.chart-wrapper{position:relative;height:250px}.chart-empty{color:var(--text-muted);text-align:center;font-style:italic;padding:var(--spacing-xl) 0}.premium-gate{text-align:center;padding:var(--spacing-xl);background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);max-width:500px;margin:var(--spacing-xl) auto}.premium-gate-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.premium-gate h2{color:var(--text-primary);margin-bottom:var(--spacing-sm)}.premium-gate p{color:var(--text-muted);margin-bottom:var(--spacing-lg)}.premium-gate-features{list-style:none;padding:0;margin-bottom:var(--spacing-lg);text-align:left;display:inline-block}.premium-gate-features li{color:var(--text-secondary);padding:var(--spacing-xs) 0}.premium-gate-features li:before{content:"•";color:var(--primary-color);font-weight:700;margin-right:var(--spacing-sm)}.premium-gate-btn{display:inline-block;text-decoration:none}.settings-card-premium h3 i,.settings-card-referral h3 i{color:var(--primary-color)}.subscription-info{display:grid;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);text-align:left}.subscription-detail{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--primary-color-10)}.subscription-detail:last-child{border-bottom:none}.sub-label{color:var(--text-muted);font-size:.9rem}.sub-value{color:var(--text-primary);font-weight:500}.sub-status.status-active{color:var(--success-color)}.sub-status.status-cancelled{color:var(--warning-color)}.sub-status.status-expired{color:var(--error-color)}.subscription-actions{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--primary-color-20);border-radius:24px;transition:var(--transition-base)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:var(--text-muted);border-radius:50%;transition:var(--transition-base)}.toggle-switch input:checked+.toggle-slider{background:var(--primary-color)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px);background:#fff}.premium-settings-cta{margin-top:var(--spacing-sm)}.premium-settings-cta p{margin-bottom:var(--spacing-md)}.referral-banner{background:linear-gradient(135deg,#8b5cf626,#3b82f626);border:1px solid rgba(139,92,246,.3);border-radius:var(--border-radius);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);text-align:center;color:var(--text-primary);font-size:.9rem;line-height:1.4}.referral-widget{text-align:left}.referral-info-text{margin-bottom:var(--spacing-md)}.referral-info-text p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.referral-link-box{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.referral-link-input{flex:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);font-size:.85rem;cursor:text}.referral-expires{color:var(--text-muted);font-size:.8rem;margin-bottom:var(--spacing-md)}.referral-stats{padding-top:var(--spacing-sm);border-top:1px solid var(--primary-color-10);margin-top:var(--spacing-md);text-align:center}.referral-stat-inline{font-size:.85rem;color:var(--text-muted)}.referral-stat-inline strong{color:var(--primary-color);font-weight:600}@media(max-width:768px){.premium-page{padding:var(--spacing-md)}.premium-hero h1{font-size:1.5rem}.premium-benefits-grid,.premium-pricing-cards{grid-template-columns:1fr}.stats-page{padding:var(--spacing-md)}.stats-charts-grid{grid-template-columns:1fr}}.public-game-page{max-width:900px;margin:0 auto;padding:2rem 1rem}.public-game-hero{display:flex;gap:2rem;margin-bottom:2rem}.public-game-cover{flex-shrink:0}.public-game-cover-img{width:264px;border-radius:12px;box-shadow:0 4px 20px #0000004d}.public-game-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.public-game-title{font-size:2rem;margin:0;color:var(--text-primary)}.public-game-developer,.public-game-publisher,.public-game-release{margin:0;color:var(--text-secondary);font-size:.95rem}.public-game-genres{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.public-game-tag{background:var(--primary-color);color:var(--bg-primary);padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600}.public-game-platforms{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.public-game-platform{background:var(--bg-tertiary);color:var(--text-secondary);padding:.2rem .6rem;border-radius:6px;font-size:.8rem}.public-game-video{margin-bottom:2rem;border-radius:12px;overflow:hidden}.public-game-video .video-container{position:relative;width:100%;padding-bottom:56.25%;background:#000}.public-game-video .video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.public-game-summary{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:2rem;color:var(--text-primary);line-height:1.6}.public-game-cta{display:flex;gap:1rem;justify-content:center}.public-game-error{text-align:center;padding:4rem 1rem}.public-game-error h1{color:var(--text-primary);margin-bottom:1rem}.public-game-error p{color:var(--text-secondary);margin-bottom:2rem}@media(max-width:768px){.public-game-hero{flex-direction:column;align-items:center;text-align:center}.public-game-cover-img{width:200px}.public-game-title{font-size:1.5rem}.public-game-genres,.public-game-platforms{justify-content:center}.public-game-cta{flex-direction:column}}
