:root{--font-display: "Cabinet Grotesk", "SF Pro Display", system-ui, sans-serif;--font-body: "Satoshi", "SF Pro Text", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--text-xs: clamp(.75rem, .7rem + .25vw, .875rem);--text-sm: clamp(.875rem, .8rem + .35vw, 1rem);--text-base: clamp(1rem, .95rem + .25vw, 1.125rem);--text-lg: clamp(1.125rem, 1rem + .75vw, 1.5rem);--text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);--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;--space-24: 6rem;--color-bg: #080610;--color-surface: #0d0b1a;--color-surface-2: #111027;--color-surface-offset: #181630;--color-surface-dynamic: #201e3a;--color-border: rgba(148, 112, 255, .1);--color-divider: rgba(148, 112, 255, .06);--color-text: #ede9ff;--color-text-muted: #9d93c7;--color-text-faint: #5c5480;--color-text-inverse: #0d0b1a;--color-primary: #7c3aed;--color-primary-hover: #6d28d9;--color-primary-active: #5b21b6;--color-primary-highlight: rgba(124, 58, 237, .12);--color-primary-border: rgba(124, 58, 237, .3);--color-secondary: #c4b5fd;--color-secondary-hover: #a78bfa;--color-secondary-muted: rgba(196, 181, 253, .15);--color-glow: rgba(124, 58, 237, .25);--color-glow-lg: rgba(124, 58, 237, .1);--color-success: #34d399;--color-success-bg: rgba(52, 211, 153, .1);--color-error: #f87171;--color-error-bg: rgba(248, 113, 113, .1);--color-warning: #fbbf24;--color-warning-bg: rgba(251, 191, 36, .1);--color-info: #60a5fa;--color-info-bg: rgba(96, 165, 250, .1);--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: .875rem;--radius-xl: 1.25rem;--radius-2xl: 1.75rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(8,6,16,.5), 0 0 0 1px rgba(124,58,237,.06);--shadow-md: 0 4px 16px rgba(8,6,16,.6), 0 0 0 1px rgba(124,58,237,.08), 0 0 24px rgba(124,58,237,.04);--shadow-lg: 0 8px 32px rgba(8,6,16,.7), 0 0 0 1px rgba(124,58,237,.1), 0 0 48px rgba(124,58,237,.08);--shadow-glow: 0 0 20px rgba(124,58,237,.3), 0 0 60px rgba(124,58,237,.1);--shadow-button: 0 2px 8px rgba(124,58,237,.35), 0 0 0 1px rgba(124,58,237,.5);--transition: .18s cubic-bezier(.16, 1, .3, 1);--transition-slow: .32s cubic-bezier(.16, 1, .3, 1);--content-narrow: 640px;--content-default: 960px;--content-wide: 1280px}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-base);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{background:radial-gradient(900px 600px at 80% -10%,var(--color-glow-lg),transparent 60%),radial-gradient(700px 500px at -10% 110%,var(--color-glow-lg),transparent 60%),var(--color-bg);background-attachment:fixed}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;margin:0}p{margin:0}a{color:var(--color-secondary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--color-secondary-hover)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}code,pre{font-family:var(--font-mono)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-surface-offset);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-border)}::selection{background:var(--color-primary-highlight);color:var(--color-text)}*:focus-visible{outline:none;box-shadow:0 0 0 3px #7c3aed59;border-radius:var(--radius-sm)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-800px 0}to{background-position:800px 0}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.app-shell.collapsed{grid-template-columns:64px 1fr}.app-main{display:flex;flex-direction:column;min-width:0}.app-content{flex:1;padding:var(--space-8);max-width:var(--content-wide);width:100%;margin:0 auto}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.card.interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);transition:transform 80ms ease,background var(--transition),box-shadow var(--transition),color var(--transition);white-space:nowrap;user-select:none}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-button)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn-primary:active:not(:disabled){background:var(--color-primary-active);transform:scale(.97)}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-offset);color:var(--color-text)}.btn-danger{background:var(--color-error-bg);color:var(--color-error);border:1px solid rgba(248,113,113,.3)}.btn-danger:hover:not(:disabled){background:#f871712e}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn-block{width:100%}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);transition:border-color var(--transition),box-shadow var(--transition)}.input::placeholder{color:var(--color-text-faint)}.input:focus{outline:none;border-color:var(--color-primary-border);box-shadow:0 0 0 4px var(--color-primary-highlight)}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500;letter-spacing:.02em;text-transform:uppercase}.input-help{font-size:var(--text-xs);color:var(--color-text-faint)}.badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;letter-spacing:.02em}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-pending{background:#9d93c71a;color:var(--color-text-muted)}.badge-session{background:var(--color-info-bg);color:var(--color-info)}.badge-crawling{background:var(--color-warning-bg);color:var(--color-warning)}.badge-crawling .dot{animation:pulse-dot 1.4s ease-in-out infinite}.badge-analyzing{background:var(--color-secondary-muted);color:var(--color-secondary)}.badge-complete{background:var(--color-success-bg);color:var(--color-success)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-paused{background:#9d93c71f;color:var(--color-text-muted)}.progress{width:100%;height:6px;background:var(--color-surface-offset);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);transition:width .6s ease;box-shadow:0 0 12px var(--color-glow)}.modal-backdrop{position:fixed;inset:0;background:#0806108c;backdrop-filter:blur(12px) saturate(1.4);-webkit-backdrop-filter:blur(12px) saturate(1.4);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-4)}.modal{width:100%;max-width:520px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-8)}.modal h2{font-size:var(--text-lg);margin-bottom:var(--space-2)}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-8);background:#080610b3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-divider)}.topbar-title{font-family:var(--font-display);font-weight:600;font-size:var(--text-lg)}.topbar-actions{display:flex;align-items:center;gap:var(--space-3)}.sidebar{position:sticky;top:0;align-self:start;height:100vh;display:flex;flex-direction:column;background:var(--color-surface);border-right:1px solid var(--color-divider);padding:var(--space-6) var(--space-4);transition:width var(--transition)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-weight:700;font-size:var(--text-base);margin-bottom:var(--space-8);padding:0 var(--space-2)}.sidebar-logo svg{flex-shrink:0}.sidebar.collapsed .sidebar-label{display:none}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;border-left:2px solid transparent;transition:background var(--transition),color var(--transition),border-color var(--transition)}.sidebar-link:hover{background:var(--color-surface-offset);color:var(--color-text)}.sidebar-link.active{background:var(--color-surface-offset);color:var(--color-text);border-left-color:var(--color-primary)}.sidebar-footer{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-top:1px solid var(--color-divider);margin-top:var(--space-4)}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-xs);flex-shrink:0}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.login-card{width:100%;max-width:400px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);box-shadow:var(--shadow-lg),0 0 120px var(--color-glow-lg);display:flex;flex-direction:column;gap:var(--space-6)}.login-logo{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-weight:700;font-size:var(--text-lg)}.login-error{color:var(--color-error);font-size:var(--text-sm);background:var(--color-error-bg);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid rgba(248,113,113,.25)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.stat-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;margin-top:var(--space-2)}.empty-state{text-align:center;padding:var(--space-16) var(--space-8);color:var(--color-text-muted)}.empty-state .icon{width:64px;height:64px;margin:0 auto var(--space-6);color:var(--color-secondary);animation:float 4s ease-in-out infinite}.empty-state h3{color:var(--color-text);font-size:var(--text-lg);margin-bottom:var(--space-3)}.tabs{display:flex;gap:var(--space-2);border-bottom:1px solid var(--color-divider);margin-bottom:var(--space-6)}.tab{padding:var(--space-3) var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;border-bottom:2px solid transparent;cursor:pointer;transition:color var(--transition),border-color var(--transition)}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-text);border-bottom-color:var(--color-primary)}.crawl-log{background:#050408;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);font-family:var(--font-mono);font-size:var(--text-sm);height:480px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.crawl-log .line-crawl{color:var(--color-text-muted)}.crawl-log .line-analyze{color:var(--color-secondary)}.crawl-log .line-saved{color:var(--color-success)}.crawl-log .line-error{color:var(--color-error)}.crawl-log .line-done{color:var(--color-secondary-hover);font-weight:600}.file-list{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.file-row{display:grid;grid-template-columns:1fr 80px 120px 120px;gap:var(--space-4);align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-divider);background:var(--color-surface);font-size:var(--text-sm)}.file-row:last-child{border-bottom:none}.file-row:hover{background:var(--color-surface-offset)}.file-row.header{background:var(--color-surface-2);font-weight:500;color:var(--color-text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}.skeleton{background:linear-gradient(90deg,var(--color-surface) 0%,var(--color-surface-offset) 50%,var(--color-surface) 100%);background-size:800px 100%;animation:shimmer 1.6s linear infinite;border-radius:var(--radius-md)}.toast-stack{position:fixed;top:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);z-index:200}.toast{min-width:280px;padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);font-size:var(--text-sm)}.toast.success{border-color:#34d3994d}.toast.error{border-color:#f871714d}
