body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}#root{min-height:100vh}.usage-topbar{background:#0f1d32f2;border-bottom:1px solid #ffffff0f;position:-webkit-sticky;position:sticky;top:0;z-index:1001}.usage-topbar-inner{align-items:center;color:var(--text-muted);display:flex;font-size:11px;gap:var(--space-3);justify-content:center;margin:0 auto;max-width:1600px;padding:4px var(--space-4)}.usage-topbar-item{align-items:center;display:flex;gap:3px}.usage-topbar-sep{opacity:.35}.usage-topbar-plan{background:#f97316;background:var(--accent-primary,#f97316);border-radius:var(--radius-sm);color:#fff;font-size:9px;font-weight:700;letter-spacing:.5px;margin-left:var(--space-1);padding:1px 6px;text-transform:uppercase}.main-navigation{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-lg);position:-webkit-sticky;position:sticky;top:28px;transition:all var(--transition-normal);z-index:1000}.nav-container{justify-content:space-between;margin:0 auto;max-width:1600px;min-height:56px;overflow-x:hidden;padding:var(--space-3) var(--space-4)}.nav-container,.nav-logo{align-items:center;display:flex;gap:var(--space-3)}.nav-logo{border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.nav-logo:hover{background:var(--bg-overlay);transform:translateY(-1px)}.logo-icon{align-items:center;border:2px solid #fff3;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:#fff;display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.logo-icon,.logo-text{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))}.logo-text{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:-.025em}.nav-items{flex:1 1;gap:var(--space-1);justify-content:center;min-width:0}.nav-item,.nav-items{align-items:center;display:flex}.nav-item{background:#0000;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-2);overflow:hidden;padding:var(--space-2) var(--space-3);position:relative;text-decoration:none;transition:all var(--transition-fast)}.nav-item:before{background:linear-gradient(90deg,#0000,var(--bg-overlay),#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-normal);width:100%}.nav-item:hover{background:var(--bg-overlay);color:var(--text-primary);transform:translateY(-1px)}.nav-item:hover:before{left:100%}.nav-item.active{background:var(--color-primary-alpha);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.nav-icon{font-size:var(--font-size-lg)}.nav-label{white-space:nowrap}.nav-theme{align-items:center;display:flex}@media (max-width:1024px){.nav-label{display:none}.nav-item{padding:var(--space-2)}}@media (max-width:768px){.nav-container{padding:var(--space-2) var(--space-3)}.nav-items{gap:var(--space-1)}.nav-item{font-size:var(--font-size-xs);padding:var(--space-2)}.logo-text,.nav-label,.usage-topbar{display:none}}@media (max-width:480px){.nav-container{padding:var(--space-2) var(--space-3)}.nav-items{gap:var(--space-1)}.nav-item{padding:var(--space-2)}.logo-text{font-size:var(--font-size-base)}.logo-icon{font-size:16px;height:32px;width:32px}}.nav-usage{background:var(--bg-secondary);background:var(--bg-tertiary,var(--bg-secondary));border:1px solid var(--border-color);border-radius:9999px;border-radius:var(--radius-full,9999px);color:var(--text-secondary);cursor:default;font-size:var(--font-size-xs);gap:var(--space-2);margin-left:auto;padding:var(--space-1) var(--space-3);white-space:nowrap}.nav-usage,.nav-usage-label{align-items:center;display:flex}.nav-usage-label{gap:2px}.nav-usage-separator{color:var(--text-secondary);color:var(--text-tertiary,var(--text-secondary));opacity:.5}.nav-usage-plan{background:#f97316;background:var(--accent-primary,#f97316);border-radius:var(--radius-sm);color:#fff;font-size:10px;font-weight:600;letter-spacing:.5px;padding:1px 6px;text-transform:uppercase}.nav-actions{flex-shrink:0}.nav-actions,.nav-user-inline{align-items:center;display:flex}.nav-user-inline{gap:var(--space-2)}.nav-user-avatar{border:2px solid var(--border-color);border-radius:50%;height:30px;object-fit:cover;width:30px}.nav-user-avatar-placeholder{align-items:center;background:#f97316;background:var(--accent-primary,#f97316);color:#fff;display:flex;font-size:var(--font-size-xs);font-weight:600;justify-content:center}.nav-user-name{color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-signout-btn{background:#0000;border:1px solid #ffffff1f;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:500;padding:4px 10px;transition:all var(--transition-fast);white-space:nowrap}.nav-signout-btn:hover{background:#ef44441a;border-color:#ef44444d;color:var(--color-error)}.upload-page{background:var(--bg-primary);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;position:relative}.upload-page:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='25' cy='25' r='1' fill='rgba(255,255,255,0.03)'/%3E%3Ccircle cx='75' cy='75' r='1' fill='rgba(255,255,255,0.03)'/%3E%3Ccircle cx='50' cy='10' r='.5' fill='rgba(255,255,255,0.02)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.upload-main{align-items:center;display:flex;flex:1 1;justify-content:center;padding:var(--space-8);position:relative;z-index:1}.upload-container{margin:0 auto;max-width:900px;width:100%}.upload-form{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);overflow:hidden;padding:var(--space-8);position:relative}.upload-form:before{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary),var(--color-success));border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.form-section{margin-bottom:var(--space-6);position:relative}.form-label{color:var(--text-primary);display:block;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);letter-spacing:-.01em;margin-bottom:var(--space-3)}.input-mode-toggle{background:var(--bg-surface);border-radius:var(--radius-lg);gap:var(--space-2);margin-bottom:var(--space-4);padding:var(--space-1)}.mode-button{align-items:center;background:#0000;border-radius:var(--radius-md);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-2);justify-content:center;padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.mode-button:hover{background:var(--bg-overlay)}.mode-button.active{background:var(--color-primary);box-shadow:var(--shadow-sm)}.job-description-input{background:var(--bg-surface);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-family:inherit;font-size:var(--font-size-base);line-height:var(--line-height-relaxed);min-height:120px;padding:var(--space-4);resize:vertical;transition:all var(--transition-fast);width:100%}.job-description-input:focus{background:var(--bg-card);border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha);outline:none}.char-count{color:var(--text-muted);font-size:var(--font-size-xs)}.file-upload-area{background:var(--bg-surface);border:2px dashed var(--border-color);border-radius:var(--radius-xl);cursor:pointer;overflow:hidden;padding:var(--space-4) var(--space-6);position:relative;text-align:center;transition:all var(--transition-normal)}.file-upload-area:before{background:linear-gradient(45deg,#0000 30%,var(--color-primary-alpha) 50%,#0000 70%);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-normal)}.file-upload-area.drag-active,.file-upload-area:hover{background:var(--bg-card);border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.file-upload-area.drag-active:before,.file-upload-area:hover:before{opacity:1}.file-input{display:none}.file-upload-label{cursor:pointer;display:block;position:relative;z-index:1}.upload-icon{color:var(--text-muted);font-size:2.5rem;height:48px;margin-bottom:var(--space-2);transition:color var(--transition-fast);width:48px}.file-upload-area:hover .upload-icon{color:var(--color-primary)}.upload-text{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.upload-hint{color:var(--text-secondary);font-size:var(--font-size-sm)}.file-list{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:var(--space-4);padding:var(--space-4)}.file-list h4{color:var(--text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-4) 0}.file-item{background:var(--bg-card);border-radius:var(--radius-md);margin-bottom:var(--space-2);padding:var(--space-3);position:relative}.file-item:hover{background:var(--bg-surface);box-shadow:var(--shadow-md);transform:translateX(4px)}.file-item:last-child{margin-bottom:0}.file-item-valid{border-left:3px solid var(--color-success)}.file-item-too-large{border-left:3px solid var(--color-error)}.file-item-over-quota{border-left:3px solid var(--color-warning)}.file-status-warning{font-size:.85em;margin-left:8px}.file-status-too-large{color:var(--color-error)}.file-status-over-quota{color:var(--color-warning)}.upload-limit-reached{color:var(--color-error)}.file-count-warning{color:var(--color-warning);font-size:.85em;margin-left:8px}.file-details{align-items:center;gap:var(--space-3)}.file-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.file-size{background:var(--bg-glass);border-radius:var(--radius-sm);font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2)}.file-remove{background:var(--color-error);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.file-remove:hover{background:var(--color-error-hover);box-shadow:var(--shadow-md);transform:scale(1.05)}.checkbox-container{align-items:flex-start;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-4);transition:background-color var(--transition-fast)}.checkbox-container:hover{background-color:#ffffff08}.enrich-checkbox{accent-color:var(--color-primary);cursor:pointer;height:20px;margin-top:4px;width:20px}.checkbox-label{display:flex;flex:1 1;flex-direction:column;gap:var(--space-1)}.checkbox-label strong{color:var(--text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.checkbox-description{color:var(--text-muted);font-size:var(--font-size-sm);line-height:1.5}.form-actions{margin-top:var(--space-8)}.submit-button{background:linear-gradient(135deg,#fb923c,#ea580c);border-radius:var(--radius-lg);box-shadow:0 4px 14px #f9731659;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);overflow:hidden;padding:var(--space-4) var(--space-8);position:relative;transition:all var(--transition-fast)}.submit-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-normal);width:100%}.submit-button:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}.submit-button:hover:before{left:100%}.url-input-section{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4)}.url-input-group{margin-bottom:var(--space-3)}.url-input{background:var(--bg-card);font-size:var(--font-size-base);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.url-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha)}.fetch-button{background:var(--color-info);box-shadow:var(--shadow-sm);font-weight:var(--font-weight-medium);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.fetch-button:hover:not(:disabled){background:var(--color-secondary-hover);box-shadow:var(--shadow-md)}.url-hint{font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.fetched-content{background:var(--bg-card);border:1px solid var(--border-color);padding:var(--space-4)}.content-preview{margin-bottom:var(--space-3)}.content-preview strong{color:var(--text-primary);display:block;font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.content-text{background:var(--bg-surface);color:var(--text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);max-height:100px;padding:var(--space-2)}.content-stats{color:var(--text-muted);font-size:var(--font-size-xs)}.processing-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh}.processing-container{padding:2rem;text-align:center}.processing-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;padding:3rem 2rem}.processing-content h2{color:var(--text-primary);font-size:1.8rem;margin:1.5rem 0 2rem}.processing-steps{margin:2rem 0}.step{align-items:center;background:var(--bg-surface);border-radius:var(--radius-md);color:var(--text-secondary);display:flex;justify-content:flex-start;margin-bottom:.5rem;padding:.75rem;transition:all var(--transition-fast)}.step.active{background:var(--bg-primary-light);color:var(--color-primary)}.step-icon{font-size:1.2rem;margin-right:.75rem}.step-text{font-weight:500}.processing-info{margin-top:2rem}.processing-info p{margin:.5rem 0}.error-state{background:var(--bg-card);border:1px solid var(--border-danger);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;padding:3rem 2rem}.error-icon{font-size:3rem;margin-bottom:1rem}.error-state h2{color:var(--text-danger);margin-bottom:1rem}.error-message{color:var(--text-primary);margin-bottom:1rem;padding:1rem}.results-page{background:var(--bg-primary);min-height:100vh;padding:.5rem 0}.results-container{margin:0 auto;max-width:1400px;padding:0 1rem}.results-actions-minimal{display:flex;gap:1rem;justify-content:flex-end;margin-bottom:1rem;padding:.5rem 0}.export-button-minimal,.submit-button-minimal{align-items:center;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all var(--transition-fast)}.export-button-minimal:hover{background:var(--bg-card);border-color:var(--border-hover);transform:translateY(-1px)}.submit-button-minimal{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.submit-button-minimal:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px)}.results-title h1{color:var(--text-primary);font-size:2.2rem;margin:0 0 .5rem}.session-info{color:var(--text-secondary);font-family:monospace;font-size:.9rem;margin:0}.results-actions{display:flex;flex-wrap:wrap;gap:1rem}.export-button{background:var(--bg-surface);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all var(--transition-fast)}.export-button:hover{background:var(--bg-card);border-color:var(--border-hover);transform:translateY(-1px)}.no-results{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:4rem 2rem}.no-results h2{color:var(--text-primary);margin-bottom:1rem}.no-results p{color:var(--text-secondary);margin-bottom:2rem}.results-footer{margin-top:1rem;text-align:center}.back-to-top{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;padding:.75rem 1.5rem;transition:all var(--transition-fast)}.back-to-top:hover{background:var(--bg-card);border-color:var(--border-hover);color:var(--text-primary)}@media (max-width:768px){.upload-main{padding:1rem}.upload-form{padding:1.5rem}.results-header{flex-direction:column;gap:1.5rem;text-align:center}.results-actions{justify-content:center}.processing-content{padding:2rem 1.5rem}.step{justify-content:center}}.input-mode-toggle{border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;gap:.5rem;margin-bottom:1rem;overflow:hidden}.mode-button{background:var(--bg-surface);border:none;border-radius:0;color:var(--text-secondary);cursor:pointer;flex:1 1;font-weight:500;padding:.75rem 1rem;transition:all .2s ease}.mode-button:hover{background:var(--bg-hover);color:var(--text-primary)}.mode-button.active{background:var(--accent-primary);color:#fff;font-weight:600}.url-input-section{display:flex;flex-direction:column;gap:1rem}.url-input-group{align-items:stretch;gap:.5rem}.url-input{background:var(--bg-surface);border-radius:var(--radius-md);font-size:1rem;padding:1rem}.url-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #f9731626}.fetch-button{background:var(--accent-primary);border-radius:var(--radius-md);gap:.5rem;padding:0 1.5rem}.fetch-button:disabled{background:var(--text-muted)}.url-hint{color:var(--text-secondary);font-size:.9rem;font-style:italic}.fetched-content{background:var(--bg-surface);border:1px solid var(--border-success);border-radius:var(--radius-md);margin-top:1rem;padding:1rem}.content-preview{display:flex;flex-direction:column;gap:.5rem}.content-text{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.4;max-height:150px;overflow-y:auto;padding:.75rem}.content-stats{color:var(--text-secondary);font-size:.8rem;text-align:right}.page-header{margin-bottom:var(--space-8);text-align:center}.page-header h1{color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:var(--space-2)}.page-description{color:var(--text-secondary);font-size:1.1rem;margin:0 auto;max-width:600px}.upload-results{flex-direction:column}.result-item,.upload-results{display:flex;gap:var(--space-3)}.result-item{align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);transition:all .3s ease}.result-item.success{background:#10b9810d;background:var(--success-bg,#10b9810d);border-color:#10b981;border-color:var(--success-color,#10b981)}.result-item.error{background:#ef44440d;background:var(--error-bg,#ef44440d);border-color:#ef4444;border-color:var(--error-color,#ef4444)}.result-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:1.2rem;height:32px;justify-content:center;width:32px}.result-item.success .result-icon{background:#10b981;background:var(--success-color,#10b981);color:#fff}.result-item.error .result-icon{background:#ef4444;background:var(--error-color,#ef4444);color:#fff}.result-info{flex:1 1}.result-filename{margin-bottom:var(--space-1)}.result-details{color:var(--text-secondary);font-size:.9rem}.result-error{color:#ef4444;color:var(--error-color,#ef4444);font-size:.9rem}.file-input-hidden{display:none}.input-method-selector{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.method-button{align-items:center;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:500;gap:var(--space-2);justify-content:center;padding:var(--space-3) var(--space-4);transition:all .2s ease}.method-button:hover{background:var(--bg-hover);border-color:var(--accent-color)}.method-button.active{background:var(--accent-color);border-color:var(--accent-color);box-shadow:0 0 0 3px #4338ca1a;color:#fff}.method-button:disabled{cursor:not-allowed;opacity:.5}.url-input-group{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.url-input{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);flex:1 1;font-size:.95rem;padding:var(--space-3);transition:all .2s ease}.url-input:focus{background:var(--bg-primary);border-color:var(--accent-color);box-shadow:0 0 0 3px #4338ca1a;outline:none}.fetch-button{align-items:center;background:var(--accent-color);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-6);transition:all .2s ease;white-space:nowrap}.fetch-button:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #4338ca4d;transform:translateY(-1px)}.fetch-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.fetched-content{margin-top:var(--space-4)}.content-preview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin-top:var(--space-2);max-height:200px;overflow-y:auto;padding:var(--space-4)}.char-count{color:var(--text-tertiary);font-size:.85rem;margin-top:var(--space-2);text-align:right}.submit-button.search-button{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);flex:2 1}.submit-button.secondary-button{background:var(--text-muted);flex:1 1}.submit-button.secondary-button:hover:not(:disabled){background:var(--text-secondary)}.form-actions{flex-wrap:wrap;gap:1rem}.form-actions button{flex:1 1;min-width:200px}.top-n-selector{align-items:center;background:var(--bg-surface);border-radius:8px;display:flex;gap:1rem;padding:1rem}.top-n-slider{-webkit-appearance:none;background:var(--border-color);border-radius:3px;flex:1 1;height:6px;outline:none}.top-n-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--color-primary);border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:20px;width:20px}.top-n-slider::-moz-range-thumb{background:var(--color-primary);border:none;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:20px;width:20px}.top-n-value{color:var(--color-primary);font-size:1.1rem;font-weight:600;min-width:100px;text-align:center}.search-results-section{border-top:2px solid var(--border-color);margin-top:2rem;padding-top:2rem}.results-header{margin-bottom:1.5rem}.results-header h2{font-size:1.5rem;margin:0 0 .5rem}.results-meta{color:var(--text-muted);font-size:.9rem}.search-results-list{display:flex;flex-direction:column;gap:1rem}.resume-result-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.resume-result-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #f9731626;transform:translateY(-2px)}.result-rank{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:40px;justify-content:center;width:40px}.result-content{flex:1 1}.result-header-row{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.result-filename{color:var(--text-primary);font-size:1.1rem;font-weight:600;word-break:break-word}.result-score{align-items:center;background:var(--color-primary-alpha);border-radius:20px;display:flex;gap:.5rem;padding:.5rem 1rem;white-space:nowrap}.score-label{color:var(--text-muted);font-size:.85rem}.score-value{color:var(--color-primary);font-size:1.1rem;font-weight:700}.result-stats{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem}.stat-item{color:var(--text-muted);font-size:.9rem}.result-snippets{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.snippet-label{color:var(--text-muted);font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.snippet-text{background:var(--bg-surface);border-left:3px solid var(--color-primary);border-radius:4px;color:var(--text-secondary);font-size:.9rem;font-style:italic;line-height:1.5;margin:.5rem 0;padding:.75rem}.no-results{color:var(--text-muted);font-size:1.1rem;padding:3rem;text-align:center}.result-strengths{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-left:4px solid #28a745;border-radius:8px;margin-top:1rem;padding:1rem}.result-strengths .section-label{color:#155724;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.strengths-list{color:#155724;margin:0;padding-left:1.25rem}.strengths-list li{font-size:.9rem;line-height:1.5;margin-bottom:.35rem}.result-improvements{background:linear-gradient(135deg,#fff3cd,#ffeeba);border-left:4px solid #ffc107;border-radius:8px;margin-top:.75rem;padding:1rem}.result-improvements .section-label{color:#856404;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.improvements-list{color:#856404;margin:0;padding-left:1.25rem}.improvements-list li{font-size:.9rem;line-height:1.5;margin-bottom:.35rem}.result-explanation{background:linear-gradient(135deg,#e7f1ff,#cce5ff);border-left:4px solid #007bff;border-radius:8px;margin-top:.75rem;padding:1rem}.result-explanation .section-label{color:#004085;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.result-explanation p{color:#004085;font-size:.9rem;line-height:1.6;margin:0}.results-summary{background:var(--bg-surface);border:2px solid var(--border-color);border-radius:12px;margin-top:2rem;padding:1.5rem}.results-summary h3{color:var(--text-primary);font-size:1.2rem;margin:0 0 1rem}.results-summary p{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin:0}.library-page{min-height:100vh}.library-container{max-width:1200px}.library-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-4)}.library-search{display:flex;flex:1 1;gap:var(--space-2);min-width:300px}.search-input{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);flex:1 1;font-size:var(--font-size-sm);max-width:400px;padding:var(--space-2) var(--space-4)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha);outline:none}.library-actions{display:flex;gap:var(--space-2)}.library-summary{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--space-4);margin-bottom:var(--space-4)}.search-filter-tag{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3)}.total-count{font-weight:var(--font-weight-medium)}.library-table-wrapper{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.library-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:var(--space-16)}.spinner{border:3px solid var(--border-color);border-top-color:var(--color-primary);margin-bottom:var(--space-4)}.library-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--space-16);text-align:center}.empty-icon{color:var(--text-muted);height:64px;margin-bottom:var(--space-4);width:64px}.library-empty h3{color:var(--text-primary);margin:0 0 var(--space-2) 0}.library-empty p{color:var(--text-secondary);margin:0 0 var(--space-6) 0}.library-table{border-collapse:collapse;width:100%}.library-table td,.library-table th{border-bottom:1px solid var(--border-color);padding:var(--space-3) var(--space-4);text-align:left}.library-table th{background:var(--bg-surface);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.library-table tbody tr{transition:background var(--transition-fast)}.library-table tbody tr:hover{background:var(--bg-hover)}.library-table tbody tr.row-selected{background:#f973161a}.col-checkbox{text-align:center;width:50px}.col-filename{min-width:200px}.col-date{width:180px}.col-size,.col-status{width:100px}.col-actions{text-align:center;width:100px}.filename-text{display:block;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{border-radius:var(--radius-full);display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-2);text-transform:capitalize}.status-success{background:#10b98126;color:#059669}.status-warning{background:#f59e0b26;color:#d97706}.status-info{background:#3b82f626;color:#2563eb}.status-error{background:#ef444426;color:#dc2626}.btn-icon{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon-danger:hover{background:#ef444426;color:#dc2626}.library-pagination{align-items:center;background:var(--bg-surface);border-radius:var(--radius-lg);border-top:1px solid var(--border-color);display:flex;gap:var(--space-4);justify-content:center;margin-top:var(--space-4);padding:var(--space-6)}.pagination-info{color:var(--text-secondary);font-size:var(--font-size-sm)}.page-size-select{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}.error-banner{align-items:center;background:#ef444426;border:1px solid #ef44444d;border-radius:var(--radius-lg);color:#dc2626;display:flex;justify-content:space-between;margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4)}.error-close{background:none;border:none;color:#dc2626;cursor:pointer;font-size:1.25rem;line-height:1;padding:0}.btn-sm{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}.btn-secondary{font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-4)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--color-primary)}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-danger{background:#dc2626;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{cursor:not-allowed;opacity:.6}.btn-ghost{background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-width:400px;padding:var(--space-6);width:90%}.modal-content h2{color:var(--text-primary);margin:0 0 var(--space-4) 0}.modal-content p{color:var(--text-secondary);margin:0 0 var(--space-6) 0}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.preview-modal-overlay{padding:var(--space-4)}.preview-modal-content{display:flex;flex-direction:column;height:90vh;max-width:900px;overflow:hidden;padding:0;width:100%}.preview-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:var(--space-4) var(--space-6)}.preview-header h2{font-size:var(--font-size-lg);margin:0;max-width:80%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-body{flex:1 1;overflow:hidden}.preview-iframe{border:none;height:100%;width:100%}.preview-footer{border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;padding:var(--space-4) var(--space-6)}@media (max-width:768px){.library-toolbar{align-items:stretch;flex-direction:column}.library-search{min-width:auto}.library-table td,.library-table th{font-size:var(--font-size-sm);padding:var(--space-2)}.col-date,.col-size{display:none}.library-pagination{flex-wrap:wrap}}.login-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:var(--space-4)}.login-container{max-width:420px;text-align:center;width:100%}.login-logo{margin-bottom:var(--space-6)}.login-logo-icon{display:block;font-size:3rem;margin-bottom:var(--space-2)}.login-logo h1{color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:700;margin:0}.login-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.login-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-4);padding:var(--space-6)}.login-card h2{color:var(--text-primary);font-size:var(--font-size-xl);font-weight:600;margin:0 0 var(--space-2)}.login-card p{color:var(--text-secondary);margin-bottom:var(--space-5)}.login-card p,.login-error{font-size:var(--font-size-sm)}.login-error{background:#fef2f2;background:var(--status-error-bg,#fef2f2);border:1px solid #dc2626;border:1px solid var(--status-error,#dc2626);border-radius:var(--radius-md);color:#dc2626;color:var(--status-error,#dc2626);margin-bottom:var(--space-4);padding:var(--space-3)}.google-signin-btn{align-items:center;background:#fff;border:1px solid #dadce0;border-radius:var(--radius-md);color:#3c4043;cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:500;gap:var(--space-3);justify-content:center;padding:var(--space-3) var(--space-4);transition:background .2s,box-shadow .2s;width:100%}.google-signin-btn:hover:not(:disabled){background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.google-signin-btn:disabled{cursor:not-allowed;opacity:.6}.google-icon{flex-shrink:0}.login-footer{color:var(--text-secondary);color:var(--text-tertiary,var(--text-secondary));font-size:var(--font-size-xs)}.dev-page-title{color:var(--text-primary);font-size:1.75rem;font-size:var(--font-size-2xl,1.75rem);font-weight:700;font-weight:var(--font-weight-bold,700);margin:0 0 4px;margin:0 0 var(--space-1,4px) 0}.dev-page-subtitle{color:var(--text-secondary);font-size:1rem;font-size:var(--font-size-base,1rem);margin:0 0 24px;margin:0 0 var(--space-6,24px) 0}.dev-section{border-top:1px solid #ffffff14;border-top:1px solid var(--border-color,#ffffff14);margin-bottom:32px;margin-bottom:var(--space-8,32px);padding-top:24px;padding-top:var(--space-6,24px)}.dev-section:first-of-type{border-top:none;padding-top:0}.dev-section-title{color:var(--text-primary);font-size:1.125rem;font-size:var(--font-size-lg,1.125rem);font-weight:600;font-weight:var(--font-weight-semibold,600);margin:0 0 8px;margin:0 0 var(--space-2,8px) 0}.dev-section-desc{color:var(--text-secondary);font-size:.875rem;font-size:var(--font-size-sm,.875rem);line-height:1.6;margin:0 0 16px;margin:0 0 var(--space-4,16px) 0}.dev-section-desc code{background:#ffffff0f;background:var(--bg-surface,#ffffff0f);border-radius:4px;border-radius:var(--radius-sm,4px);font-size:.85em;padding:2px 6px}.dev-muted{color:var(--text-secondary);color:var(--text-tertiary,var(--text-secondary));font-style:italic}.dev-error-banner,.dev-muted{font-size:.875rem;font-size:var(--font-size-sm,.875rem)}.dev-error-banner{align-items:center;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;border-radius:var(--radius-lg,8px);color:#ef4444;color:var(--color-error,#ef4444);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--space-4,16px);padding:12px 16px;padding:var(--space-3,12px) var(--space-4,16px)}.dev-error-dismiss{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 0 0 12px;padding:0 0 0 var(--space-3,12px)}.dev-key-create-row{display:flex;gap:12px;gap:var(--space-3,12px);margin-bottom:16px;margin-bottom:var(--space-4,16px)}.dev-key-input{background:#ffffff0f;background:var(--bg-surface,#ffffff0f);border:1px solid #ffffff1a;border:1px solid var(--border-color,#ffffff1a);border-radius:8px;border-radius:var(--radius-lg,8px);color:var(--text-primary);flex:1 1;font-size:.875rem;font-size:var(--font-size-sm,.875rem);outline:none;padding:12px 16px;padding:var(--space-3,12px) var(--space-4,16px);transition:border-color .2s}.dev-key-input::placeholder{color:var(--text-secondary);color:var(--text-tertiary,var(--text-secondary))}.dev-key-input:focus{border-color:#4285f4;border-color:var(--color-primary,#4285f4)}.dev-key-create-btn{background:#4285f4;background:var(--color-primary,#4285f4);border:none;border-radius:8px;border-radius:var(--radius-lg,8px);color:#fff;cursor:pointer;font-size:.875rem;font-size:var(--font-size-sm,.875rem);font-weight:600;font-weight:var(--font-weight-semibold,600);padding:12px 20px;padding:var(--space-3,12px) var(--space-5,20px);transition:opacity .2s;white-space:nowrap}.dev-key-create-btn:hover:not(:disabled){opacity:.9}.dev-key-create-btn:disabled{cursor:not-allowed;opacity:.5}.dev-key-created-banner{background:#22c55e14;border:1px solid #22c55e40;border-radius:8px;border-radius:var(--radius-lg,8px);margin-bottom:16px;margin-bottom:var(--space-4,16px);padding:16px;padding:var(--space-4,16px)}.dev-key-created-header{color:#22c55e;color:var(--color-success,#22c55e);font-size:.875rem;font-size:var(--font-size-sm,.875rem);font-weight:600;font-weight:var(--font-weight-semibold,600);margin-bottom:12px;margin-bottom:var(--space-3,12px)}.dev-key-created-value{align-items:center;background:#0003;background:var(--bg-surface,#0003);border-radius:6px;border-radius:var(--radius-md,6px);display:flex;gap:12px;gap:var(--space-3,12px);overflow-x:auto;padding:12px;padding:var(--space-3,12px)}.dev-key-created-value code{color:var(--text-primary);flex:1 1;font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;font-size:var(--font-size-sm,.875rem);word-break:break-all}.dev-copy-btn{background:#ffffff14;background:var(--bg-surface,#ffffff14);border:1px solid #ffffff1a;border:1px solid var(--border-color,#ffffff1a);border-radius:6px;border-radius:var(--radius-md,6px);color:var(--text-primary);cursor:pointer;font-size:.75rem;font-size:var(--font-size-xs,.75rem);padding:8px 12px;padding:var(--space-2,8px) var(--space-3,12px);transition:background .2s;white-space:nowrap}.dev-copy-btn:hover{background:#ffffff1f;background:var(--bg-surface-hover,#ffffff1f)}.dev-keys-table-wrap{border:1px solid #ffffff1a;border:1px solid var(--border-color,#ffffff1a);border-radius:8px;border-radius:var(--radius-lg,8px);overflow-x:auto}.dev-keys-table{border-collapse:collapse;font-size:.875rem;font-size:var(--font-size-sm,.875rem);width:100%}.dev-keys-table th{background:#ffffff0a;background:var(--bg-surface,#ffffff0a);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border-color,#ffffff14);color:var(--text-secondary);font-size:.75rem;font-size:var(--font-size-xs,.75rem);font-weight:500;font-weight:var(--font-weight-medium,500);letter-spacing:.05em;text-align:left;text-transform:uppercase}.dev-keys-table td,.dev-keys-table th{padding:12px 16px;padding:var(--space-3,12px) var(--space-4,16px)}.dev-keys-table td{border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-color,#ffffff0d);color:var(--text-primary)}.dev-keys-table tbody tr:last-child td{border-bottom:none}.dev-key-prefix{background:#ffffff0f;background:var(--bg-surface,#ffffff0f);border-radius:4px;border-radius:var(--radius-sm,4px);font-family:JetBrains Mono,Fira Code,monospace;font-size:.8em;padding:2px 6px}.dev-key-label-cell{font-weight:500;font-weight:var(--font-weight-medium,500)}.dev-key-date{color:var(--text-secondary)}.dev-revoke-btn{background:#0000;border:1px solid #ef444466;border-radius:6px;border-radius:var(--radius-md,6px);color:#ef4444;color:var(--color-error,#ef4444);cursor:pointer;font-size:.75rem;font-size:var(--font-size-xs,.75rem);font-weight:500;font-weight:var(--font-weight-medium,500);padding:4px 12px;padding:var(--space-1,4px) var(--space-3,12px);transition:background .2s}.dev-revoke-btn:hover:not(:disabled){background:#ef44441a}.dev-revoke-btn:disabled{cursor:not-allowed;opacity:.5}.dev-usage-grid{display:flex;flex-direction:column;gap:16px;gap:var(--space-4,16px)}.dev-usage-bar-row{display:flex;flex-direction:column;gap:8px;gap:var(--space-2,8px)}.dev-usage-bar-label{align-items:center;color:var(--text-primary);display:flex;font-size:.875rem;font-size:var(--font-size-sm,.875rem);justify-content:space-between}.dev-usage-bar-count{color:var(--text-secondary);font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;font-size:var(--font-size-xs,.75rem)}.dev-usage-bar-track{background:#ffffff0f;background:var(--bg-surface,#ffffff0f);border-radius:999px;height:8px;overflow:hidden}.dev-usage-bar-fill{border-radius:999px;height:100%;min-width:2px;transition:width .5s ease}.dev-usage-plan-badge{background:#ffffff0a;background:var(--bg-surface,#ffffff0a);border-radius:8px;border-radius:var(--radius-lg,8px);display:inline-block;margin-top:8px;margin-top:var(--space-2,8px);padding:8px 16px;padding:var(--space-2,8px) var(--space-4,16px)}.dev-snippet-lang,.dev-usage-plan-badge{color:var(--text-secondary);font-size:.875rem;font-size:var(--font-size-sm,.875rem)}.dev-snippet-lang{font-weight:600;font-weight:var(--font-weight-semibold,600);margin:16px 0 8px;margin:var(--space-4,16px) 0 var(--space-2,8px) 0}.dev-code-block-wrapper{margin:0 0 8px;margin:0 0 var(--space-2,8px) 0;position:relative}.dev-code-block{background:#00000059;border:2px solid #ffffff26;border-radius:8px;border-radius:var(--radius-lg,8px);color:var(--text-primary);font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;font-size:var(--font-size-xs,.75rem);line-height:1.6;margin:0;overflow-x:auto;padding:16px;padding:var(--space-4,16px);padding-right:3.5rem;white-space:pre}.dev-code-copy-btn{align-items:center;background:#ffffff14;border:1px solid #ffffff26;border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;font-size:.75rem;gap:4px;padding:4px 8px;position:absolute;right:8px;top:8px;transition:all .15s}.dev-code-copy-btn:hover{background:#ffffff26;color:var(--text-primary)}.dev-code-copy-btn.copied{border-color:var(--color-success);color:var(--color-success)}@media (max-width:640px){.dev-key-create-row{flex-direction:column}.dev-key-created-value{align-items:stretch;flex-direction:column}}.jd-title-input{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;padding:var(--space-3) var(--space-4);transition:border-color .2s,box-shadow .2s;width:100%}.jd-title-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f9731626;outline:none}.form-hint{color:var(--text-tertiary);font-size:.8rem;font-weight:400;margin-left:.5rem}.jd-source-toggle{border:1px solid var(--border-primary);border-radius:var(--radius-md);display:flex;gap:0;margin-bottom:var(--space-3);overflow:hidden}.jd-source-btn{background:var(--bg-secondary);border:none;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.9rem;padding:var(--space-2) var(--space-3);transition:background .2s,color .2s}.jd-source-btn:first-child{border-right:1px solid var(--border-primary)}.jd-source-btn.active{background:#f9731626;color:var(--color-primary);font-weight:600}.jd-source-btn:hover:not(.active){background:var(--bg-tertiary)}.jd-library-dropdown-wrap{display:flex;flex-direction:column;gap:var(--space-3)}.jd-library-select{-webkit-appearance:none;appearance:none;background:var(--bg-secondary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%239ca3af' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:.95rem;padding:var(--space-3) var(--space-4);padding-right:36px;width:100%}.jd-library-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f9731626;outline:none}.jd-preview-readonly{background:var(--bg-tertiary);cursor:default;opacity:.8}.jd-library-empty,.jd-library-loading{background:var(--bg-secondary);border:1px dashed var(--border-primary);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:.9rem;padding:var(--space-4);text-align:center}.jd-library-section{border-top:1px solid var(--border-primary);margin-top:var(--space-6);padding-top:var(--space-4)}.jd-library-list{display:flex;flex-direction:column;gap:var(--space-2)}.jd-library-item{align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:border-color .2s}.jd-library-item:hover{border-color:var(--color-primary)}.jd-library-item-info{flex:1 1;min-width:0}.jd-library-item-title{color:var(--text-primary);font-size:.95rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jd-library-item-meta{color:var(--text-tertiary);font-size:.8rem;margin-top:2px}.jd-library-item-snippet{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:.85rem;margin-top:4px;overflow:hidden}.jd-library-delete-btn{background:none;border:1px solid #0000;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;font-size:1.1rem;opacity:.5;padding:var(--space-1) var(--space-2);transition:opacity .2s,border-color .2s}.jd-library-delete-btn:hover{border-color:var(--color-error);opacity:1}.jd-library-delete-btn:disabled{cursor:not-allowed;opacity:.3}.library-tab-toggle{background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;display:flex;gap:0;margin-bottom:1.5rem;padding:3px;width:-webkit-fit-content;width:fit-content}.library-tab-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#ffffff80;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 20px;transition:all .2s ease}.library-tab-btn:hover{background:#ffffff0d;color:#fffc}.library-tab-btn.active{background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 2px 8px #f973164d;color:#fff;font-weight:600}.tab-count{background:#ffffff26;border-radius:10px;font-size:.75rem;min-width:18px;padding:1px 7px;text-align:center}.library-tab-btn.active .tab-count{background:#ffffff40}.jd-tab-content{animation:fadeIn .2s ease}.jd-title-editable{align-items:center;cursor:pointer;display:flex;gap:6px}.jd-title-editable:hover{color:#f97316}.jd-edit-icon{font-size:.7rem;opacity:0;transition:opacity .15s ease}.jd-title-editable:hover .jd-edit-icon{opacity:.7}.jd-inline-edit{align-items:center;display:flex;gap:6px}.jd-inline-edit-input{background:#ffffff0f;border:1px solid #f97316;border-radius:6px;color:#fff;flex:1 1;font-size:.9rem;font-weight:600;min-width:200px;outline:none;padding:4px 8px}.jd-inline-edit-input:focus{box-shadow:0 0 0 2px #f9731640}.jd-inline-edit-cancel,.jd-inline-edit-save{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.85rem;height:28px;justify-content:center;transition:all .15s ease;width:28px}.jd-inline-edit-save{background:#22c55e26;color:#22c55e}.jd-inline-edit-save:hover{background:#22c55e4d}.jd-inline-edit-cancel{background:#ef444426;color:#ef4444}.jd-inline-edit-cancel:hover{background:#ef44444d}.btn-icon-danger{color:#fff6}.btn-icon-danger:hover{background:#ef44441a;color:#ef4444}.jd-preview-text{word-wrap:break-word;background:#0003;border-radius:8px;color:#ffffffd9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.9rem;line-height:1.6;margin:0;max-height:70vh;overflow-y:auto;padding:1rem;white-space:pre-wrap}.App{background:var(--bg-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px;text-align:center;transition:background var(--transition-normal)}.App-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);color:var(--text-primary);margin-bottom:24px;padding:24px 20px;transition:all var(--transition-normal)}.header-top{align-items:flex-start;display:flex;gap:20px;justify-content:space-between}.header-content{flex:1 1}.header-theme-toggle{flex-shrink:0}.App-header h1{color:var(--text-primary);font-size:2.2rem;font-weight:700;margin:0 0 8px;text-shadow:0 2px 4px #0003}.App-header p{color:var(--text-secondary);font-size:1.1rem;margin:0 0 16px;opacity:.9}.header-stats{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:12px}.header-stats span{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);color:var(--text-secondary);font-size:.9rem;padding:8px 16px;transition:all var(--transition-fast)}.header-stats span:hover{background:var(--bg-card);border-color:var(--border-hover);transform:translateY(-1px)}.App-main{margin:0 auto;max-width:900px}.upload-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin-bottom:20px;padding:32px;text-align:left;transition:all var(--transition-normal)}.upload-form:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.form-group{margin-bottom:20px}.form-group label{color:var(--text-primary);display:block;font-size:1.1rem;font-weight:600;margin-bottom:8px}.required{color:var(--error-color)}input[type=file],textarea{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:16px;padding:12px 16px;transition:all var(--transition-normal);width:100%}textarea{min-height:120px;resize:vertical}input[type=file]:focus,textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #ffd7001a;outline:none}input.error,textarea.error{border-color:var(--error-color);box-shadow:0 0 0 3px #f443361a}.input-info{align-items:center;display:flex;font-size:.9rem;justify-content:space-between;margin-top:8px}.char-count{color:var(--text-secondary)}.char-count.warning{color:var(--text-warning);font-weight:600}.validation-hint{color:var(--color-primary);font-style:italic}.file-info{margin-top:8px}.file-requirements{color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:.9rem;gap:20px;margin-bottom:15px}.selected-files{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:15px;padding:15px;transition:all var(--transition-normal)}.selected-files h4{color:var(--text-primary);font-size:1rem;margin:0 0 12px}.file-list{display:flex;flex-direction:column;gap:8px}.file-item{align-items:center;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:8px 12px;transition:all var(--transition-fast)}.file-item:hover{background:var(--bg-card);border-color:var(--border-hover)}.file-details{align-items:flex-start;display:flex;flex:1 1;flex-direction:column}.file-name{color:var(--text-primary);font-size:.95rem;font-weight:500}.file-size{color:var(--text-secondary);font-size:.85rem}.file-status{font-size:.85rem;font-weight:500}.status-ok{color:var(--text-success)}.status-error{color:var(--text-danger)}.validation-errors{background:var(--bg-danger-light);border:1px solid var(--border-danger);border-radius:var(--radius-md);margin-bottom:20px;padding:15px}.validation-errors h4{color:var(--text-danger);font-size:1rem;margin:0 0 10px}.validation-errors ul{margin:0;padding-left:20px}.validation-errors li{color:var(--text-danger);margin-bottom:5px}.error-message{background:var(--bg-danger-light);border:1px solid var(--border-danger);border-radius:var(--radius-md);color:var(--text-danger);padding:15px;text-align:center}.warning-message{background:var(--bg-warning-light);border:1px solid var(--border-warning);border-radius:var(--radius-md);color:var(--text-warning);margin-bottom:20px;padding:15px;text-align:center}.loading-container{margin:20px 0;padding:30px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--color-primary);height:40px;margin:0 auto 15px;width:40px}.loading-text{color:var(--color-primary);font-size:1.1rem;font-weight:500;margin-bottom:15px}.progress-bar{background:var(--bg-surface);border-radius:var(--radius-sm);height:8px;margin-top:10px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);height:100%;transition:width .3s ease}.form-actions{display:flex;gap:15px;justify-content:center;margin-top:30px}.clear-button,.submit-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;min-width:160px;padding:15px 30px;transition:all .3s ease}.submit-button{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);box-shadow:0 4px 15px #667eea66}.submit-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea99}.submit-button:disabled{box-shadow:0 4px 15px #667eea33;opacity:.6}.clear-button{background:var(--bg-surface);border:2px solid var(--border-color);color:var(--text-secondary)}.clear-button:hover{background:var(--bg-card);border-color:var(--border-hover)}.results{margin-top:40px}.results-header{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-bottom:25px;padding:30px;text-align:center}.results-header h2{color:var(--text-primary);font-size:2rem;font-weight:700;margin:0 0 20px}.results-metadata{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;margin-bottom:20px}.stat{align-items:center;background:var(--bg-card);border-radius:var(--radius-lg);display:flex;flex-direction:column;min-width:120px;padding:15px}.stat-label{font-size:.9rem;margin-bottom:5px}.stat-value{color:var(--color-primary);font-size:1.3rem}.processing-info{color:var(--text-secondary);display:flex;font-size:.9rem;gap:20px;justify-content:center}.request-id{background:var(--bg-surface);border-radius:var(--radius-sm);font-family:monospace;padding:2px 6px}.failed-files{background:var(--bg-danger-light);border:1px solid var(--border-danger);border-radius:var(--radius-lg);margin-bottom:25px;padding:20px}.failed-files h3{color:#c53030;margin:0 0 15px}.failed-list{display:flex;flex-direction:column;gap:10px}.failed-item{align-items:center;background:#fff;border:1px solid #fed7d7;border-radius:8px;display:flex;justify-content:space-between;padding:10px}.failed-filename{color:#333;font-weight:500}.failed-error{color:#c53030;flex:1 1;font-size:.9rem;text-align:center}.failed-size{color:#666;font-size:.8rem}.rankings{display:flex;flex-direction:column;gap:20px}.ranking-card{border:1px solid #e2e8f0;border-radius:15px;box-shadow:0 8px 25px #0000001a;transition:all .3s ease}.ranking-card:hover{box-shadow:0 15px 35px #00000026;transform:translateY(-5px)}.rank-1{border-left:5px solid gold;box-shadow:0 8px 25px #ffd7004d}.rank-2{border-left:5px solid silver}.rank-3{border-left:5px solid #cd7f32}.ranking-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.rank-badge{gap:8px}.rank-badge,.rank-number{align-items:center;display:flex}.rank-number{background:#667eea;border-radius:50%;color:#fff;font-size:1.1rem;font-weight:700;height:35px;justify-content:center;width:35px}.crown{animation:bounce 2s infinite;font-size:1.5rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.ranking-title{flex:1 1;margin-left:20px;text-align:left}.ranking-title h3{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 5px}.score{border-radius:25px;box-shadow:0 4px 10px #667eea4d;font-size:1.1rem;font-weight:700;padding:8px 20px}.ranking-content{padding:30px}.ranking-content h4{align-items:center;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0 0 15px}.ranking-content ul{margin:0 0 25px}.ranking-content li{color:#555;line-height:1.5;margin-bottom:8px}.strengths ul{background:linear-gradient(135deg,#f0fff4,#e6fffa);border-left:4px solid #48bb78;box-shadow:0 2px 10px #48bb781a}.improvements ul,.strengths ul{border-radius:10px;padding:20px}.improvements ul{background:linear-gradient(135deg,#fffaf0,#fef5e7);border-left:4px solid #ed8936;box-shadow:0 2px 10px #ed89361a}.explanation{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:4px solid #667eea;border-radius:10px;box-shadow:0 2px 10px #667eea1a;padding:20px}.explanation p{color:#555;line-height:1.7}.summary{border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-top:30px;padding:30px}.summary h3{align-items:center;display:flex;font-size:1.5rem;font-weight:700;gap:10px;margin:0 0 20px}.summary-content p{color:#555;font-size:1.05rem;line-height:1.7;margin:0}.App-footer{background:#2d3748;border-radius:15px;color:#fff;margin-top:60px;padding:30px 20px;text-align:center}.footer-links{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;margin-top:15px}.footer-links span{font-size:.9rem;opacity:.8}@media (max-width:768px){.App{padding:10px}.App-header{padding:30px 15px}.header-top{align-items:center;flex-direction:column;gap:15px}.header-theme-toggle{align-self:flex-end}.App-header h1{font-size:2.2rem}.header-stats{flex-direction:column;gap:15px}.upload-form{padding:25px}.file-requirements{flex-direction:column;gap:10px}.file-item{align-items:flex-start;flex-direction:column;gap:8px}.fab{bottom:20px;height:56px;right:20px;width:56px}.results-metadata{flex-direction:column;gap:15px}.processing-info{flex-direction:column;gap:10px}.failed-item{align-items:flex-start;flex-direction:column;gap:8px}.ranking-header{flex-direction:column;gap:15px;text-align:center}.ranking-title{margin-left:0;text-align:center}.ranking-content{padding:20px}.form-actions{flex-direction:column}.clear-button,.submit-button{width:100%}}@media (max-width:480px){.App-header h1{font-size:1.8rem}.upload-form{padding:20px}.stat{min-width:100px;padding:12px}.ranking-content{padding:15px}}.required{color:#e53e3e}.form-group textarea{border:2px solid #e2e8f0;border-radius:6px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;transition:border-color .2s;width:100%}.form-group textarea:focus{border-color:#667eea;outline:none}.form-group input[type=file]{background-color:#f8f9fa;border:2px dashed #e2e8f0;border-radius:6px;cursor:pointer;padding:10px;transition:border-color .2s;width:100%}.form-group input[type=file]:hover{border-color:#667eea}.file-info{color:#666;display:block;font-size:12px;margin-top:5px}.selected-files{background-color:#f0f4f8;border-radius:6px;margin-top:10px;padding:10px}.selected-files p{color:#333;font-weight:600;margin:0 0 5px}.selected-files ul{margin:0;padding-left:20px}.selected-files li{color:#666;font-size:14px}.error-message{background-color:#fed7d7;border:1px solid #feb2b2;border-radius:6px;color:#c53030;margin-bottom:20px;padding:12px}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 30px;transition:transform .2s;width:100%}.submit-button:hover:not(:disabled){transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.results{text-align:left}.results h2{color:#333;margin-bottom:25px;text-align:center}.rankings{margin-bottom:30px}.ranking-card{background:#fff;border-left:5px solid #e2e8f0;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin-bottom:20px;overflow:hidden;transition:transform .2s}.ranking-card:hover{transform:translateY(-2px)}.rank-1{border-left-color:#48bb78}.rank-2{border-left-color:#ed8936}.rank-3{border-left-color:#ed64a6}.ranking-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.ranking-header h3{color:#333;font-size:1.1rem;margin:0}.score{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:14px;font-weight:600;padding:8px 16px}.ranking-content{padding:20px}.ranking-content h4{color:#333;font-size:1rem;margin:0 0 10px}.ranking-content ul{margin:0 0 20px;padding-left:20px}.ranking-content li{color:#666;margin-bottom:5px}.strengths ul{background-color:#f0fff4;border-left:3px solid #48bb78}.improvements ul,.strengths ul{border-radius:6px;padding:10px 20px}.improvements ul{background-color:#fffaf0;border-left:3px solid #ed8936}.explanation{background-color:#f7fafc;border-left:3px solid #667eea;border-radius:6px;padding:15px}.explanation p{color:#666;line-height:1.6;margin:0}.summary{background:#fff;border-left:5px solid #667eea;border-radius:10px;box-shadow:0 4px 6px #0000001a;padding:25px}.summary h3{color:#333;margin:0 0 15px}.summary p{color:#666;line-height:1.6;margin:0}@media (max-width:768px){.App{padding:10px}.App-header{padding:30px 15px}.App-header h1{font-size:2rem}.upload-form{padding:20px}.ranking-header{flex-direction:column;gap:10px;text-align:center}.ranking-content{padding:15px}}:root{--bg-primary:linear-gradient(135deg,#0b1628,#0f1d32);--bg-secondary:#0f1d32f2;--bg-surface:#152542cc;--bg-card:#0b162899;--bg-glass:#ffffff0d;--bg-overlay:#0000004d;--text-primary:#f8fafc;--text-secondary:#e2e8f0;--text-muted:#94a3b8;--text-accent:#cbd5e1;--color-primary:#fb923c;--color-primary-hover:#f97316;--color-primary-alpha:#fb923c33;--color-secondary:#152542;--color-secondary-hover:#1b2e52;--color-success:#10b981;--color-success-hover:#059669;--color-warning:#f59e0b;--color-warning-hover:#d97706;--color-error:#ef4444;--color-error-hover:#dc2626;--color-info:#3b82f6;--accent-color:#fb923c;--accent-hover:#f97316;--accent-primary:#fb923c;--border-color:#ffffff1a;--border-hover:#ffffff26;--border-focus:var(--color-primary);--shadow-xs:0 1px 2px 0 #0000004d;--shadow-sm:0 1px 3px 0 #0006,0 1px 2px 0 #0003;--shadow-md:0 4px 6px -1px #0006,0 2px 4px -1px #0003;--shadow-lg:0 10px 15px -3px #0006,0 4px 6px -2px #0003;--shadow-xl:0 20px 25px -5px #0006,0 10px 10px -5px #0003;--shadow-glow:0 0 20px #fb923c66;--transition-fast:0.15s cubic-bezier(0.4,0,0.2,1);--transition-normal:0.3s cubic-bezier(0.4,0,0.2,1);--transition-slow:0.5s cubic-bezier(0.4,0,0.2,1);--radius-xs:2px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.625;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem}body{color:#f8fafc;color:var(--text-primary);transition:background .3s cubic-bezier(.4,0,.2,1),color .3s cubic-bezier(.4,0,.2,1);transition:background var(--transition-normal),color var(--transition-normal)}.app-container,body{background:linear-gradient(135deg,#0b1628,#0f1d32);background:var(--bg-primary)}.app-container{min-height:100vh;transition:background .3s cubic-bezier(.4,0,.2,1);transition:background var(--transition-normal)}.glass-effect{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#152542cc;background:var(--bg-surface);border:1px solid #ffffff1a;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.glass-effect:hover{background:#0b162899;background:var(--bg-card);border-color:#ffffff26;border-color:var(--border-hover);box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0003;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-primary{background:#fb923c;background:var(--accent-color);border:none;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 3px 0 #0006,0 1px 2px 0 #0003;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.btn-primary:hover{background:#f97316;background:var(--accent-hover);box-shadow:0 4px 6px -1px #0006,0 2px 4px -1px #0003;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:#152542cc;background:var(--bg-surface);border:1px solid #ffffff1a;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#f8fafc;color:var(--text-primary);cursor:pointer;font-weight:500;padding:12px 24px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.btn-secondary:hover{background:#0b162899;background:var(--bg-card);border-color:#ffffff26;border-color:var(--border-hover)}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#152542cc;background:var(--bg-surface);border:1px solid #ffffff1a;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:16px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.card:hover{border-color:#ffffff26;border-color:var(--border-hover);transform:translateY(-2px)}.card:hover,.fab{box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0003;box-shadow:var(--shadow-lg)}.fab{align-items:center;background:#fb923c;background:var(--accent-color);border:none;border-radius:50%;bottom:24px;cursor:pointer;display:flex;height:64px;justify-content:center;position:fixed;right:24px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:64px;z-index:1000}.fab:hover{background:#f97316;background:var(--accent-hover);box-shadow:0 12px 20px #0003;transform:scale(1.1)}.fab:active{transform:scale(.95)}.theme-toggle{align-items:center;background:#152542cc;background:var(--bg-surface);border:1px solid #ffffff1a;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;display:flex;height:48px;justify-content:center;padding:8px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:48px}.theme-toggle:hover{background:#0b162899;background:var(--bg-card);border-color:#ffffff26;border-color:var(--border-hover);transform:scale(1.05)}@media (max-width:768px){.fab{bottom:16px;height:56px;right:16px;width:56px}.card{margin-bottom:12px;padding:16px}.theme-toggle{height:44px;width:44px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.animate-fade-in{animation:fadeIn ease-out .3s cubic-bezier(.4,0,.2,1);animation:fadeIn var(--transition-normal) ease-out}.animate-slide-in{animation:slideIn ease-out .3s cubic-bezier(.4,0,.2,1);animation:slideIn var(--transition-normal) ease-out}.btn-primary:focus,.btn-secondary:focus,.fab:focus,.theme-toggle:focus{outline:2px solid #fb923c;outline:2px solid var(--accent-color);outline-offset:2px}@media (prefers-contrast:high){:root{--border-color:#ffffff80;--text-secondary:#ffffffe6}[data-theme=dark]{--border-color:#ffffff4d;--text-secondary:#e0e0e0e6}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.dashboard{background:var(--bg-primary);margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px);padding:var(--space-8) var(--space-6) var(--space-6);position:relative}.dashboard:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='20' height='20' patternUnits='userSpaceOnUse'%3E%3Cpath d='M20 0H0v20' fill='none' stroke='rgba(255,255,255,0.02)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:-1}.dashboard-header{margin-bottom:var(--space-6);text-align:center}.dashboard-title{align-items:center;display:flex;gap:var(--space-4);justify-content:center;margin-bottom:var(--space-2)}.dashboard-icon{color:var(--color-primary);filter:drop-shadow(0 4px 8px var(--color-primary-alpha));font-size:3rem}.dashboard-title h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);letter-spacing:-.025em;margin:0}.match-score-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);margin-bottom:var(--space-6);overflow:hidden;padding:var(--space-6);position:relative}.match-score-card:before{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary),var(--color-success));border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.match-score-card .card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.card-icon{color:var(--color-warning);filter:drop-shadow(0 2px 4px rgba(245,158,11,.3));font-size:2rem}.match-score-card h2{color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0}.card-description{color:var(--text-secondary);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin-bottom:var(--space-6)}.chart-container{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);margin-top:var(--space-4);padding:var(--space-6)}.dashboard.loading{align-items:center;display:flex;justify-content:center;min-height:200px}.loading-spinner{text-align:center}.spinner{animation:spin 1s linear infinite;border-left:4px solid var(--border-color);border:4px solid var(--border-color);border-left-color:var(--accent-color);border-radius:50%;height:40px;margin:0 auto 16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-spinner p{color:var(--text-secondary);font-size:1.1rem}.dashboard.empty{align-items:center;display:flex;justify-content:center;min-height:200px}.empty-state{color:var(--text-secondary);text-align:center}.empty-icon{font-size:4rem;margin-bottom:16px}.empty-state h2{color:var(--text-primary);margin-bottom:8px}.dashboard-header{margin-bottom:32px}.dashboard-header h2{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:20px}.stats-overview{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}.stat-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,var(--bg-surface) 0,#fb923c0d 100%);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 2px 4px #0000000d;padding:1.25rem;text-align:center;transition:all var(--transition-normal)}.stat-card:hover{border-color:var(--accent-color);box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.stat-value{color:var(--accent-color);display:block;font-size:2.25rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:var(--text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.results-section{margin-top:var(--space-6)}.results-section h3{color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-6);text-align:center}.results-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:var(--space-4)}.result-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;padding:var(--space-6);position:relative;transition:all var(--transition-fast)}.result-card:before{background:linear-gradient(135deg,var(--color-primary-alpha),#0000);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-fast)}.result-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-xl);transform:translateY(-6px)}.result-card:hover:before{opacity:1}.card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.card-header h3{color:var(--text-primary);flex:1 1;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0;text-align:left;word-break:break-word}.score-badge{align-items:center;display:flex;flex-direction:column;gap:var(--space-1)}.score-badge .rank{background:var(--bg-surface)}.score-badge .score{background:linear-gradient(135deg,#f97316,#ea580c);border-radius:9999px;box-shadow:0 6px 18px #f9731640,inset 0 -2px 6px #00000014;color:#fff;display:inline-block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);min-width:64px;padding:8px 18px;text-align:center}.score-badge .rank{background:#0000000f;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-2)}.improvements-section h4,.strengths-section h4{color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:8px}.improvements-section ul,.strengths-section ul{list-style:none;margin:0;padding:0}.improvements-section li,.strengths-section li{color:var(--text-secondary);font-size:.85rem;margin-bottom:4px;padding-left:12px;position:relative}.strengths-section li:before{color:var(--success-color);content:"✓";left:0;position:absolute}.improvements-section li:before{color:var(--warning-color);content:"→";left:0;position:absolute}.card-footer{display:flex;gap:12px;justify-content:flex-end}.card-footer .btn-primary,.card-footer .btn-secondary{font-size:.85rem;padding:8px 16px}.chart-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);height:400px;margin:24px 0;padding:24px}@media (max-width:768px){.dashboard{padding:16px}.dashboard-header h2{font-size:1.5rem}.results-grid,.stats-overview{gap:16px;grid-template-columns:1fr}.result-card{padding:20px}.card-header{align-items:flex-start;flex-direction:column;gap:12px}.score-badge{align-self:flex-end}.card-footer{justify-content:stretch}.card-footer .btn-primary,.card-footer .btn-secondary{flex:1 1}.chart-container{height:300px;padding:16px}}@media (max-width:480px){.dashboard{padding:12px}.card-footer{flex-direction:column;gap:8px}.stat-value{font-size:2rem}.chart-container{height:250px;padding:12px}}.cost-info-section{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 4px 6px #0000000d;margin-top:1.5rem;padding:1.5rem}.cost-info-section h3{align-items:center;color:var(--text-primary);display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.cost-details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:1rem}.cost-detail-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem}.cost-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem}.cost-icon{font-size:1.25rem}.cost-header h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.cost-stats{display:flex;flex-direction:column;gap:.5rem}.cost-stat{align-items:center;display:flex;justify-content:space-between;padding:.25rem 0}.cost-stat.total-cost{border-top:1px solid var(--border-color);font-weight:600;margin-top:.25rem;padding-top:.5rem}.cost-label{color:var(--text-secondary);font-size:.875rem}.cost-value{color:var(--text-primary);font-family:Courier New,monospace;font-weight:500}.cost-stat.total-cost .cost-value{color:var(--accent-color);font-size:1rem;font-weight:600}.cost-note{background:var(--bg-accent);border:1px solid var(--border-accent);border-radius:var(--radius-sm);margin-top:1rem;padding:.75rem}.cost-note p{color:var(--text-secondary);font-size:.875rem;margin:0}.cost-card{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.cost-card .stat-label,.cost-card .stat-value{color:#fff}@media (max-width:768px){.cost-details-grid{grid-template-columns:1fr}.cost-stat{align-items:flex-start;flex-direction:column;gap:.25rem}}
/*# sourceMappingURL=main.fa490e6c.css.map*/