.layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg)}.header{background:linear-gradient(135deg,#1e293bf2,#0f172afa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(51,65,85,.8);padding:var(--spacing-md) 0;position:sticky;top:0;z-index:100;box-shadow:0 4px 6px -1px #0003}.header-content{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg)}.logo{text-decoration:none;color:inherit;transition:transform var(--transition-base)}.logo:hover{transform:translateY(-1px)}.logo h1{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.nav{display:flex;align-items:center;gap:var(--spacing-lg)}.nav-link{color:var(--color-text-secondary);text-decoration:none;font-size:.95rem;font-weight:500;transition:color var(--transition-base);position:relative;padding:6px 0}.nav-link:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));transform:scaleX(0);transition:transform var(--transition-base);border-radius:2px}.nav-link:hover{color:var(--color-primary)}.nav-link:hover:after{transform:scaleX(1)}.user-menu{display:flex;align-items:center;gap:var(--spacing-md);padding-left:var(--spacing-md);border-left:1px solid var(--color-bg-tertiary)}.user-email{color:var(--color-text-secondary);font-size:.9rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu .btn{padding:8px 16px;font-size:.9rem}.main-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg);animation:fadeIn .3s ease-in}.footer{background:linear-gradient(135deg,#1e293b99,#0f172acc);border-top:1px solid rgba(51,65,85,.5);padding:var(--spacing-xl) var(--spacing-lg);text-align:center;color:var(--color-text-muted);margin-top:auto}.footer p{margin:var(--spacing-xs) 0;font-size:.875rem;line-height:1.6}.footer-disclaimer{font-size:.8rem;opacity:.8;max-width:800px;margin:var(--spacing-md) auto 0}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-secondary{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-bg-tertiary);padding:8px 16px;border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn-secondary:hover{background-color:#33415580;border-color:var(--color-primary);color:var(--color-text)}.loading-container{min-height:50vh;display:flex;align-items:center;justify-content:center}.loading{font-size:1.1rem;color:var(--color-text-secondary);text-align:center;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.header-content{flex-direction:row;padding:0 var(--spacing-md)}.nav{gap:var(--spacing-md);flex-wrap:wrap}.user-menu{flex-direction:column;align-items:flex-end;gap:var(--spacing-sm);padding-left:0;border-left:none}.user-email{max-width:150px;font-size:.85rem}.main-content{padding:var(--spacing-lg) var(--spacing-md)}.nav-link{font-size:.9rem}.logo h1{font-size:1.2rem}}@media (max-width: 480px){.header{padding:var(--spacing-sm) 0}.header-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.nav{width:100%;justify-content:space-between;gap:var(--spacing-sm)}.user-menu{width:100%;flex-direction:row;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-bg-tertiary);border-left:none}.logo h1{font-size:1.1rem}.footer{padding:var(--spacing-lg) var(--spacing-md)}}@media (prefers-reduced-motion: reduce){.main-content,.loading,.logo,.nav-link,.btn-primary,.btn-secondary{animation:none!important;transition:none!important}.nav-link:after{transition:none!important}}.logo:focus-visible,.nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:4px}.btn-primary:focus-visible,.btn-secondary:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-contrast: high){.header{border-bottom-width:2px}.nav-link:after{height:3px}.user-menu{border-left-width:2px}}.home-container{max-width:1200px;margin:0 auto}.hero{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);animation:fadeIn .5s ease-in}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:var(--spacing-lg);letter-spacing:-.03em;color:var(--color-text)}.gradient-text{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.hero-subtitle{font-size:1.25rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-2xl);max-width:700px;margin-left:auto;margin-right:auto;line-height:1.6}.hero-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.btn-large{padding:14px 32px;font-size:1.05rem;border-radius:10px;font-weight:600;min-width:160px}.features{padding:var(--spacing-2xl) var(--spacing-lg);background:linear-gradient(135deg,#1e293b4d,#0f172a80);border-radius:var(--border-radius-xl);margin:var(--spacing-2xl) 0;border:1px solid rgba(51,65,85,.5)}.features h2{text-align:center;font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-xl);letter-spacing:-.02em}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl);margin-top:var(--spacing-xl)}.feature-card{background:linear-gradient(135deg,#1e293b99,#0f172a66);border:1px solid rgba(51,65,85,.6);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-4px);border-color:#3b82f680;box-shadow:0 12px 24px #0000004d;background:linear-gradient(135deg,#1e293bcc,#0f172a99)}.feature-card h3{font-size:1.4rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-primary-light);letter-spacing:-.01em}.feature-card p{color:var(--color-text-secondary);line-height:1.6;font-size:1rem}.legal-section{background:linear-gradient(135deg,#ef44440d,#ef444405);border:1px solid rgba(239,68,68,.2);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);margin:var(--spacing-2xl) 0;text-align:center}.legal-section h3{font-size:1.3rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-text)}.legal-section p{color:var(--color-text-secondary);line-height:1.7;max-width:800px;margin:0 auto;font-size:.95rem}.btn{padding:10px 24px;border-radius:var(--border-radius);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);border:none;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-primary:hover{background:linear-gradient(135deg,var(--color-primary-dark),#1d4ed8);transform:translateY(-2px);box-shadow:0 8px 16px #3b82f64d}.btn-secondary{background-color:transparent;color:var(--color-text);border:2px solid var(--color-bg-tertiary)}.btn-secondary:hover{background-color:#33415580;border-color:var(--color-primary);transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}@media (max-width: 768px){.hero{padding:var(--spacing-xl) var(--spacing-md)}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-actions{flex-direction:column;align-items:stretch}.btn-large{width:100%}.features{padding:var(--spacing-xl) var(--spacing-md)}.features h2{font-size:2rem}.features-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.legal-section{padding:var(--spacing-lg) var(--spacing-md)}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.features h2{font-size:1.75rem}.feature-card h3{font-size:1.2rem}.feature-card p{font-size:.95rem}}@media (prefers-reduced-motion: reduce){.hero,.feature-card,.btn{animation:none!important;transition:none!important}.feature-card:hover,.btn:hover{transform:none!important}}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-contrast: high){.feature-card,.legal-section,.features,.btn-secondary{border-width:2px}}.auth-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.auth-card{background:linear-gradient(135deg,#1e293bf2,#0f172ae6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.6);border-radius:var(--border-radius-lg);padding:var(--spacing-2xl);max-width:450px;width:100%;box-shadow:0 20px 40px #0006}.auth-card h1{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-sm);text-align:center;letter-spacing:-.02em}.auth-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);font-size:.95rem;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-weight:500;color:var(--color-text-secondary);font-size:.9rem;letter-spacing:.01em}.form-group input{width:100%;padding:12px var(--spacing-md);background-color:#1e293b99;border:1px solid rgba(51,65,85,.8);border-radius:var(--border-radius);color:var(--color-text);font-size:.95rem;transition:all var(--transition-base)}.form-group input:hover{border-color:#3b82f680;background-color:#1e293bcc}.form-group input:focus{outline:none;border-color:var(--color-primary);background-color:#1e293be6;box-shadow:0 0 0 3px #3b82f626}.form-group input::placeholder{color:var(--color-text-muted)}.error-message{background:linear-gradient(135deg,#ef444426,#ef44441a);border:1px solid rgba(239,68,68,.4);color:#fca5a5;padding:var(--spacing-md);border-radius:var(--border-radius);text-align:center;font-size:.9rem;line-height:1.5;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.auth-divider{text-align:center;margin:var(--spacing-lg) 0;position:relative}.auth-divider span{background-color:#1e293bf2;padding:0 var(--spacing-md);color:var(--color-text-muted);position:relative;z-index:1;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(51,65,85,.8),transparent)}.oauth-buttons{display:flex;gap:var(--spacing-md)}.btn-oauth{flex:1;background-color:#33415599;color:var(--color-text);border:1px solid rgba(51,65,85,.8);padding:12px var(--spacing-md);border-radius:var(--border-radius);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-oauth:hover{background-color:#3b82f633;border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f633}.btn-oauth:active{transform:translateY(0)}.auth-switch{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid rgba(51,65,85,.5);color:var(--color-text-secondary);font-size:.95rem}.auth-switch a{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color var(--transition-base)}.auth-switch a:hover{color:var(--color-primary-light);text-decoration:underline}.auth-form button[type=submit]{margin-top:var(--spacing-md);padding:12px var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.auth-form button[type=submit]:hover{background:linear-gradient(135deg,var(--color-primary-dark),#1d4ed8);transform:translateY(-2px);box-shadow:0 8px 16px #3b82f64d}.auth-form button[type=submit]:active{transform:translateY(0)}.auth-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@media (max-width: 480px){.auth-container{padding:var(--spacing-lg) var(--spacing-md)}.auth-card{padding:var(--spacing-xl)}.auth-card h1{font-size:1.75rem}.oauth-buttons{flex-direction:column}.btn-oauth{width:100%}}@media (prefers-reduced-motion: reduce){.auth-container,.error-message,.btn-oauth,.auth-form button[type=submit]{animation:none!important;transition:none!important}.btn-oauth:hover,.auth-form button[type=submit]:hover{transform:none!important}}.form-group input:focus-visible,.btn-oauth:focus-visible,.auth-form button[type=submit]:focus-visible,.auth-switch a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-contrast: high){.auth-card,.form-group input,.btn-oauth,.error-message{border-width:2px}.auth-divider:before{height:2px}}.rom-manager{width:100%;max-width:1200px;margin:0 auto}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.storage-limit{padding:.5rem 1rem;background:var(--bg-secondary, #f5f5f5);border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary, #666)}.rom-card{background:#fff;border:1px solid var(--border-color, #e0e0e0);border-radius:.75rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.rom-info h3{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary, #1a1a1a)}.rom-meta{font-size:.875rem;color:var(--text-secondary, #666);margin-bottom:.5rem}.rom-hash{font-family:Courier New,monospace;font-size:.75rem;color:var(--text-tertiary, #999);margin-top:.75rem;padding:.5rem;background:var(--bg-tertiary, #fafafa);border-radius:.25rem;word-break:break-all}.rom-actions{display:flex;gap:.75rem;margin-top:1.5rem}.rom-upload-zone{border:2px dashed var(--border-color, #d0d0d0);border-radius:1rem;padding:3rem 2rem;text-align:center;background:var(--bg-secondary, #fafafa);transition:all .3s ease;cursor:pointer}.rom-upload-zone:hover{border-color:var(--primary-color, #007bff);background:var(--bg-hover, #f0f7ff)}.rom-upload-zone.dragging{border-color:var(--primary-color, #007bff);background:var(--bg-active, #e6f2ff);transform:scale(1.02)}.rom-upload-zone.uploading{border-color:var(--success-color, #28a745);background:var(--bg-success, #f0fff4)}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-text{font-size:1.125rem;font-weight:500;color:var(--text-primary, #1a1a1a);margin-bottom:.5rem}.upload-subtext{font-size:.875rem;color:var(--text-secondary, #666);margin:1rem 0}.upload-info{font-size:.875rem;color:var(--text-tertiary, #999);margin-top:1rem}.upload-progress{padding:2rem}.progress-bar{width:100%;height:.5rem;background:var(--bg-tertiary, #e0e0e0);border-radius:.25rem;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:var(--primary-color, #007bff);transition:width .3s ease;border-radius:.25rem}.progress-text{font-size:1rem;font-weight:500;color:var(--text-primary, #1a1a1a)}.loading{text-align:center;padding:3rem;color:var(--text-secondary, #666);font-size:1rem}.legal-notice{font-size:.75rem;color:var(--text-tertiary, #999);margin-top:1.5rem;text-align:center;line-height:1.5}@media (max-width: 768px){.rom-actions{flex-direction:column}.rom-actions button{width:100%}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.upload-text{font-size:1rem}}.save-manager{width:100%;max-width:1200px;margin:0 auto}.empty-state{text-align:center;padding:3rem;background:var(--bg-secondary, #fafafa);border-radius:.75rem;border:1px solid var(--border-color, #e0e0e0)}.empty-state p{color:var(--text-secondary, #666);margin-bottom:.5rem}.empty-subtext{font-size:.875rem;color:var(--text-tertiary, #999)}.saves-container{display:flex;flex-direction:column;gap:2rem}.rom-saves-group{background:#fff;border:1px solid var(--border-color, #e0e0e0);border-radius:.75rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.rom-saves-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #e0e0e0)}.rom-saves-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.save-count{padding:.375rem .75rem;background:var(--bg-secondary, #f5f5f5);border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary, #666)}.saves-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.save-card{background:var(--bg-tertiary, #fafafa);border:1px solid var(--border-color, #e0e0e0);border-radius:.5rem;padding:1rem;transition:all .2s ease}.save-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.save-info{margin-bottom:1rem}.save-slot-badge{display:inline-block;padding:.25rem .5rem;background:var(--primary-color, #007bff);color:#fff;border-radius:.25rem;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.save-meta{font-size:.875rem;color:var(--text-secondary, #666);margin-bottom:.375rem;display:flex;align-items:center;gap:.25rem}.save-actions{display:flex;gap:.5rem}.save-actions button{flex:1}.save-limit-warning{margin-top:1rem;padding:.75rem 1rem;background:var(--warning-bg, #fff3cd);border:1px solid var(--warning-border, #ffc107);border-radius:.5rem;color:var(--warning-text, #856404);font-size:.875rem;text-align:center}.btn-small{padding:.5rem 1rem;font-size:.875rem}@media (max-width: 768px){.saves-grid{grid-template-columns:1fr}.rom-saves-header{flex-direction:column;align-items:flex-start;gap:.75rem}.save-actions{flex-direction:column}.save-actions button{width:100%}}@media (max-width: 480px){.rom-saves-group{padding:1rem}.save-card{padding:.75rem}}.dashboard-container{max-width:1200px;margin:0 auto;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{margin-bottom:var(--spacing-xl)}.header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.dashboard-header h1{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xs);letter-spacing:-.02em}.header-subtitle{color:var(--color-text-secondary);font-size:.95rem;margin:0}.header-actions{display:flex;gap:var(--spacing-sm);align-items:center}.dashboard-header .btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);white-space:nowrap}.btn-icon-text{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.btn-text-desktop{display:inline}@media (max-width: 640px){.btn-text-desktop{display:none}.btn-icon-text{padding:10px 12px}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(30,41,59,.8) 100%);border:1px solid rgba(51,65,85,.6);border-radius:12px;padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);transition:all .2s ease}.stat-card:hover{border-color:#3b82f680;transform:translateY(-2px);box-shadow:0 8px 16px #0003}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon-primary{background:linear-gradient(135deg,#3b82f633,#3b82f61a);color:var(--color-primary)}.stat-icon-success{background:linear-gradient(135deg,#10b98133,#10b9811a);color:var(--color-success)}.stat-icon-warning{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--color-warning)}.stat-content{flex:1;min-width:0}.stat-value{font-size:1.75rem;font-weight:700;line-height:1.2;color:var(--color-text);letter-spacing:-.02em}.stat-label{font-size:.875rem;color:var(--color-text-secondary);margin-top:2px}.controls-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:280px;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:var(--spacing-md);color:var(--color-text-muted);pointer-events:none}.search-input{width:100%;padding:10px var(--spacing-md) 10px 44px;background-color:var(--color-bg-secondary);border:1px solid var(--color-bg-tertiary);border-radius:var(--border-radius);color:var(--color-text);font-size:.95rem;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--color-primary);background-color:#1e293bcc;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:var(--color-text-muted)}.search-clear{position:absolute;right:var(--spacing-sm);background:transparent;border:none;padding:var(--spacing-xs);color:var(--color-text-muted);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-clear:hover{background-color:#ffffff0d;color:var(--color-text)}.sort-options{display:flex;align-items:center;gap:var(--spacing-sm)}.sort-label{font-size:.9rem;color:var(--color-text-secondary);white-space:nowrap}.sort-select{padding:10px var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-bg-tertiary);border-radius:var(--border-radius);color:var(--color-text);font-size:.95rem;cursor:pointer;transition:all .2s ease}.sort-select:hover{border-color:var(--color-primary)}.sort-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(30,41,59,.6) 100%);border:1px solid var(--color-bg-tertiary);border-radius:16px;margin-top:var(--spacing-xl);max-width:600px;margin-left:auto;margin-right:auto}.empty-state-icon{width:80px;height:80px;margin:0 auto var(--spacing-lg);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f626,#8b5cf626);border-radius:20px;color:var(--color-primary)}.empty-state h2{font-size:1.75rem;margin-bottom:var(--spacing-md);font-weight:700;letter-spacing:-.02em}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:1rem;line-height:1.6}.legal-notice{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-bg-tertiary);font-size:.85rem;color:var(--color-text-muted);line-height:1.5}.no-results{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.no-results svg{margin-bottom:var(--spacing-md);opacity:.5}.no-results h3{font-size:1.25rem;margin-bottom:var(--spacing-sm);color:var(--color-text)}.no-results p{margin-bottom:var(--spacing-lg)}.saves-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.save-card{background:var(--color-bg-secondary);border:1px solid var(--color-bg-tertiary);border-radius:12px;overflow:hidden;transition:all .2s ease;display:flex;flex-direction:column}.save-card:hover{border-color:#3b82f680;transform:translateY(-4px);box-shadow:0 12px 24px #0000004d}.save-thumbnail{height:120px;background:linear-gradient(135deg,#3b82f626,#8b5cf626);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--color-bg-tertiary)}.game-icon{width:64px;height:64px;border-radius:12px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:.05em;box-shadow:0 4px 12px #0000004d}.save-info{padding:var(--spacing-md);flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.game-title{font-size:1.1rem;font-weight:600;margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;letter-spacing:-.01em}.save-meta-row{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--color-text-secondary)}.meta-item svg{opacity:.7;flex-shrink:0}.save-slot-badge{display:inline-flex;align-items:center;padding:4px 10px;background:#3b82f626;border:1px solid rgba(59,130,246,.3);border-radius:6px;font-size:.8rem;color:var(--color-primary);font-weight:500;width:fit-content}.save-actions{padding:var(--spacing-md);padding-top:0;display:flex;gap:var(--spacing-sm)}.btn-play{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-icon{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.skeleton{background:linear-gradient(90deg,#33415566,#33415599,#33415566);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--border-radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-title{height:32px;width:200px}.skeleton-button{height:40px;width:140px;border-radius:var(--border-radius)}.skeleton-card{border:1px solid var(--color-bg-tertiary)}.skeleton-stat{height:60px;width:100%}.skeleton-card-content{height:200px;width:100%}.btn{padding:10px 20px;border-radius:var(--border-radius);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff}.btn-primary:hover{background:linear-gradient(135deg,var(--color-primary-dark),#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text);border:1px solid var(--color-bg-tertiary)}.btn-secondary:hover{background-color:#334155cc;border-color:var(--color-primary)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-bg-tertiary)}.btn-ghost:hover{background-color:#ef44441a;border-color:var(--color-danger);color:var(--color-danger)}.btn-large{padding:14px 28px;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}@media (max-width: 768px){.dashboard-header h1{font-size:1.75rem}.header-content{flex-direction:column;align-items:stretch}.stats-grid{grid-template-columns:1fr}.controls-bar{flex-direction:column;align-items:stretch}.search-box{min-width:auto}.sort-options{width:100%;justify-content:space-between}.sort-select{flex:1}.saves-grid{grid-template-columns:1fr}}@media (max-width: 480px){.dashboard-container{padding:0 var(--spacing-sm)}.stat-value{font-size:1.5rem}.save-actions{flex-direction:column}.btn-play,.btn-icon{width:100%}}@media (prefers-reduced-motion: reduce){.dashboard-container,.stat-card,.save-card,.btn,.search-input,.skeleton{animation:none!important;transition:none!important}}.btn:focus-visible,.search-input:focus-visible,.sort-select:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-contrast: high){.stat-card,.save-card,.empty-state{border-width:2px}.btn-ghost:hover{background-color:#ef444433}}.tabs-nav{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--color-bg-tertiary);overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;color:var(--color-text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s ease;white-space:nowrap}.tab-button:hover{color:var(--color-text);background-color:#3b82f60d}.tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-button svg{flex-shrink:0}.tab-content{animation:fadeIn .3s ease-in}.key-bindings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.key-bindings-modal{background-color:var(--color-bg-secondary);border:2px solid var(--color-bg-tertiary);border-radius:var(--border-radius);width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.key-bindings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-bg-tertiary)}.key-bindings-header h2{font-size:1.5rem;color:var(--color-text);margin:0}.close-button{background:transparent;border:none;color:var(--color-text-secondary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--border-radius);transition:all .2s;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.close-button:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.key-bindings-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.key-bindings-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:.95rem}.conflict-warning{background-color:#ef44441a;border:1px solid var(--color-danger);border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--color-danger)}.conflict-warning strong{font-weight:600}.button-groups{display:flex;flex-direction:column;gap:var(--spacing-lg)}.button-group{background-color:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-md)}.group-title{font-size:1rem;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.5px}.button-mappings{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.button-mapping{display:flex;flex-direction:column;gap:var(--spacing-sm)}.button-label{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.key-capture-button{background-color:var(--color-bg-tertiary);color:var(--color-text);border:2px solid var(--color-bg-tertiary);padding:var(--spacing-md);border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px;display:flex;align-items:center;justify-content:center}.key-capture-button:hover{background-color:var(--color-bg-secondary);border-color:var(--color-primary)}.key-capture-button.capturing{border-color:var(--color-primary);background-color:var(--color-primary);animation:pulse 1.5s infinite}.key-capture-button.conflict{border-color:var(--color-danger);background-color:#ef44441a}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.capturing-text{color:#fff;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.key-display{font-family:Courier New,monospace;font-size:1.1rem}.key-display.unset{color:var(--color-text-muted);font-style:italic}.key-bindings-tips{margin-top:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--color-bg);border-radius:var(--border-radius);border-left:4px solid var(--color-primary)}.key-bindings-tips h4{font-size:.95rem;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.key-bindings-tips ul{list-style:none;padding:0;margin:0}.key-bindings-tips li{color:var(--color-text-secondary);font-size:.9rem;padding:var(--spacing-xs) 0;padding-left:var(--spacing-md);position:relative}.key-bindings-tips li:before{content:"•";position:absolute;left:0;color:var(--color-primary)}.key-bindings-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-top:1px solid var(--color-bg-tertiary);gap:var(--spacing-md)}.footer-actions{display:flex;gap:var(--spacing-md)}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-primary:disabled{background-color:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:not-allowed}.btn-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text)}.btn-secondary:hover{background-color:var(--color-bg)}.btn-tertiary{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-bg-tertiary)}.btn-tertiary:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.toast-success{position:fixed;top:20px;right:20px;background-color:var(--color-success);color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius);box-shadow:0 4px 12px #0000004d;z-index:2000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.key-bindings-modal{width:95%;max-height:95vh}.button-mappings{grid-template-columns:1fr}.key-bindings-footer{flex-direction:column;align-items:stretch}.footer-actions{width:100%}.footer-actions button{flex:1}}@media (prefers-reduced-motion: reduce){.key-bindings-overlay,.key-bindings-modal,.toast-success,.key-capture-button.capturing{animation:none}}.emulator-container{min-height:100vh;background-color:var(--color-bg);padding:var(--spacing-lg)}.emulator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-bg-secondary)}.emulator-header h1{font-size:2rem;margin:0}.btn-back{background-color:var(--color-bg-tertiary);color:var(--color-text)}.btn-back:hover{background-color:var(--color-bg-secondary)}.status-info{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--border-radius)}.fps-counter{font-family:Courier New,monospace;font-size:1.2rem;font-weight:700;color:var(--color-success)}.last-save-time{font-size:.9rem;color:var(--color-text-secondary)}.auto-save-status{font-size:.9rem;color:var(--color-success)}.error-banner{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-error);color:#fff;padding:var(--spacing-md);border-radius:var(--border-radius);margin-bottom:var(--spacing-lg)}.error-banner button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0 var(--spacing-sm)}.emulator-main{display:grid;grid-template-columns:auto 400px;gap:var(--spacing-xl);align-items:start}@media (max-width: 1200px){.emulator-main{grid-template-columns:1fr}}.screens-container{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:var(--color-bg-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius)}.screen-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.screen-wrapper label,.screen-wrapper .screen-label{font-size:.875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.screen,.ds-screen{border:3px solid var(--color-bg-tertiary);border-radius:4px;background-color:#000;cursor:default;box-shadow:0 4px 12px #0000004d;image-rendering:pixelated;image-rendering:crisp-edges}.bottom-screen{cursor:crosshair}.bottom-screen:active{cursor:grabbing}.controls-panel{display:flex;flex-direction:column;gap:var(--spacing-lg);position:relative;z-index:10;background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius)}.rom-upload{background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius);text-align:center}.rom-upload .btn{width:100%}.emulator-controls{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius)}.emulator-controls .btn{padding:var(--spacing-md);font-size:1rem}.keyboard-guide{background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius);border-left:4px solid var(--color-primary)}.keyboard-guide-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.keyboard-guide h3{margin:0;font-size:1.1rem}.keyboard-note{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:.9rem;margin-bottom:0}.keyboard-warning{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:6px;color:var(--color-warning);font-size:.85rem;margin-bottom:0}.key-mappings{display:flex;flex-direction:column;gap:var(--spacing-md)}.key-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.key-group strong{color:var(--color-text);font-size:.9rem;margin-bottom:var(--spacing-xs)}.key-group span{color:var(--color-text-secondary);font-size:.85rem;padding-left:var(--spacing-sm)}.btn-small{padding:6px 12px;font-size:.875rem}.controls-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);font-size:.875rem}.controls-grid kbd{background-color:var(--color-bg-tertiary);padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:.85rem;border:1px solid var(--color-bg);box-shadow:0 1px 2px #0003}.rom-info{background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius)}.rom-info h3{margin-top:0;margin-bottom:var(--spacing-md);font-size:1.1rem}.info-item{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-bg-tertiary)}.info-item:last-child{border-bottom:none}.info-item span:first-child{color:var(--color-text-secondary);font-weight:500}.info-item .hash{font-family:Courier New,monospace;font-size:.875rem}.status-running{color:var(--color-success);font-weight:700}.status-paused{color:var(--color-warning);font-weight:700}.legal-notice{background-color:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--border-radius);border-left:4px solid var(--color-warning);font-size:.875rem;color:var(--color-text-secondary)}.legal-notice p{margin:0;line-height:1.5}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.spinner{border:4px solid var(--color-bg-tertiary);border-top:4px solid var(--color-primary);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spinner{animation:none;border-top-color:var(--color-primary)}}.loading-overlay p{margin-top:var(--spacing-lg);color:#fff;font-size:1.2rem}.bottom-screen{touch-action:manipulation}.emulator-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.back-button{background-color:var(--color-bg-tertiary);color:var(--color-text);border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);cursor:pointer;font-size:1rem;transition:background-color .2s}.back-button:hover{background-color:var(--color-bg-secondary)}.error-message{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-error);color:#fff;padding:var(--spacing-md);border-radius:var(--border-radius);margin-bottom:var(--spacing-lg)}.error-message button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0 var(--spacing-sm)}.loading-message{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-secondary);border-radius:var(--border-radius);margin-bottom:var(--spacing-lg)}.rom-info-panel{background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius)}.rom-info-panel h3{margin-top:0;margin-bottom:var(--spacing-md);font-size:1.1rem}.rom-details{display:flex;flex-direction:column;gap:var(--spacing-xs)}.rom-details p{margin:0;font-size:.9rem;color:var(--color-text-secondary)}.control-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.upload-button{display:inline-block;background-color:red;color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius);cursor:pointer;text-align:center;font-size:1.2rem;font-weight:700;transition:all .3s;box-shadow:0 0 20px #f009;animation:pulse-red 2s infinite;border:3px solid #ff3333}.upload-button:hover{background-color:#c00;transform:scale(1.05);box-shadow:0 0 30px #ff0000e6}@keyframes pulse-red{0%,to{box-shadow:0 0 20px #f009}50%{box-shadow:0 0 40px red}}.control-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.control-button{background-color:var(--color-bg-tertiary);color:var(--color-text);border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);cursor:pointer;font-size:.9rem;transition:background-color .2s;flex:1;min-width:120px}.control-button:hover{background-color:var(--color-bg-secondary)}.control-button-info{background-color:#3b82f633;border:1px solid rgba(59,130,246,.4)}.control-button-info:hover{background-color:#3b82f64d}.control-button-save{background-color:#22c55e33;border:1px solid rgba(34,197,94,.4)}.control-button-save:hover{background-color:#22c55e4d}.tech-info{background-color:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--border-radius);font-size:.875rem;color:var(--color-text-secondary)}.tech-info p{margin:var(--spacing-xs) 0}.desmond-container{background-color:var(--color-bg-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius);display:flex;justify-content:center;align-items:center;min-height:400px;max-height:600px;position:relative;z-index:1;overflow:hidden;margin-bottom:var(--spacing-lg)}.core-info-banner{background-color:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--border-radius);border-left:4px solid var(--color-primary);margin-bottom:var(--spacing-lg)}.core-info-banner strong{display:block;font-size:1.1rem;margin-bottom:var(--spacing-xs);color:var(--color-text)}.core-limitations{margin-top:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.limitation-item{font-size:.875rem;color:#f59e0b;padding:var(--spacing-xs) var(--spacing-sm);background-color:#f59e0b1a;border-radius:var(--border-radius-sm);border-left:3px solid #f59e0b}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-light: #60a5fa;--color-secondary: #8b5cf6;--color-success: #10b981;--color-danger: #ef4444;--color-warning: #f59e0b;--color-bg: #0f172a;--color-bg-secondary: #1e293b;--color-bg-tertiary: #334155;--color-text: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--border-radius: 8px;--border-radius-sm: 6px;--border-radius-lg: 12px;--border-radius-xl: 16px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-bottom:2px solid var(--color-primary);text-align:center}.app-header h1{font-size:2rem;margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header p{color:var(--color-text-secondary)}.app-main{flex:1;padding:var(--spacing-xl);max-width:1200px;margin:0 auto;width:100%}.app-main ul{list-style:none;margin-top:var(--spacing-lg);font-size:1.1rem}.app-main li{padding:var(--spacing-sm);color:var(--color-text-secondary)}button{background-color:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);font-family:inherit}button:hover{background-color:var(--color-primary-dark);transform:translateY(-1px)}button:active{transform:translateY(0)}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.6;transform:none!important}input,select,textarea{background-color:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-bg-tertiary);padding:10px var(--spacing-md);border-radius:var(--border-radius);font-size:.95rem;font-family:inherit;transition:all var(--transition-base)}input:hover,select:hover,textarea:hover{border-color:#3b82f680}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
