.tag-selector{background:#000000c7;border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:.75rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 30px #00000059;max-width:920px}.tag-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.75rem;color:#e2e8f0}.tag-count{background:#ffffff1f;padding:.15rem .5rem;border-radius:999px;font-weight:700}.tag-options{display:flex;flex-wrap:wrap;gap:.35rem}.tag-option{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .55rem;border:1.5px solid rgba(255,255,255,.18);border-radius:999px;background:#ffffff0f;color:#e2e8f0;font-size:.7rem;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.tag-option:hover:not(.disabled):not(.selected){border-color:var(--tag-color);background:#ffffff1a;transform:translateY(-1px)}.tag-option:focus-visible{outline:2px solid rgba(255,255,255,.35);outline-offset:2px}.tag-option.selected{color:#fff;font-weight:700;border-color:var(--tag-color);background:color-mix(in srgb,var(--tag-color) 18%,rgba(255,255,255,.06));box-shadow:0 0 0 1px #ffffff14,0 0 12px color-mix(in srgb,var(--tag-color) 55%,transparent)}.tag-option.disabled{opacity:.35;cursor:not-allowed;transform:none}.taggable-level-preview{position:relative;border-radius:12px;overflow:hidden;transition:box-shadow .18s ease,transform .18s ease}.taggable-level-preview .level-content{transition:filter .18s ease}.taggable-level-preview:hover .level-content{filter:brightness(.9) saturate(.92) grayscale(.1)}.tag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .18s ease;background:#0000001a}.taggable-level-preview:hover .tag-overlay{opacity:1;pointer-events:auto}.taggable-level-preview:hover .selected-tags-badge{opacity:0}.tag-overlay.visible{opacity:1;pointer-events:auto}.selected-tags-badge{position:absolute;bottom:.6rem;left:50%;transform:translate(-50%);background:#22c55eeb;color:#fff;padding:.25rem .75rem;border-radius:999px;font-size:.7rem;font-weight:800;box-shadow:0 8px 18px #00000052}@media (prefers-reduced-motion: reduce){.tag-option,.taggable-level-preview,.taggable-level-preview .level-content,.tag-overlay{transition:none}}@media (max-width: 768px){.tag-selector{padding:.55rem}.tag-option{font-size:.65rem;padding:.25rem .45rem}}.builder-page{max-width:900px;margin:0 auto;padding:2rem}.builder-login{text-align:center;padding:3rem 2rem;background:var(--card-bg, #1a1f2e);border-radius:12px;border:1px solid var(--border-color, #2d3548)}.builder-login h2{color:var(--primary-color, #7c8aff);margin-bottom:1rem}.builder-login p{color:var(--text-secondary, #a0aec0);margin-bottom:1.5rem}.login-button{background:var(--primary-color, #7c8aff);color:#fff;border:none;padding:.875rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .2s,transform .1s}.login-button:hover{background:var(--primary-hover, #6b7aff);transform:translateY(-1px)}.login-hint{font-size:.85rem;color:var(--text-muted, #6b7280);margin-top:1rem}.google-login-container{margin:1.5rem 0;display:flex;flex-direction:column;align-items:center;gap:.75rem}.google-button-wrapper{display:flex;justify-content:center;min-height:44px}.login-divider{display:flex;align-items:center;margin:1.5rem 0;color:var(--text-muted, #6b7280)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color, #2d3548)}.login-divider span{padding:0 1rem;font-size:.85rem;text-transform:uppercase}.login-button.dev-login{background:var(--card-bg, #1a1f2e);border:1px solid var(--border-color, #2d3548);color:var(--text-secondary, #a0aec0)}.login-button.dev-login:hover{background:var(--border-color, #2d3548);border-color:var(--text-muted, #6b7280)}.privacy-notice{font-size:.8rem;color:var(--text-muted, #6b7280);margin-top:1.5rem;max-width:400px;margin-left:auto;margin-right:auto;line-height:1.5}.login-error{color:var(--error-color, #f56565);font-size:.9rem}.auth-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-radius:8px;overflow:hidden;border:1px solid var(--border-color, #2d3548)}.auth-tab{flex:1;padding:.75rem 1rem;background:transparent;border:none;color:var(--text-secondary, #a0aec0);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}.auth-tab:hover{background:var(--border-color, #2d3548)}.auth-tab.active{background:var(--primary-color, #7c8aff);color:#fff}.auth-form{width:100%;max-width:320px;margin:0 auto}.auth-form .form-group{margin-bottom:1rem;text-align:left}.auth-form label{display:block;color:var(--text-secondary, #a0aec0);font-size:.85rem;margin-bottom:.4rem}.auth-form input{width:100%;padding:.75rem;border:1px solid var(--border-color, #2d3548);border-radius:6px;background:var(--bg-input, #0d1117);color:var(--text-primary, #e2e8f0);font-size:1rem;transition:border-color .2s}.auth-form input:focus{outline:none;border-color:var(--primary-color, #7c8aff)}.auth-form input:disabled{opacity:.6;cursor:not-allowed}.auth-form .login-button{width:100%;margin-top:.5rem}.auth-form .login-button:disabled{opacity:.6;cursor:not-allowed}.auth-error{background:#f5656526;border:1px solid var(--error-color, #f56565);color:var(--error-color, #f56565);padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem;text-align:center}.builder-loading{text-align:center;padding:3rem;color:var(--text-secondary, #a0aec0)}.builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #2d3548)}.builder-user-info h2{color:var(--primary-color, #7c8aff);margin:0 0 .5rem}.builder-user-info p{color:var(--text-secondary, #a0aec0);margin:0}.logout-button{background:transparent;color:var(--text-secondary, #a0aec0);border:1px solid var(--border-color, #2d3548);padding:.5rem 1rem;font-size:.9rem;border-radius:6px;cursor:pointer;transition:all .2s}.logout-button:hover{border-color:var(--danger-color, #ef4444);color:var(--danger-color, #ef4444)}.email-verification-notice{background:linear-gradient(135deg,#fbbf2426,#f59e0b1a);border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;margin-bottom:2rem;display:flex;gap:1rem;align-items:flex-start}.verification-icon{font-size:2rem;flex-shrink:0}.verification-content h3{color:#fbbf24;margin:0 0 .5rem;font-size:1.1rem}.verification-content p{color:var(--text-secondary, #a0aec0);margin:0 0 .75rem;line-height:1.5}.resend-verification-button{background:#fbbf24;color:#1a1f2e;border:none;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:6px;cursor:pointer;transition:background .2s;margin-top:.5rem}.resend-verification-button:hover{background:#f59e0b}.builder-error{background:#ef44441a;border:1px solid var(--danger-color, #ef4444);color:var(--danger-color, #ef4444);padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.builder-error button{background:var(--danger-color, #ef4444);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.builder-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--card-bg, #1a1f2e);border:1px solid var(--border-color, #2d3548);border-radius:8px;padding:1.25rem;text-align:center}.stat-card .stat-value{display:block;font-size:1.75rem;font-weight:700;color:var(--primary-color, #7c8aff)}.stat-card .stat-label{color:var(--text-secondary, #a0aec0);font-size:.85rem}.builder-generators{background:var(--card-bg, #1a1f2e);border:1px solid var(--border-color, #2d3548);border-radius:12px;padding:1.5rem}.generators-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.generators-header h3{color:var(--text-primary, #e2e8f0);margin:0}.add-generator-button{background:var(--success-color, #22c55e);color:#fff;border:none;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:6px;cursor:pointer;transition:background .2s}.add-generator-button:hover{background:#1ea350}.generators-loading,.generators-empty{text-align:center;padding:2rem;color:var(--text-secondary, #a0aec0)}.generators-empty p{margin:.5rem 0}.generators-list{display:flex;flex-direction:column;gap:1rem}.generator-card{background:var(--bg-secondary, #0f1318);border:1px solid var(--border-color, #2d3548);border-radius:8px;padding:1.25rem}.generator-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.generator-info h4{color:var(--text-primary, #e2e8f0);margin:0 0 .25rem;font-size:1.1rem}.generator-id{font-size:.8rem;color:var(--text-secondary, #a0aec0);background:var(--card-bg, #1a1f2e);padding:.15rem .4rem;border-radius:4px}.generator-version{color:var(--primary-color, #7c8aff);font-size:.9rem;font-weight:600}.generator-description{color:var(--text-secondary, #a0aec0);font-size:.9rem;margin:0 0 .75rem;line-height:1.4}.generator-tags .tag{background:var(--primary-color, #7c8aff);color:#fff;font-size:.75rem;padding:.2rem .5rem;border-radius:4px}.generator-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.75rem;margin-bottom:1rem;padding:.75rem;background:var(--card-bg, #1a1f2e);border-radius:6px}.generator-stats .stat{text-align:center}.generator-stats .stat-value{display:block;font-size:1rem;font-weight:600;color:var(--text-primary, #e2e8f0)}.generator-stats .stat-label{font-size:.7rem;color:var(--text-secondary, #a0aec0)}.generator-actions{display:flex;gap:.75rem;flex-wrap:wrap}.view-button{display:inline-block;background:transparent;color:var(--accent-color, #4ecdc4);border:1px solid var(--accent-color, #4ecdc4);padding:.5rem 1rem;font-size:.85rem;border-radius:4px;cursor:pointer;text-decoration:none;transition:all .2s}.view-button:hover{background:var(--accent-color, #4ecdc4);color:var(--bg-color, #1a1f2e)}.edit-button{background:var(--primary-color, #7c8aff);color:#fff;border:none;padding:.5rem 1rem;font-size:.85rem;border-radius:4px;cursor:pointer;transition:background .2s}.edit-button:hover{background:var(--primary-hover, #6b7aff)}.delete-button{background:transparent;color:var(--danger-color, #ef4444);border:1px solid var(--danger-color, #ef4444);padding:.5rem 1rem;font-size:.85rem;border-radius:4px;cursor:pointer;transition:all .2s}.delete-button:hover{background:var(--danger-color, #ef4444);color:#fff}.generator-form{background:var(--bg-secondary, #0f1318);border:1px solid var(--primary-color, #7c8aff);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.generator-form h4{color:var(--primary-color, #7c8aff);margin:0 0 1.5rem}.form-error{background:#ef44441a;border:1px solid var(--danger-color, #ef4444);color:var(--danger-color, #ef4444);padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;color:var(--text-primary, #e2e8f0);font-size:.9rem;font-weight:500;margin-bottom:.5rem}.form-group input[type=text],.form-group input[type=url],.form-group textarea{width:100%;background:var(--card-bg, #1a1f2e);border:1px solid var(--border-color, #2d3548);color:var(--text-primary, #e2e8f0);padding:.625rem .875rem;font-size:.9rem;border-radius:6px;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color, #7c8aff)}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input[type=file]{color:var(--text-secondary, #a0aec0)}.form-group small{display:block;color:var(--text-muted, #6b7280);font-size:.8rem;margin-top:.4rem}.form-group small a{color:var(--primary-color, #7c8aff)}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.submit-button{background:var(--success-color, #22c55e);color:#fff;border:none;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border-radius:6px;cursor:pointer;transition:background .2s}.submit-button:hover:not(:disabled){background:#1ea350}.submit-button:disabled{opacity:.6;cursor:not-allowed}.cancel-button{background:transparent;color:var(--text-secondary, #a0aec0);border:1px solid var(--border-color, #2d3548);padding:.75rem 1.5rem;font-size:.95rem;border-radius:6px;cursor:pointer;transition:all .2s}.cancel-button:hover:not(:disabled){border-color:var(--text-secondary, #a0aec0)}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.verify-email-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.verify-email-card{background:var(--card-bg, #1a1f2e);border:1px solid var(--border-color, #2d3548);border-radius:12px;padding:3rem;text-align:center;max-width:400px}.verify-icon{font-size:4rem;margin-bottom:1.5rem}.verify-icon.loading{animation:pulse 1.5s ease-in-out infinite}.verify-email-card h2{color:var(--text-primary, #e2e8f0);margin:0 0 1rem}.verify-email-card p{color:var(--text-secondary, #a0aec0);line-height:1.5;margin-bottom:1.5rem}.email-required-page{max-width:500px;margin:0 auto;padding:2rem}.email-required-card{background:var(--card-bg, #1a1f2e);border:2px solid #fbbf24;border-radius:12px;padding:2.5rem;text-align:center}.email-required-card .icon{font-size:4rem;margin-bottom:1rem}.email-required-card h2{color:#fbbf24;margin:0 0 1rem}.email-required-card p{color:var(--text-secondary, #a0aec0);margin:0 0 1rem;line-height:1.5}.email-required-card .email-highlight{color:var(--primary-color, #7c8aff);font-weight:600}.email-required-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.email-required-actions button{padding:.75rem 1.5rem;font-size:.95rem;border-radius:6px;cursor:pointer;transition:all .2s}.email-required-actions .resend-button{background:#fbbf24;color:#1a1f2e;border:none;font-weight:600}.email-required-actions .resend-button:hover{background:#f59e0b}.email-required-actions .resend-button:disabled{opacity:.6;cursor:not-allowed}.email-required-actions .logout-button{background:transparent;color:var(--text-secondary, #a0aec0);border:1px solid var(--border-color, #2d3548)}.forgot-password-link{display:block;text-align:center;color:var(--primary-color, #7c8aff);font-size:.85rem;margin-top:1rem;cursor:pointer;background:none;border:none;text-decoration:underline}.forgot-password-link:hover{color:var(--primary-hover, #6b7aff)}.password-reset-form{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color, #2d3548)}.password-reset-form .form-group{margin-bottom:1rem;text-align:left}.password-reset-success{color:var(--success-color, #22c55e);background:#22c55e1a;padding:.75rem;border-radius:6px;margin-bottom:1rem}@media (max-width: 600px){.builder-page{padding:1rem}.builder-header,.generators-header{flex-direction:column;align-items:flex-start;gap:1rem}.generator-stats{grid-template-columns:repeat(2,1fr)}.generator-actions,.form-actions{flex-direction:column}}.generator-page{max-width:1400px;margin:0 auto;padding:1rem}.generator-loading,.generator-error{text-align:center;padding:3rem}.generator-error h2{color:var(--error-color, #ff6b6b);margin-bottom:1rem}.generator-header{background:var(--card-bg, #1e2a3a);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-color, #2d3e50)}.generator-header .back-link{display:inline-block;color:var(--primary-color, #4ecdc4);text-decoration:none;margin-bottom:1rem;font-size:.9rem;transition:opacity .2s}.generator-header .back-link:hover{opacity:.8}.generator-title{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.generator-title h1{margin:0;font-size:1.75rem;color:var(--text-primary, #fff)}.generator-version{background:var(--accent-bg, #2d3e50);padding:.25rem .75rem;border-radius:12px;font-size:.85rem;color:var(--text-secondary, #a0aec0)}.generator-inactive-badge{background:#ff6b6b;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.generator-id-display{display:block;color:var(--text-secondary, #a0aec0);font-size:.9rem;margin-bottom:1rem;font-family:JetBrains Mono,Fira Code,monospace}.generator-description{color:var(--text-primary, #e0e0e0);line-height:1.6;margin-bottom:1rem}.generator-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.generator-tags .tag{background:var(--tag-bg, #3d4f61);color:var(--tag-color, #4ecdc4);padding:.25rem .75rem;border-radius:12px;font-size:.8rem}.generator-docs-link{display:inline-block;color:var(--primary-color, #4ecdc4);text-decoration:none;font-size:.9rem;transition:opacity .2s}.generator-docs-link:hover{opacity:.8}.generator-stats-section{background:var(--card-bg, #1e2a3a);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-color, #2d3e50)}.generator-stats-section h2{margin:0 0 1rem;font-size:1.25rem;color:var(--text-primary, #fff)}.generator-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.generator-stats-grid .stat-card{background:var(--accent-bg, #2d3e50);border-radius:8px;padding:1rem;text-align:center}.generator-stats-grid .stat-card.highlight{background:linear-gradient(135deg,#2d4a5e,#1e3545);border:1px solid var(--primary-color, #4ecdc4)}.generator-stats-grid .stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary, #fff)}.generator-stats-grid .stat-label{display:block;font-size:.75rem;color:var(--text-secondary, #a0aec0);margin-top:.25rem}.generator-levels-section{background:var(--card-bg, #1e2a3a);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-color, #2d3e50)}.generator-levels-section h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary, #fff)}.levels-hint{color:var(--text-secondary, #a0aec0);font-size:.9rem;margin-bottom:1rem}.levels-container{overflow-x:auto;overflow-y:visible}.level-preview-list{display:flex;flex-direction:column;gap:1rem}.level-preview{position:relative;background:var(--accent-bg, #2d3e50);border-radius:8px;padding:.5rem;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;border:2px solid transparent}.level-preview[style*="cursor: pointer"]:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:var(--primary-color, #4ecdc4)}.level-preview[style*="cursor: pointer"]:hover .level-preview-label{background:var(--primary-color, #4ecdc4);color:#000}.level-preview[style*="cursor: pointer"]:after{content:"Click for stats →";position:absolute;bottom:.75rem;right:.75rem;background:#4ecdc4e6;color:#000;padding:.25rem .5rem;border-radius:4px;font-size:.65rem;font-weight:600;opacity:0;transition:opacity .2s ease;z-index:1}.level-preview[style*="cursor: pointer"]:hover:after{opacity:1}.level-preview canvas{border-radius:4px;max-width:100%;height:auto}.level-preview-label{position:absolute;top:.75rem;left:.75rem;background:#000000b3;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-family:JetBrains Mono,Fira Code,monospace;z-index:1;transition:background .2s ease,color .2s ease}.level-preview-loading,.level-preview-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;color:#fff;padding:.5rem 1rem;border-radius:4px;font-size:.85rem}.level-preview-error{color:#ff6b6b}.generator-meta{text-align:center;padding:1rem;color:var(--text-secondary, #a0aec0);font-size:.8rem}.generator-meta p{margin:.25rem 0}@media (max-width: 768px){.generator-title h1{font-size:1.5rem}.generator-stats-grid{grid-template-columns:repeat(3,1fr)}.generator-stats-grid .stat-value{font-size:1.25rem}}@media (max-width: 480px){.generator-stats-grid{grid-template-columns:repeat(2,1fr)}}.leaderboard-table .generator-link{color:var(--primary-color, #4ecdc4);text-decoration:none;transition:opacity .2s}.generator-card .view-button{display:inline-block;background:var(--accent-bg, #2d3e50);color:var(--primary-color, #4ecdc4);border:1px solid var(--primary-color, #4ecdc4);padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-size:.9rem;transition:background-color .2s}.generator-card .view-button:hover{background:var(--primary-color, #4ecdc4);color:var(--card-bg, #1e2a3a)}.stats-page{max-width:1200px;margin:0 auto;padding:2rem;font-family:Segoe UI,system-ui,sans-serif}.stats-title{font-size:2.5rem;font-weight:700;color:#1a1a2e;margin-bottom:2rem;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-loading,.stats-error,.stats-empty{text-align:center;padding:4rem 2rem;font-size:1.25rem;color:#64748b}.stats-error{color:#dc2626}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.stats-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid rgba(0,0,0,.05)}.stats-card h2{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.stats-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.metric{text-align:center;padding:.75rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.metric.large{grid-column:1 / -1;padding:1.5rem;background:linear-gradient(135deg,#667eea15,#764ba215)}.metric-value{display:block;font-size:1.75rem;font-weight:700;color:#1a1a2e;line-height:1.2}.metric.large .metric-value{font-size:3rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.metric-label{display:block;font-size:.75rem;color:#64748b;margin-top:.25rem;text-transform:uppercase;letter-spacing:.5px}.vote-bars{display:flex;flex-direction:column;gap:.75rem}.vote-bar-row{display:grid;grid-template-columns:80px 1fr 50px;align-items:center;gap:.75rem}.bar-label{font-size:.875rem;color:#374151;font-weight:500}.bar-container{height:24px;background:#f1f5f9;border-radius:12px;overflow:hidden}.bar{height:100%;border-radius:12px;transition:width .5s ease-out;min-width:4px}.bar-left{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.bar-right{background:linear-gradient(90deg,#10b981,#34d399)}.bar-tie{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.bar-skip{background:linear-gradient(90deg,#6b7280,#9ca3af)}.bar-value{font-size:.875rem;font-weight:600;color:#374151;text-align:right}.engagement-card .stats-metrics{gap:1.5rem}.stats-note{text-align:center;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.stats-note p{margin:0;font-size:.875rem;color:#64748b;line-height:1.6}@media (max-width: 768px){.stats-page{padding:1rem}.stats-title{font-size:1.75rem}.stats-grid{grid-template-columns:1fr}.vote-bar-row{grid-template-columns:70px 1fr 40px;gap:.5rem}.bar-label{font-size:.75rem}}.level-detail-page{max-width:1200px;margin:0 auto;padding:2rem;font-family:Segoe UI,system-ui,sans-serif}.level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.level-header h1{font-size:2rem;color:#1a1a2e;margin:0}.level-header .level-id{margin:0}.level-subheader{margin-bottom:2rem}.level-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.back-link{color:#667eea;text-decoration:none;font-size:.875rem}.back-link:hover{text-decoration:underline}.play-level-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.play-level-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.level-id{font-family:monospace;font-size:.875rem;color:#64748b;background:#f1f5f9;padding:.25rem .75rem;border-radius:4px;display:inline-block}.level-loading,.level-error{text-align:center;padding:4rem 2rem;font-size:1.25rem;color:#64748b}.level-error{color:#dc2626}.level-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.level-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 4px #0000000d;border:1px solid #e2e8f0}.level-card.full-width{grid-column:1 / -1}.level-card h2{font-size:1rem;font-weight:600;color:#374151;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #f0f0f0}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.metric{text-align:center;padding:.75rem;background:#f8fafc;border-radius:8px}.metric .value{display:block;font-size:1.5rem;font-weight:700;color:#1a1a2e}.metric .label{display:block;font-size:.7rem;color:#64748b;text-transform:uppercase;margin-top:.25rem}.difficulty-display{text-align:center}.difficulty-badge{display:inline-block;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.875rem;margin-bottom:1rem}.difficulty-badge.very_easy{background:#d1fae5;color:#065f46}.difficulty-badge.easy{background:#e0f2fe;color:#0369a1}.difficulty-badge.medium{background:#fef3c7;color:#92400e}.difficulty-badge.hard{background:#fed7aa;color:#c2410c}.difficulty-badge.very_hard{background:#fecaca;color:#b91c1c}.difficulty-badge.unknown{background:#f1f5f9;color:#64748b}.difficulty-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.difficulty-fill{height:100%;background:linear-gradient(90deg,#22c55e,#f59e0b,#ef4444);transition:width .5s ease}.outcomes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.outcome{text-align:center;padding:.5rem;border-radius:8px}.outcome.win{background:#d1fae5}.outcome.loss{background:#fecaca}.outcome.tie{background:#fef3c7}.outcome.skip{background:#f1f5f9}.outcome.play-skipped{background:#fce7f3}.outcome .count{display:block;font-size:1.25rem;font-weight:700}.outcome.win .count{color:#065f46}.outcome.loss .count{color:#b91c1c}.outcome.tie .count{color:#92400e}.outcome.skip .count{color:#374151}.outcome.play-skipped .count{color:#9d174d}.outcome .label{font-size:.65rem;text-transform:uppercase;color:#64748b}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:18px;font-size:.8rem;border:2px solid #e2e8f0;background:#f8fafc;transition:transform .15s ease}.tag-item:hover{transform:scale(1.03)}.tag-name{color:#1f2937;font-weight:500}.tag-count{background:#667eea;color:#fff;padding:.15rem .5rem;border-radius:12px;font-weight:700;font-size:.75rem;min-width:1.5rem;text-align:center}.no-tags{color:#94a3b8;font-style:italic;margin:0}.heatmap-container{background:#1a1a2e;border-radius:8px;overflow-x:auto;padding:.5rem}.heatmap-layers{position:relative;display:inline-block}.heatmap-level-canvas{display:block;image-rendering:pixelated;border-radius:4px}.heatmap-overlay-canvas{position:absolute;top:0;left:0;pointer-events:none;image-rendering:pixelated}.heatmap-description,.trajectory-description{font-size:.875rem;color:#64748b;margin:0 0 1rem}.no-data{text-align:center;color:#94a3b8;font-style:italic;margin-top:1rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.feature-group{text-align:center;padding:.75rem;background:#f8fafc;border-radius:8px}.feature-group h3{font-size:.7rem;text-transform:uppercase;color:#64748b;margin:0 0 .25rem}.feature-group p{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0}.feature-group small{display:block;font-size:.65rem;color:#94a3b8;margin-top:.25rem}@media (max-width: 768px){.level-detail-page{padding:1rem}.level-grid{grid-template-columns:1fr}.outcomes-grid{grid-template-columns:repeat(2,1fr)}}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:var(--color-bg-medium);padding:var(--spacing-lg);text-align:center;border-bottom:4px solid var(--color-lime)}.app-header .subtitle{font-size:.875rem;color:var(--color-lime);margin-bottom:0}.app-nav{display:flex;justify-content:center;gap:1rem;margin-top:var(--spacing-md)}.nav-link{color:var(--color-text-dim);text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:all .2s;font-weight:500}.nav-link:hover{color:var(--color-lime)}.nav-link.active{color:var(--color-lime);background:#99e6001a}.app-main{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.connection-screen{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;max-width:600px;margin:0 auto}.connection-screen.error{border-color:var(--color-error)}.connection-screen button{margin-top:var(--spacing-md)}.connection-screen .hint{margin-top:var(--spacing-md);font-size:.75rem}.battle-flow{width:100%;max-width:1200px;margin:0 auto}.welcome-state{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px}.welcome-state h2{margin-bottom:var(--spacing-lg)}.welcome-state p{margin-bottom:var(--spacing-lg);font-size:1rem}.welcome-state button{margin-top:var(--spacing-md)}.error-state{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-error);border-radius:8px}.battle-info{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px}.battle-info h2{margin-bottom:var(--spacing-lg)}.battle-info p{margin-bottom:var(--spacing-sm);font-family:var(--font-pixel);font-size:.75rem}.battle-info button{margin-top:var(--spacing-lg)}.game-canvas-container{display:flex;flex-direction:column;align-items:center}.game-canvas{width:256px;height:256px;border:2px solid var(--color-lime);background-color:#5c94fc;image-rendering:pixelated;image-rendering:crisp-edges}.game-canvas-loading,.game-canvas-error{width:256px;height:256px;border:4px solid var(--color-lime);background-color:var(--color-bg-medium);display:flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-size:.625rem;text-align:center;padding:var(--spacing-md)}.game-canvas-error{border-color:var(--color-error);color:var(--color-error)}.controls-hint{font-family:var(--font-pixel);font-size:.625rem;color:var(--color-lime);text-align:center}.game-status{font-family:var(--font-pixel);font-size:.5rem;color:var(--color-text);text-align:center;margin-top:var(--spacing-xs)}canvas{display:block;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges}.battle-header{text-align:center;margin-bottom:var(--spacing-lg)}.battle-header h2{margin-bottom:var(--spacing-sm)}.battle-header .controls-hint{font-family:var(--font-pixel);font-size:.625rem}.battle-header .practice-hint{font-family:var(--font-pixel);font-size:.75rem;color:var(--color-coin);margin-bottom:var(--spacing-xs)}.battle-screen{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.level-panel{background-color:var(--color-bg-medium);border:4px solid var(--color-bg-dark);border-radius:8px;padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center}.level-panel.active{border-color:var(--color-success);box-shadow:0 0 30px #63c64d99}.level-panel.done{border-color:var(--color-lime);opacity:.9}.level-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:var(--spacing-sm);font-family:var(--font-pixel);font-size:.75rem}.level-label{background-color:var(--color-lime);color:var(--color-bg-dark);padding:var(--spacing-xs) var(--spacing-sm);font-weight:700}.generator-name{color:var(--color-lime)}.generator-hidden{color:var(--color-text);opacity:.6;font-style:italic}.skip-button{background-color:transparent;border:1px solid var(--color-warning);color:var(--color-warning);font-family:var(--font-pixel);font-size:.625rem;padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;transition:all .2s ease}.skip-button:hover{background-color:var(--color-warning);color:var(--color-bg-dark)}.level-status{margin-top:var(--spacing-sm);font-family:var(--font-pixel);font-size:.625rem;text-align:center}.status-playing{color:var(--color-success);animation:pulse 1s infinite}.status-complete{color:var(--color-lime)}.status-waiting{color:var(--color-text);opacity:.5}.status-next{color:var(--color-text)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.level-summary{background-color:var(--color-bg-dark);padding:var(--spacing-md);border-radius:4px;font-family:var(--font-pixel);font-size:.625rem;min-height:100px;width:256px}.level-summary p{margin-bottom:var(--spacing-xs)}.battle-footer{text-align:center;font-family:var(--font-pixel);font-size:.625rem;color:var(--color-lime)}.results-header{text-align:center;margin-bottom:var(--spacing-lg)}.generator-reveal{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.reveal-panel{background-color:var(--color-bg-medium);padding:var(--spacing-md) var(--spacing-lg);border:4px solid var(--color-lime);border-radius:8px;font-family:var(--font-pixel);text-align:center}.reveal-label{display:block;font-size:.75rem;color:var(--color-text);margin-bottom:var(--spacing-xs)}.reveal-name{display:block;font-size:1rem;color:var(--color-lime)}.submitting-state{text-align:center;padding:var(--spacing-lg);font-family:var(--font-pixel)}.voting-panel{padding:var(--spacing-lg);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;text-align:center;max-width:600px;margin:var(--spacing-lg) auto}.voting-panel h3{margin-bottom:var(--spacing-lg);font-size:1rem}.vote-buttons{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-md)}.vote-button{padding:var(--spacing-md) var(--spacing-lg);font-size:.75rem;min-width:140px}.vote-button.left{background-color:#4a9eff;color:#fff}.vote-button.right{background-color:#ff6b4a;color:#fff}.vote-button.tie{background-color:#9b59b6;color:#fff}.vote-button.skip{background-color:#666;color:#fff}.skip-section{margin-top:var(--spacing-md)}.skip-section .vote-button{min-width:200px}.voting-levels-container{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);max-width:100%;overflow-x:auto}.voting-level-panel{background-color:var(--color-bg-medium);border:3px solid var(--color-lime);border-radius:8px;padding:var(--spacing-md)}.voting-level-header{display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-sm)}.voting-level-label{font-family:var(--font-display);font-size:1.25rem;color:var(--color-lime);background-color:var(--color-bg-dark);padding:.25rem 1rem;border-radius:4px;letter-spacing:.1em}.voting-level-preview{display:flex;justify-content:center;overflow-x:auto;background-color:var(--color-bg-dark);border-radius:4px;padding:var(--spacing-sm)}.voting-level-preview .level-preview-container{max-width:100%}.voting-level-preview .level-preview-canvas{max-width:100%;height:auto}.voting-level-preview .level-preview-info{display:none}.voting-generator-reveal{font-family:var(--font-display);font-size:.9rem;color:var(--color-success);background-color:var(--color-bg-dark);padding:.25rem .75rem;border-radius:4px;margin-left:var(--spacing-md);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.results-auto-advance{text-align:center;padding:var(--spacing-lg)}.results-auto-advance .auto-advance-hint{font-size:.85rem;color:var(--color-text);opacity:.7;animation:pulse 1.5s infinite}.tag-hint{text-align:center;font-size:.8rem;color:var(--color-text);opacity:.7;margin:var(--spacing-sm) 0;font-style:italic}.leaderboard{padding:var(--spacing-lg);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;max-width:800px;margin:0 auto}.leaderboard h2{margin-bottom:var(--spacing-md);text-align:center}.leaderboard-table{width:100%;border-collapse:collapse;font-family:var(--font-pixel);font-size:.625rem;margin-top:var(--spacing-md)}.leaderboard-table th,.leaderboard-table td{padding:var(--spacing-sm);text-align:left;border-bottom:2px solid var(--color-bg-dark)}.leaderboard-table th{color:var(--color-lime);font-weight:400}.leaderboard-table td{color:var(--color-text)}.leaderboard-table .generator-name{color:var(--color-lime)}.leaderboard-table .generator-link{color:var(--color-lime);text-decoration:none;transition:opacity .2s}.leaderboard-table .generator-link:hover{opacity:.8;text-decoration:underline}.leaderboard .timestamp{text-align:center;font-size:.625rem;color:var(--color-lime);opacity:.7;margin-top:var(--spacing-md)}.leaderboard-page{max-width:900px;margin:0 auto;padding:var(--spacing-lg)}.leaderboard-page-header{text-align:center;margin-bottom:var(--spacing-xl)}.leaderboard-page-header h1{font-family:var(--font-display);font-size:1.5rem;color:var(--color-lime);margin-bottom:var(--spacing-sm)}.leaderboard-page-header p{font-size:.75rem;opacity:.8}.leaderboard-loading,.leaderboard-error{text-align:center;padding:var(--spacing-xl)}.leaderboard-error .retry-button{margin-top:var(--spacing-md)}.results-brief{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;max-width:500px;margin:0 auto}.results-brief h2{color:var(--color-lime);margin-bottom:var(--spacing-lg)}.generator-reveal-brief{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.generator-reveal-brief .reveal-item{display:flex;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-sm);background-color:var(--color-bg-dark);border-radius:4px}.generator-reveal-brief .reveal-label{color:var(--color-text);opacity:.7}.generator-reveal-brief .reveal-name{color:var(--color-lime);font-weight:700}.auto-advance-hint{font-size:.75rem;color:var(--color-text);opacity:.6;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.leaderboard-state{display:flex;flex-direction:column;gap:var(--spacing-lg);align-items:center}.leaderboard-state h2{color:var(--color-success)}.gameplay-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.gameplay-state h2{text-align:center;font-size:1.25rem}.status-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-dark);border-bottom:2px solid var(--color-lime);font-family:var(--font-pixel);font-size:.625rem}.admin-page{max-width:1200px;margin:0 auto;padding:var(--spacing-lg);width:100%}.admin-page h2{font-family:var(--font-display);font-size:1.5rem;color:var(--color-lime);margin-bottom:var(--spacing-md);text-align:center}.admin-user{text-align:center;color:var(--color-success);font-size:.85rem;margin-bottom:var(--spacing-lg)}.admin-login-required,.admin-access-denied,.admin-error{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;max-width:500px;margin:0 auto}.admin-access-denied{border-color:var(--color-error)}.admin-access-denied p:first-child{font-size:2rem;margin-bottom:var(--spacing-md)}.google-button-container{display:flex;justify-content:center;margin:var(--spacing-lg) 0}.admin-tabs{display:flex;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-bg-medium);padding-bottom:var(--spacing-sm)}.admin-tabs button{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:2px solid transparent;color:var(--color-text);font-family:var(--font-display);font-size:.9rem;cursor:pointer;transition:all .2s;border-radius:4px 4px 0 0}.admin-tabs button:hover{color:var(--color-lime);background:#99e6001a}.admin-tabs button.active{color:var(--color-lime);border-color:var(--color-lime);border-bottom-color:transparent;background:var(--color-bg-medium)}.admin-section{background-color:var(--color-bg-medium);border:2px solid var(--color-bg-dark);border-radius:8px;padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.admin-section h3{font-family:var(--font-display);font-size:1.1rem;color:var(--color-lime);margin-bottom:var(--spacing-md)}.section-description{font-size:.85rem;color:var(--color-text);opacity:.7;margin-bottom:var(--spacing-md)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.stat-card{background-color:var(--color-bg-dark);padding:var(--spacing-md);border-radius:8px;text-align:center}.stat-value{font-family:var(--font-display);font-size:1.5rem;color:var(--color-lime);margin-bottom:var(--spacing-xs)}.stat-label{font-size:.75rem;color:var(--color-text);opacity:.8}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table.compact{max-width:500px}.admin-table th,.admin-table td{padding:var(--spacing-sm);text-align:left;border-bottom:1px solid var(--color-bg-dark)}.admin-table th{color:var(--color-lime);font-weight:600}.admin-table td{color:var(--color-text)}.admin-table td code{background:var(--color-bg-dark);padding:2px 6px;border-radius:3px;font-family:monospace;font-size:.8rem}.admin-table tr.highlight{background:#99e6000d}.admin-table tr.highlight td:last-child{color:var(--color-warning, #f1c40f)}.no-data{text-align:center;color:var(--color-success);padding:var(--spacing-lg)}.more-count{text-align:center;color:var(--color-text);opacity:.6;margin-top:var(--spacing-md)}.matrix-container{overflow-x:auto;margin:var(--spacing-md) 0}.confusion-matrix{border-collapse:collapse;font-size:.7rem;min-width:100%}.confusion-matrix th,.confusion-matrix td{padding:6px 8px;text-align:center;border:1px solid var(--color-bg-dark);position:relative;min-width:60px}.confusion-matrix th{background:var(--color-bg-dark);color:var(--color-lime);font-weight:400}.confusion-matrix td.diagonal{background:var(--color-bg-dark)}.confusion-matrix td.empty{background:#ffffff05;color:var(--color-text);opacity:.3}.confusion-matrix td.win-high{background:#63c64d4d;color:var(--color-success)}.confusion-matrix td.loss-high{background:#e648484d;color:var(--color-error)}.confusion-matrix td.balanced{background:#99e6001a;color:var(--color-lime)}.confusion-matrix .battle-count{display:block;font-size:.6rem;opacity:.5}.coverage-summary{font-size:.85rem;color:var(--color-text);margin-bottom:var(--spacing-md);display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.coverage-summary .separator{opacity:.3}.matrix-legend{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-md);font-size:.75rem;justify-content:center;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--spacing-xs)}.legend-item .cell{width:16px;height:16px;border-radius:2px;border:1px solid var(--color-bg-dark)}.legend-item .cell.win-high{background:#63c64d4d}.legend-item .cell.balanced{background:#99e6001a}.legend-item .cell.loss-high{background:#e648484d}.legend-item .cell.empty{background:#ffffff05}.admin-export{padding:var(--spacing-md) 0}.export-status{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:8px;background:var(--color-bg-dark);border:1px solid var(--color-lime);text-align:center;font-size:.9rem}.export-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.export-card{background:var(--color-bg-dark);border:1px solid rgba(153,230,0,.2);border-radius:12px;padding:var(--spacing-md)}.export-card h4{margin:0 0 var(--spacing-sm) 0;color:var(--color-lime);font-family:var(--font-display);font-size:1rem}.export-card p{margin:0 0 var(--spacing-md) 0;font-size:.85rem;color:var(--color-text-dim);line-height:1.4}.export-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#99e60033,#99e6001a);border:1px solid var(--color-lime);color:var(--color-lime);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.export-btn:hover{background:var(--color-lime);color:var(--color-bg)}.export-actions{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid rgba(153,230,0,.2)}.export-actions h4{margin:0 0 var(--spacing-md) 0;color:var(--color-lime);font-family:var(--font-display)}.action-btn{padding:var(--spacing-sm) var(--spacing-lg);background:#fa03;border:1px solid var(--color-warning);color:var(--color-warning);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;margin-right:var(--spacing-md)}.action-btn:hover{background:var(--color-warning);color:var(--color-bg)}.action-hint{font-size:.8rem;color:var(--color-text-dim)}:root{--color-bg-dark: #0f380f;--color-bg-medium: #306230;--color-lime: #9bbc0f;--color-light: #8bac0f;--color-text: #e0f8d0;--color-text-dim: rgba(224, 248, 208, .7);--color-error: #e43b44;--color-success: #63c64d;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-pixel: "Press Start 2P", cursive;--font-system: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--card-bg: #1a2e1a;--bg-secondary: #0d1f0d;--border-color: #2d4a2d;--text-primary: #e0f8d0;--text-secondary: #a0c8a0;--text-muted: #6a8a6a;--primary-color: #9bbc0f;--primary-hover: #8bac0f;--danger-color: #e43b44}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-system);background-color:var(--color-bg-dark);color:var(--color-text);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-pixel);line-height:1.4;font-weight:400}h1{font-size:1.5rem;margin-bottom:var(--spacing-md)}h2{font-size:1rem;margin-bottom:var(--spacing-sm)}p{margin-bottom:var(--spacing-sm)}button{font-family:var(--font-pixel);font-size:.75rem;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-lime);color:var(--color-bg-dark);border:3px solid var(--color-bg-dark);cursor:pointer;transition:all .1s;text-transform:uppercase}button:hover:not(:disabled){background-color:var(--color-light);transform:translateY(-2px);box-shadow:0 4px 0 var(--color-bg-dark)}button:active:not(:disabled){transform:translateY(0);box-shadow:none}button:disabled{opacity:.5;cursor:not-allowed}button.primary-button{background-color:var(--color-success);color:#fff;padding:var(--spacing-md) var(--spacing-xl);font-size:.875rem}.error-message{color:var(--color-error);font-family:var(--font-pixel);font-size:.75rem}.hint{color:var(--color-lime);font-size:.875rem;opacity:.8}#root{width:100%;min-height:100vh}
