@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.project-card{background:var(--card-bg, #ffffff);border:1px solid var(--border-default, #e0e0e0);border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-500, #007bff)}.project-card:focus{outline:2px solid var(--color-primary-500, #007bff);outline-offset:2px}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.project-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary, #212529);flex:1}.project-status{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;white-space:nowrap}.project-status.active{background:var(--success-bg, #d4edda);color:var(--success-text, #155724)}.project-status.pendingdeletion{background:var(--warning-bg, #fff3cd);color:var(--warning-text, #856404)}.project-description{margin-bottom:1rem;color:var(--text-secondary, #6c757d);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.project-badges{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem}.project-badge{font-size:.75rem;border-radius:999px;padding:.2rem .5rem;border:1px solid transparent}.project-badge.repo-connected{background:var(--info-bg, #e7f1ff);color:var(--info-text, #0f4fa8)}.project-badge.missing-files{background:var(--warning-bg, #fff4e6);color:var(--warning-text, #7c4800)}.project-badge.archived{background:var(--surface-secondary, #f3f3f3);color:var(--text-secondary, #555)}.project-meta{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--text-muted, #868e96);padding-top:.75rem;border-top:1px solid var(--border-default, #e0e0e0)}.project-files,.project-date{display:flex;align-items:center;gap:.25rem}.project-last-activity{margin-top:.5rem;font-size:.8rem;color:var(--text-secondary, #6c757d)}.project-list-container{width:100%}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.project-list-loading,.project-list-error,.project-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.project-list-error{color:var(--color-error, #dc3545)}.error-message{color:var(--text-secondary, #6c757d);font-size:.875rem;margin-top:.5rem}.retry-btn{margin-top:1rem;padding:.5rem 1rem;background:var(--color-primary-500, #007bff);color:var(--text-on-primary, white);border:none;border-radius:4px;cursor:pointer}.retry-btn:hover{opacity:.9}.project-list-empty{padding:6rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.project-list-empty h3{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary, #212529)}.project-list-empty p{margin:0;color:var(--text-secondary, #6c757d)}.project-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem}.pagination-btn{padding:.5rem 1rem;background:var(--color-primary-500, #007bff);color:var(--text-on-primary, white);border:none;border-radius:4px;cursor:pointer;transition:opacity .2s ease}.pagination-btn:hover:not(:disabled){opacity:.9}.pagination-btn:disabled{background:var(--border-default, #e0e0e0);color:var(--text-muted, #868e96);cursor:not-allowed}.pagination-info{color:var(--text-secondary, #6c757d);font-size:.875rem}@media(max-width:768px){.project-grid{grid-template-columns:1fr}}.project-form{background:var(--card-bg, #ffffff);border:1px solid var(--border-default, #e0e0e0);border-radius:8px;overflow:hidden;max-width:600px;width:100%}.form-header{padding:1.5rem;border-bottom:1px solid var(--border-default, #e0e0e0)}.form-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #212529)}.form-body{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary, #212529)}.form-group .required{color:var(--color-error, #dc3545)}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-default, #e0e0e0);border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary-500, #007bff);box-shadow:0 0 0 3px color-mix(in oklab,var(--color-primary-500, #007bff) 20%,transparent)}.form-group input:disabled,.form-group textarea:disabled{background:var(--disabled-bg, #f8f9fa);cursor:not-allowed}.form-group textarea{resize:vertical;min-height:100px}.form-error{padding:.75rem;background:var(--danger-bg, #f8d7da);color:var(--danger-text, #721c24);border:1px solid var(--danger-border, #f5c6cb);border-radius:4px;font-size:.875rem;margin-top:1rem}.form-footer{padding:1.5rem;border-top:1px solid var(--border-default, #e0e0e0);display:flex;justify-content:flex-end;gap:.75rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary-500, #007bff);color:var(--text-on-primary, white)}.btn-primary:hover:not(:disabled){background:var(--primary-hover, #0056b3)}.btn-secondary{background:var(--secondary-bg, #f8f9fa);color:var(--text-primary, #212529);border:1px solid var(--border-default, #e0e0e0)}.btn-secondary:hover:not(:disabled){background:var(--secondary-hover, #e2e6ea)}@media(max-width:768px){.form-footer{flex-direction:column}.btn{width:100%}}.project-details{max-width:1200px;margin:0 auto;padding:2rem}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-default, #e0e0e0)}.project-header-content{flex:1}.back-btn{background:none;border:none;color:var(--color-primary-500, #007bff);cursor:pointer;font-size:1rem;padding:.5rem 0;margin-bottom:1rem}.back-btn:hover{text-decoration:underline}.project-header h1{margin:0 0 .5rem;font-size:2rem;color:var(--text-primary, #212529)}.project-description-section,.project-files-section,.project-repository-section{margin-bottom:2rem;padding:1.5rem;background:var(--card-bg, #ffffff);border:1px solid var(--border-default, #e0e0e0);border-radius:8px}.project-description-section h2,.project-files-section h2,.project-repository-section h2{margin:0 0 1rem;font-size:1.25rem;color:var(--text-primary, #212529)}.project-description-section p{margin:0;color:var(--text-secondary, #6c757d);line-height:1.6}.files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.upload-btn{cursor:pointer}.files-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #6c757d)}.files-list{display:flex;flex-direction:column;gap:.75rem}.file-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-light, #f8f9fa);border:1px solid var(--border-default, #e0e0e0);border-radius:6px;transition:background .2s ease}.file-item:hover{background:var(--bg-hover, #e9ecef)}.file-info{display:flex;align-items:center;gap:1rem;flex:1}.file-icon{font-size:1.5rem}.file-details{flex:1}.file-name{font-weight:500;color:var(--text-primary, #212529);margin-bottom:.25rem}.file-meta{font-size:.875rem;color:var(--text-muted, #868e96)}.file-delete-btn{background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.5rem;opacity:.6;transition:opacity .2s ease}.file-delete-btn:hover:not(:disabled){opacity:1}.file-delete-btn:disabled{cursor:not-allowed;opacity:.3}.btn-danger{background:var(--color-error, #dc3545);color:var(--text-on-primary, white)}.btn-danger:hover:not(:disabled){background:var(--danger-hover, #c82333)}.modal-overlay{position:fixed;inset:0;background:var(--backdrop-overlay, rgba(0, 0, 0, .5));display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--card-bg, #ffffff);border-radius:8px;padding:2rem;max-width:500px;width:90%}.modal-content h3{margin:0 0 1rem;color:var(--text-primary, #212529)}.modal-content p{margin:0 0 1.5rem;color:var(--text-secondary, #6c757d)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.project-details-loading,.project-details-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-default, #e0e0e0);border-top-color:var(--color-primary-500, #007bff);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@media(max-width:768px){.project-header{flex-direction:column;gap:1rem}.project-actions,.project-actions .btn{width:100%}.files-header{flex-direction:column;align-items:flex-start;gap:1rem}.upload-btn{width:100%}}.repository-connected{display:flex;justify-content:space-between;align-items:center;gap:1rem}.repository-info{display:flex;align-items:center;gap:.5rem}.repo-icon{font-size:1.25rem}.repo-link{color:var(--color-primary-500, #007bff);text-decoration:none;font-weight:500}.repo-link:hover{text-decoration:underline}.repository-not-connected{color:var(--text-secondary, #6c757d)}.repository-picker{display:flex;flex-direction:column;gap:.75rem}.repository-select-group{display:flex;gap:.5rem;align-items:center}.repository-select{flex:1;padding:.55rem .7rem;border:1px solid var(--border-default, #e0e0e0);border-radius:6px;background:var(--card-bg, #ffffff);color:var(--text-primary, #212529);font-size:.9rem}.onboarding-page{max-width:900px;margin:0 auto;display:grid;gap:var(--space-6)}.onboarding-header{display:grid;gap:var(--space-3)}.onboarding-progress{display:inline-flex;width:fit-content;background:var(--surface-elevated);border:1px solid var(--border-default);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-weight:600}.onboarding-step-list{list-style:none;display:grid;gap:var(--space-4)}.onboarding-step{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);background:var(--surface-secondary)}.onboarding-step.active{border-color:var(--color-primary-500)}.onboarding-step.completed{opacity:.8}.onboarding-step-title-row{display:flex;align-items:center;gap:var(--space-3)}.onboarding-step-number{width:28px;height:28px;border-radius:999px;background:var(--surface-elevated);display:inline-flex;align-items:center;justify-content:center;font-weight:700}.onboarding-step-check{margin-left:auto;color:var(--color-success);font-weight:600}.onboarding-step-content{margin-top:var(--space-4)}.onboarding-inline-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:center}.onboarding-complete{border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);background:var(--surface-elevated);display:grid;gap:var(--space-3)}.projects-page{max-width:1400px;margin:0 auto;padding:2rem}.projects-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-default, #e0e0e0)}.projects-header-content h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700;color:var(--text-primary, #212529)}.projects-subtitle{margin:0;font-size:1.125rem;color:var(--text-secondary, #6c757d)}.create-btn{white-space:nowrap}.create-form-container{margin-bottom:2rem;display:flex;justify-content:center}.projects-content{width:100%}.projects-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:1rem}.kpi-item{border:1px solid var(--border-default, #e0e0e0);border-radius:8px;padding:.75rem;background:var(--card-bg, #fff)}.kpi-label{display:block;color:var(--text-secondary, #6c757d);font-size:.875rem}.projects-controls,.projects-saved-views,.projects-filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.75rem}.projects-search,.projects-sort{border:1px solid var(--border-default, #e0e0e0);border-radius:6px;padding:.5rem .75rem;min-height:36px}.projects-search{min-width:260px}.projects-saved-views button,.projects-filters button{border:1px solid var(--border-default, #e0e0e0);background:var(--surface-elevated, #fff);color:var(--text-primary, #212529);border-radius:999px;padding:.25rem .75rem;cursor:pointer}.projects-saved-views button:hover,.projects-filters button:hover{background:var(--surface-hover, #f1f3f5);border-color:var(--border-strong, #adb5bd)}.projects-saved-views button.active,.projects-filters button.active{background:var(--color-primary-500, #007bff);color:var(--text-on-primary, white);border-color:var(--color-primary-500, #007bff)}.filter-count{color:var(--text-secondary, #6c757d);font-size:.875rem}@media(max-width:768px){.projects-page{padding:1rem}.projects-header{flex-direction:column;gap:1rem}.projects-header-content h1{font-size:2rem}.create-btn{width:100%}.projects-search{min-width:100%}}.settings-page{max-width:1200px;margin:0 auto;padding:2rem;display:grid;gap:1.5rem}.settings-header h1{font-size:2rem;margin-bottom:.25rem}.settings-header p{color:var(--text-secondary)}.settings-section{border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--surface-elevated);padding:1rem}.settings-section h2{font-size:1.25rem;margin-bottom:.75rem}.settings-section-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem}.settings-state{color:var(--text-secondary)}.settings-state.error{color:var(--color-error)}.settings-list{display:grid;gap:.75rem}.settings-item{display:flex;justify-content:space-between;gap:1rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.75rem}.settings-item h3{margin-bottom:.25rem}.settings-item p{margin-bottom:.25rem;color:var(--text-secondary)}.settings-item-actions{display:flex;gap:.5rem;align-items:flex-start}.discover-results{margin-bottom:.75rem}.discover-results p{margin-bottom:.5rem;color:var(--text-secondary)}.discover-chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{font-size:.8rem;padding:.35rem .6rem}.settings-form{display:grid;gap:.75rem}.settings-form label{display:grid;gap:.4rem;font-weight:500}.settings-form input,.settings-form textarea{width:100%;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--surface-primary);color:var(--text-primary);padding:.55rem .7rem}.checkbox-row{display:flex!important;align-items:center;gap:.5rem;font-weight:500}.checkbox-row input{width:auto}.form-actions{display:flex;gap:.75rem}@media(max-width:768px){.settings-page{padding:1rem}.settings-section-header,.settings-item,.form-actions{flex-direction:column;align-items:stretch}}.github-connection-status{display:grid;gap:.5rem}.connection-info{display:flex;align-items:center;gap:1rem}.status-badge{font-weight:600;font-size:.9rem}.status-badge.connected{color:var(--color-success, #22c55e)}.status-badge.disconnected{color:var(--text-secondary)}.connection-help{color:var(--text-secondary);font-size:.85rem}.settings-state.success{color:var(--color-success, #22c55e)}.status-pill{border-radius:999px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.status-pill.ready{background:color-mix(in oklab,var(--color-success, #22c55e) 20%,transparent);color:var(--color-success, #22c55e)}.status-pill.not-ready{background:color-mix(in oklab,var(--color-error, #ef4444) 20%,transparent);color:var(--color-error, #ef4444)}.readiness-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem}.readiness-card{border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.75rem;margin-bottom:.75rem}.readiness-card h3{margin-bottom:.5rem}.readiness-metrics,.readiness-checklist,.readiness-issues{display:grid;gap:.45rem;margin:0;padding-left:1rem}.readiness-checklist li,.readiness-issues li{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.5rem;list-style:none}.readiness-checklist li{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.readiness-checklist li.complete{background:color-mix(in oklab,var(--color-success, #22c55e) 10%,transparent)}.readiness-checklist li.incomplete{background:color-mix(in oklab,var(--color-warning, #f59e0b) 10%,transparent)}.checklist-details{color:var(--text-secondary);margin-top:.2rem}.issue-severity{text-transform:uppercase;font-size:.75rem;font-weight:700}.issue-severity.blocking{color:var(--color-error, #ef4444)}.issue-severity.non-blocking{color:var(--color-warning, #f59e0b)}.ai-provider-active{border-color:var(--color-success, #22c55e);background:color-mix(in oklab,var(--color-success, #22c55e) 6%,transparent)}.chat-page{display:grid;grid-template-columns:280px 1fr;gap:var(--space-4);min-height:calc(100vh - 10rem)}.chat-sidebar-panel,.chat-main-panel{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.chat-sidebar-panel{padding:var(--space-4)}.chat-session-list{list-style:none;margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.chat-session-item{width:100%;text-align:left;background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer;color:var(--text-primary);transition:background var(--transition-fast),border-color var(--transition-fast)}.chat-session-item:hover{background:var(--surface-hover);border-color:var(--border-default)}.chat-session-item.active{border-color:color-mix(in srgb,var(--color-primary-500) 45%,var(--border-default));background:color-mix(in srgb,var(--color-primary-500) 16%,var(--surface-primary))}.chat-session-title,.chat-session-meta{display:block}.chat-session-title{color:var(--text-primary)}.chat-session-meta{font-size:var(--font-size-sm);color:var(--text-secondary)}.chat-main-panel{display:grid;grid-template-rows:auto 1fr auto;min-height:38rem}.chat-session-header{padding:var(--space-4);border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.chat-session-header-main{min-width:0}.chat-session-header p{color:var(--text-secondary);margin-top:var(--space-1)}.chat-connection-status{display:inline-flex;align-items:center;gap:var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-1) var(--space-2);font-size:var(--font-size-sm)}.chat-connection-status-reconnecting,.chat-connection-status-reconnected{border-color:color-mix(in srgb,var(--color-warning) 30%,transparent);background:color-mix(in srgb,var(--color-warning) 10%,var(--surface-primary))}.chat-connection-status-closed,.chat-connection-status-error{border-color:color-mix(in srgb,var(--color-error) 40%,transparent);background:color-mix(in srgb,var(--color-error) 10%,var(--surface-primary))}.chat-message-list{padding:var(--space-4);overflow:auto;display:flex;flex-direction:column;gap:var(--space-3)}.chat-message{padding:var(--space-3);border-radius:var(--radius-md);background:var(--surface-primary);border:1px solid var(--border-subtle)}.chat-message-user{border-left:3px solid var(--color-primary-500)}.chat-message-assistant{border-left:3px solid var(--color-accent-500)}.chat-composer{padding:var(--space-4);border-top:1px solid var(--border-subtle);display:grid;gap:var(--space-3)}.chat-composer-controls{display:flex;gap:var(--space-3)}.chat-composer-status{margin:0;padding:var(--space-2) var(--space-3);border:1px solid color-mix(in srgb,var(--color-primary-500) 20%,transparent);background:color-mix(in srgb,var(--color-primary-500) 10%,var(--surface-primary));color:var(--text-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.chat-composer textarea{flex:1;resize:vertical;min-height:4rem;border-radius:var(--radius-md);border:1px solid var(--border-default);padding:var(--space-3);font:inherit;background:var(--surface-primary);color:var(--text-primary)}.chat-state{display:grid;gap:var(--space-2);place-items:center;min-height:24rem}.chat-empty-form{width:min(30rem,100%);display:grid;gap:var(--space-2);margin:var(--space-2) 0}.chat-empty-form label{font-size:var(--font-size-sm);color:var(--text-secondary)}.chat-empty-form input,.chat-empty-form select{width:100%;border-radius:var(--radius-md);border:1px solid var(--border-default);padding:var(--space-2) var(--space-3);font:inherit;background:var(--surface-primary);color:var(--text-primary)}.chat-empty-hint{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary)}.chat-state-error{color:var(--color-error)}@media(max-width:960px){.chat-page{grid-template-columns:1fr}.chat-composer-controls{flex-direction:column}.chat-session-header{flex-direction:column;align-items:stretch}.chat-connection-status{justify-content:space-between}}#root{min-height:100vh}.content>*{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gradient-border{position:relative;background:var(--surface-elevated);border-radius:var(--radius-xl)}.gradient-border:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,var(--color-primary-400),var(--color-accent-400));-webkit-mask:linear-gradient(var(--mask-solid, #fff) 0 0) content-box,linear-gradient(var(--mask-solid, #fff) 0 0);mask:linear-gradient(var(--mask-solid, #fff) 0 0) content-box,linear-gradient(var(--mask-solid, #fff) 0 0);-webkit-mask-composite:xor;mask-composite:exclude}:root{color-scheme:light;--color-primary-50: hsl(220, 100%, 97%);--color-primary-100: hsl(220, 100%, 94%);--color-primary-200: hsl(220, 100%, 87%);--color-primary-300: hsl(220, 100%, 75%);--color-primary-400: hsl(220, 100%, 62%);--color-primary-500: hsl(220, 100%, 50%);--color-primary-600: hsl(220, 100%, 44%);--color-primary-700: hsl(220, 100%, 37%);--color-primary-800: hsl(220, 100%, 30%);--color-primary-900: hsl(220, 100%, 22%);--color-accent-50: hsl(280, 100%, 97%);--color-accent-100: hsl(280, 100%, 94%);--color-accent-200: hsl(280, 100%, 87%);--color-accent-300: hsl(280, 100%, 75%);--color-accent-400: hsl(280, 90%, 65%);--color-accent-500: hsl(280, 85%, 55%);--color-accent-600: hsl(280, 80%, 48%);--color-success: hsl(145, 65%, 42%);--color-warning: hsl(38, 95%, 50%);--color-error: hsl(4, 90%, 58%);--color-info: hsl(200, 90%, 50%);--color-gray-50: hsl(220, 20%, 98%);--color-gray-100: hsl(220, 15%, 95%);--color-gray-200: hsl(220, 14%, 90%);--color-gray-300: hsl(220, 12%, 80%);--color-gray-400: hsl(220, 10%, 60%);--color-gray-500: hsl(220, 10%, 45%);--color-gray-600: hsl(220, 12%, 35%);--color-gray-700: hsl(220, 14%, 25%);--color-gray-800: hsl(220, 16%, 18%);--color-gray-900: hsl(220, 20%, 12%);--color-gray-950: hsl(220, 25%, 8%);--surface-primary: var(--color-gray-50);--surface-secondary: var(--color-gray-100);--surface-elevated: white;--surface-overlay: rgba(255, 255, 255, .8);--mask-solid: #fff;--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-600);--text-tertiary: var(--color-gray-400);--text-on-primary: white;--border-subtle: var(--color-gray-200);--border-default: var(--color-gray-300);--border-strong: var(--color-gray-400);--surface-hover: var(--color-gray-100);--surface-hover-strong: var(--color-gray-200);--card-bg: var(--surface-elevated);--primary-hover: var(--color-primary-600);--secondary-bg: var(--surface-secondary);--secondary-hover: var(--surface-hover-strong);--text-muted: var(--text-tertiary);--disabled-bg: var(--surface-secondary);--bg-light: var(--surface-secondary);--bg-hover: var(--surface-hover-strong);--danger-hover: hsl(4, 80%, 50%);--danger-bg: hsl(4, 95%, 94%);--danger-text: hsl(4, 70%, 33%);--danger-border: hsl(4, 70%, 80%);--info-bg: hsl(200, 90%, 92%);--info-text: hsl(200, 80%, 24%);--success-bg: hsl(145, 45%, 90%);--success-text: hsl(145, 70%, 22%);--warning-bg: hsl(38, 95%, 90%);--warning-text: hsl(38, 80%, 26%);--backdrop-overlay: rgba(15, 23, 42, .45);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-glow: 0 0 40px rgba(99, 102, 241, .15);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-xs: .75rem;--font-size-sm: .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-size-5xl: 3rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--z-tooltip: 500;--header-height: 64px;--sidebar-width: 280px;--sidebar-collapsed-width: 72px}[data-theme=dark],.dark{color-scheme:dark;--surface-primary: var(--color-gray-950);--surface-secondary: var(--color-gray-900);--surface-elevated: var(--color-gray-800);--surface-overlay: rgba(0, 0, 0, .6);--text-primary: var(--color-gray-50);--text-secondary: var(--color-gray-400);--text-tertiary: var(--color-gray-500);--border-subtle: var(--color-gray-800);--border-default: var(--color-gray-700);--border-strong: var(--color-gray-500);--surface-hover: var(--color-gray-800);--surface-hover-strong: var(--color-gray-700);--color-primary-500: var(--color-primary-400);--primary-hover: var(--color-primary-300);--secondary-bg: var(--surface-secondary);--secondary-hover: var(--surface-hover-strong);--disabled-bg: var(--color-gray-900);--bg-light: var(--color-gray-900);--bg-hover: var(--surface-hover);--danger-hover: hsl(4, 95%, 66%);--danger-bg: hsl(4, 48%, 20%);--danger-text: hsl(4, 100%, 82%);--danger-border: hsla(4, 90%, 58%, .45);--info-bg: hsl(200, 45%, 20%);--info-text: hsl(200, 100%, 80%);--success-bg: hsl(145, 42%, 20%);--success-text: hsl(145, 80%, 76%);--warning-bg: hsla(38, 95%, 50%, .2);--warning-text: hsl(38, 100%, 78%);--backdrop-overlay: rgba(0, 0, 0, .6);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(99, 102, 241, .25)}@media(prefers-color-scheme:dark){[data-theme=system]{color-scheme:dark;--surface-primary: var(--color-gray-950);--surface-secondary: var(--color-gray-900);--surface-elevated: var(--color-gray-800);--surface-overlay: rgba(0, 0, 0, .6);--text-primary: var(--color-gray-50);--text-secondary: var(--color-gray-400);--text-tertiary: var(--color-gray-500);--border-subtle: var(--color-gray-800);--border-default: var(--color-gray-700);--border-strong: var(--color-gray-500);--surface-hover: var(--color-gray-800);--surface-hover-strong: var(--color-gray-700);--color-primary-500: var(--color-primary-400);--primary-hover: var(--color-primary-300);--secondary-bg: var(--surface-secondary);--secondary-hover: var(--surface-hover-strong);--disabled-bg: var(--color-gray-900);--bg-light: var(--color-gray-900);--bg-hover: var(--surface-hover);--danger-hover: hsl(4, 95%, 66%);--danger-bg: hsl(4, 48%, 20%);--danger-text: hsl(4, 100%, 82%);--danger-border: hsla(4, 90%, 58%, .45);--info-bg: hsl(200, 45%, 20%);--info-text: hsl(200, 100%, 80%);--success-bg: hsl(145, 42%, 20%);--success-text: hsl(145, 80%, 76%);--warning-bg: hsla(38, 95%, 50%, .2);--warning-text: hsl(38, 100%, 78%);--backdrop-overlay: rgba(0, 0, 0, .6)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background:var(--surface-primary);min-height:100vh}.layout-shell{position:relative;height:100dvh;overflow:hidden}.layout-frame{display:flex;height:100%}.skip-link{position:absolute;left:-9999px;top:var(--space-2);z-index:calc(var(--z-modal) + 1);background:var(--surface-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--space-2) var(--space-4);text-decoration:none}.skip-link:focus{left:var(--space-2)}.header{height:var(--header-height);background:var(--surface-overlay);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);flex-shrink:0}.header-start{display:flex;align-items:center;gap:var(--space-4)}.header-end{display:flex;align-items:center;gap:var(--space-3)}.onboarding-chip{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:1px solid var(--color-primary-400);color:var(--color-primary-600);text-decoration:none;font-size:var(--font-size-xs);font-weight:600}.onboarding-chip:hover{background:var(--surface-hover)}.logo{font-size:var(--font-size-xl);font-weight:700;background:linear-gradient(135deg,var(--color-primary-500),var(--color-accent-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.main-container{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-width);background:var(--surface-secondary);border-right:1px solid var(--border-subtle);transition:transform var(--transition-normal);z-index:var(--z-dropdown);display:flex;flex-direction:column;overflow-y:auto}.sidebar.closed{transform:translate(-100%)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.sidebar-close-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border-default);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);font-weight:500}.nav-link:hover{background:var(--surface-hover);color:var(--color-primary-500)}.nav-link.active{background:var(--surface-hover);color:var(--color-primary-500);border:1px solid var(--border-default)}.content{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden}.content-inner{width:min(1120px,100%);margin:0 auto;padding:var(--space-8) var(--space-6)}.mobile-sidebar-overlay{position:fixed;inset:0;z-index:calc(var(--z-dropdown) - 1);border:none;background:var(--backdrop-overlay);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);cursor:pointer}.theme-toggle-btn{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--surface-elevated);color:var(--text-secondary);cursor:pointer}@media(min-width:769px){.layout-frame{display:grid;grid-template-columns:var(--sidebar-width) 1fr}.sidebar{position:relative;inset:auto;transform:translate(0);z-index:auto}.sidebar.closed{transform:translate(0)}.sidebar-close-btn,.sidebar-toggle{display:none}}@media(max-width:768px){.header{padding:0 var(--space-4)}.header-end{gap:var(--space-2)}.command-palette-trigger>span{display:none}.content-inner{padding:var(--space-6) var(--space-4)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--font-size-sm);font-weight:600;line-height:1;text-decoration:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.btn-primary{background:linear-gradient(135deg,var(--color-primary-500),var(--color-accent-500));color:#fff;box-shadow:var(--shadow-md),0 0 0 0 var(--color-primary-400)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg),0 0 20px #6366f166}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-strong)}.command-palette-trigger{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--surface-elevated);color:var(--text-secondary);cursor:pointer}.command-palette-trigger kbd,.command-item-meta kbd{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-xs);font-family:var(--font-mono);padding:0 var(--space-1)}.command-palette-backdrop{position:fixed;inset:0;z-index:var(--z-modal);background:#00000073;display:flex;justify-content:center;align-items:flex-start;padding-top:12vh}.command-palette{width:min(680px,92vw);background:var(--surface-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden}.command-palette-input{width:100%;border:none;border-bottom:1px solid var(--border-subtle);background:transparent;color:var(--text-primary);padding:var(--space-4);font-size:var(--font-size-base)}.command-palette-input:focus{outline:none}.command-palette-results{list-style:none;max-height:360px;overflow-y:auto;padding:var(--space-2)}.command-item{width:100%;border:none;background:transparent;text-align:left;display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer}.command-item:hover,.command-item.active{background:var(--surface-hover)}.command-item-label{color:var(--text-primary)}.command-item-meta{display:inline-flex;align-items:center;gap:var(--space-2)}.command-item-group{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em}.command-item-empty{color:var(--text-secondary);padding:var(--space-4)}.sidebar-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-toggle:hover{background:var(--surface-hover)}.hamburger-icon{display:block;width:18px;height:2px;background:var(--text-primary);position:relative}.hamburger-icon:before,.hamburger-icon:after{content:"";position:absolute;width:18px;height:2px;background:var(--text-primary);left:0}.hamburger-icon:before{top:-6px}.hamburger-icon:after{top:6px}.user-menu{display:flex;align-items:center;gap:var(--space-3)}.user-name{font-weight:500;color:var(--text-secondary)}.sign-out-btn,.sign-in-btn{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.sign-out-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border-default)}.sign-out-btn:hover{background:var(--color-error);color:#fff;border-color:var(--color-error)}.sign-in-btn{background:var(--color-primary-500);color:#fff;border:none}.sign-in-btn:hover{background:var(--color-primary-600)}.hero{text-align:center;padding:var(--space-20) var(--space-4);max-width:800px;margin:0 auto}.hero h1{font-size:var(--font-size-5xl);font-weight:700;background:linear-gradient(135deg,var(--color-primary-500),var(--color-accent-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-4);animation:fadeInUp .6s ease-out}.hero-subtitle{font-size:var(--font-size-xl);color:var(--text-secondary);margin-bottom:var(--space-8);animation:fadeInUp .6s ease-out .1s backwards}.hero-actions{display:flex;gap:var(--space-4);justify-content:center;animation:fadeInUp .6s ease-out .2s backwards}.features{padding:var(--space-16) var(--space-4);max-width:1200px;margin:0 auto}.features h2{text-align:center;font-size:var(--font-size-3xl);margin-bottom:var(--space-12)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-6)}.feature-card{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-normal)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-primary-300)}.feature-card h3{font-size:var(--font-size-lg);margin-bottom:var(--space-3)}.feature-card p{color:var(--text-secondary);font-size:var(--font-size-sm)}.placeholder-page,.not-found-page{text-align:center;padding:var(--space-16)}.placeholder-page h2,.not-found-page h1{font-size:var(--font-size-3xl);color:var(--text-primary);margin-bottom:var(--space-4)}.placeholder-page p,.not-found-page p{color:var(--text-secondary);margin-bottom:var(--space-6)}.not-found-page h1{font-size:var(--font-size-5xl);background:linear-gradient(135deg,var(--color-primary-500),var(--color-accent-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-loading,.callback-loading,.callback-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;gap:var(--space-4)}.callback-error{color:var(--color-error)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spinner{width:40px;height:40px;border:3px solid var(--border-subtle);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}
