@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";:root{--canvas:#f8fafc;--card:#fff;--card-border:#f1f5f9;--sidebar-bg:#0b1120;--sidebar-text:#cbd5e1;--sidebar-muted:#64748b;--sidebar-hover:#1e293b;--sidebar-active:#1e293b;--primary:#2563eb;--primary-hover:#1d4ed8;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--border:#e2e8f0;--border-light:#f1f5f9;--input-border:#d1d5db;--success:#10b981;--warning:#f97316;--purple:#a855f7;--blue:#3b82f6;--amber:#d97706;--emerald:#059669;--red:#ef4444;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-card:0 1px 3px 0 #0000000d, 0 1px 2px -1px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a}*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;background:var(--canvas);color:var(--text-primary);height:100%;font-family:Inter,system-ui,-apple-system,sans-serif}#root{height:100%}.login-page{background:#f3f4f6;flex-direction:column;min-height:100vh;display:flex}.login-nav{border-bottom:2px solid var(--primary);background:#fff;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex}.login-nav-left{align-items:center;gap:10px;display:flex}.login-nav-logo{width:36px;height:36px}.login-nav-brand{color:var(--text-primary);letter-spacing:-.01em;font-size:16px;font-weight:700}.login-nav-brand small{color:var(--sidebar-muted);margin-top:-2px;font-size:11px;font-weight:500;display:block}.login-nav-right{align-items:center;gap:16px;display:flex}.login-nav-link{color:#374151;font-size:14px;font-weight:500;text-decoration:none}.login-nav-btn{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;background:#fff;padding:6px 16px;font-size:14px;font-weight:500}.login-main{flex:1;place-items:center;padding:48px 24px;display:grid}.login-card{border:1px solid var(--border);border-radius:var(--radius-lg);width:960px;max-width:96vw;box-shadow:var(--shadow-lg);background:#fff;grid-template-columns:1fr 1fr;min-height:520px;display:grid}.login-left{border-right:1px solid var(--border);flex-direction:column;padding:48px;display:flex}.login-logo-big{width:100px;height:100px;margin:0 auto 32px}.login-tabs{border-radius:var(--radius-md);background:#f3f4f6;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:32px;padding:4px;display:grid}.login-tab{color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:0;padding:10px;font-size:14px;font-weight:500}.login-tab.active{color:var(--text-primary);background:#fff;box-shadow:0 1px 2px #0000000d}.login-form{flex-direction:column;gap:20px;display:flex}.login-form label{color:#374151;font-size:14px;font-weight:500}.login-form input{border:1px solid var(--input-border);border-radius:var(--radius-sm);outline:none;height:42px;padding:0 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}.login-form input::placeholder{color:var(--text-muted)}.login-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:0;height:42px;font-size:15px;font-weight:500;transition:background .15s}.login-btn:hover{background:var(--primary-hover)}.login-divider{color:var(--text-muted);align-items:center;gap:12px;margin:8px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-google{border:1px solid var(--border);border-radius:var(--radius-sm);color:#374151;cursor:pointer;background:#fff;justify-content:center;align-items:center;gap:10px;height:42px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.login-google:hover{background:#f9fafb}.login-forgot{text-align:center;color:var(--primary);margin-top:4px;font-size:14px;font-weight:500;text-decoration:none}.login-right{flex-direction:column;padding:48px;display:flex}.login-right-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.login-right-header h2{color:var(--text-primary);font-size:18px;font-weight:700}.login-right p{color:var(--text-secondary);font-size:14px;line-height:1.5}.login-features{flex-direction:column;gap:12px;margin-top:24px;display:flex}.login-feature{color:#4b5563;align-items:center;gap:12px;font-size:14px;font-weight:500;display:flex}.login-feature svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}.login-cta-box{border:1px solid var(--border);border-radius:var(--radius-md);background:#f9fafb;margin-top:32px;padding:20px}.login-cta-box h4{color:var(--primary);margin-bottom:4px;font-size:14px;font-weight:600}.login-cta-box p{color:var(--text-secondary);font-size:14px}.login-cta-box a{color:var(--primary);align-items:center;gap:4px;margin-top:8px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.login-footer{text-align:center;border-top:1px solid var(--border);background:#f3f4f6;padding:24px}.login-footer a{color:var(--text-secondary);margin:0 8px;font-size:13px;text-decoration:none}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);width:240px;min-width:240px;color:var(--sidebar-text);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff0f;align-items:center;gap:10px;padding:16px;display:flex}.sidebar-brand-icon{width:28px;height:28px}.sidebar-brand-text{color:#fff;letter-spacing:-.01em;font-size:15px;font-weight:700}.sidebar-brand-text small{color:var(--sidebar-muted);letter-spacing:.02em;margin-top:1px;font-size:10px;font-weight:500;display:block}.sidebar-search{margin:8px 16px 12px}.sidebar-search input{background:var(--sidebar-hover);border-radius:var(--radius-sm);width:100%;height:36px;color:var(--sidebar-text);border:0;outline:none;padding:0 12px 0 32px;font-family:inherit;font-size:13px}.sidebar-search input::placeholder{color:var(--sidebar-muted)}.sidebar-search{position:relative}.sidebar-search:before{content:"🔍";opacity:.5;font-size:13px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.nav-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--sidebar-muted);padding:16px 16px 8px;font-size:11px;font-weight:600}.nav-item{height:36px;color:var(--sidebar-text);cursor:pointer;text-align:left;background:0 0;border:0;align-items:center;gap:12px;width:100%;padding:0 16px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.nav-item:hover,.nav-item.active{background:var(--sidebar-hover);color:#fff}.nav-item .nav-icon{border-radius:var(--radius-sm);place-items:center;width:20px;height:20px;font-size:12px;display:grid}.nav-item .nav-badge{background:var(--red);color:#fff;border-radius:999px;place-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:11px;font-weight:700;display:grid}.nav-expandable{color:var(--sidebar-text);cursor:pointer;justify-content:space-between;align-items:center;padding:8px 16px;font-size:14px;font-weight:500;display:flex}.nav-expandable:hover{background:var(--sidebar-hover)}.nav-subitems{flex-direction:column;display:flex}.nav-subitems .nav-item{height:32px;padding-left:48px;font-size:13px}.sidebar-footer{border-top:1px solid #ffffff0f;margin-top:auto;padding:8px 0}.sidebar-footer .nav-item{height:40px;color:var(--sidebar-muted)}.sidebar-version{color:#334155;padding:8px 16px;font-size:10px}.topbar{border-bottom:1px solid var(--border-light);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex}.topbar-left{align-items:center;gap:12px;display:flex}.btn-create{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:0;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.btn-create:hover{background:var(--primary-hover)}.btn-dropdown{border:1px solid var(--border);border-radius:var(--radius-md);color:#374151;cursor:pointer;background:#fff;align-items:center;gap:6px;padding:8px 12px;font-size:14px;font-weight:500;display:flex}.topbar-search{width:480px;max-width:40vw;position:relative}.topbar-search input{border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;height:40px;color:var(--text-primary);outline:none;padding:0 44px 0 40px;font-family:inherit;font-size:13px}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-search:before{content:"🔍";opacity:.4;font-size:15px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.topbar-search .kbd{color:var(--text-muted);background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:700;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.topbar-right{align-items:center;gap:12px;display:flex}.icon-btn{cursor:pointer;border:0;border-radius:999px;place-items:center;width:40px;height:40px;font-size:18px;display:grid;position:relative}.icon-btn.sparkles{background:#fef3c7}.icon-btn.clipboard{background:#f3e8ff}.icon-btn.mic,.icon-btn.bell{background:#ffe4e6}.icon-btn .badge{background:var(--red);color:#fff;border-radius:999px;place-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:grid;position:absolute;top:-2px;right:-2px}.user-pill{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:999px;place-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:grid}.user-info{flex-direction:column;display:flex}.user-info .name{color:var(--text-primary);font-size:14px;font-weight:600}.user-info .role{color:var(--text-secondary);font-size:12px}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.content-scroll{flex:1;padding:32px;overflow-y:auto}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.page-header-left{align-items:center;gap:12px;display:flex}.page-icon{color:#fff;border-radius:10px;place-items:center;width:40px;height:40px;font-size:20px;display:grid}.page-icon.orange{background:linear-gradient(135deg,#fb923c,#ea580c)}.page-title h1{color:var(--text-primary);letter-spacing:-.025em;font-size:24px;font-weight:700;line-height:1.2}.page-title p{color:var(--text-secondary);margin-top:2px;font-size:14px}.btn-ghost{border:1px solid var(--border);border-radius:var(--radius-md);color:#374151;cursor:pointer;background:#fff;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:flex}.kpi-grid-4{grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin-bottom:24px;display:grid}.kpi-icon-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:24px;position:relative}.kpi-icon-card .label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500}.kpi-icon-card .value{color:var(--text-primary);letter-spacing:-.02em;font-size:28px;font-weight:700}.kpi-icon-card .icon-box{border-radius:var(--radius-md);color:#fff;place-items:center;width:48px;height:48px;font-size:20px;display:grid;position:absolute;top:24px;right:24px}.kpi-icon-card .icon-box.green{background:var(--success);box-shadow:0 8px 24px -6px #10b98159}.kpi-icon-card .icon-box.orange{background:var(--warning);box-shadow:0 8px 24px -6px #f9731659}.kpi-icon-card .icon-box.purple{background:var(--purple);box-shadow:0 8px 24px -6px #a855f759}.kpi-icon-card .icon-box.blue{background:var(--blue);box-shadow:0 8px 24px -6px #3b82f659}.kpi-progress-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:24px}.kpi-progress-card .label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500}.kpi-progress-card .value{margin-bottom:10px;font-size:24px;font-weight:700}.kpi-progress-card .value.blue{color:var(--primary)}.kpi-progress-card .value.amber{color:var(--amber)}.kpi-progress-card .value.emerald{color:var(--emerald)}.kpi-progress-card .track{background:#f3f4f6;border-radius:999px;width:100%;height:8px;margin-bottom:6px;overflow:hidden}.kpi-progress-card .track .fill{border-radius:999px;height:100%}.kpi-progress-card .fill.blue{background:var(--blue)}.kpi-progress-card .fill.emerald{background:var(--emerald)}.kpi-progress-card .caption{color:var(--text-muted);font-size:12px}.bottom-split{grid-template-columns:2fr 1fr;gap:24px;display:grid}.chart-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:24px}.chart-card h3{color:var(--text-primary);margin-bottom:16px;font-size:16px;font-weight:600}.tech-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:24px}.tech-card h3{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.tech-filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tech-filter{border-radius:999px;align-items:center;gap:4px;padding:4px 12px;font-size:11px;font-weight:600;display:flex}.tech-filter.blue{color:var(--primary);background:#eff6ff;border:1px solid #dbeafe}.tech-filter.green{color:var(--emerald);background:#ecfdf5;border:1px solid #d1fae5}.tech-filter.gray{color:#4b5563;background:#f3f4f6}.tech-list{flex-direction:column;display:flex}.tech-row{border-bottom:1px solid #f9fafb;align-items:center;gap:12px;padding:12px 0;display:flex}.tech-row:last-child{border-bottom:0}.tech-avatar{color:#fff;border-radius:999px;place-items:center;width:40px;height:40px;font-size:13px;font-weight:600;display:grid;position:relative}.tech-avatar .dot{background:var(--text-muted);border:2px solid #fff;border-radius:999px;width:10px;height:10px;position:absolute;bottom:0;right:0}.tech-name{color:var(--text-primary);flex:1;font-size:14px;font-weight:500}.tech-badge{color:var(--text-secondary);background:#f3f4f6;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:500}.module-workspace{flex-direction:column;gap:16px;display:flex}.module-toolbar{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-md);align-items:center;gap:10px;padding:12px;display:flex}.module-table-wrap{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-md);overflow:hidden}.module-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border-light);white-space:nowrap;background:#f8fafc;padding:10px 16px;font-size:11px;font-weight:700}.module-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);padding:10px 16px}.btn{border-radius:var(--radius-md);cursor:pointer;border:0;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-ghost{border:1px solid var(--border);color:#374151;background:#fff}.btn-ghost:hover{background:#f8fafc}.btn-danger{background:var(--red);color:#fff}.modal-backdrop{z-index:50;background:#0f172a73;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);width:min(720px,96vw);max-height:90vh;box-shadow:var(--shadow-lg);padding:24px;overflow:auto}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;display:flex}.modal-header h2{font-size:18px;font-weight:700}.modal-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.modal-field{flex-direction:column;gap:4px;display:flex}.modal-field label{color:#374151;font-size:13px;font-weight:500}.modal-field input,.modal-field select{border:1px solid var(--input-border);border-radius:var(--radius-sm);outline:none;height:40px;padding:0 12px;font-family:inherit;font-size:13px}.modal-field input:focus,.modal-field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}.modal-actions{border-top:1px solid var(--border-light);justify-content:flex-end;gap:10px;margin-top:16px;padding-top:16px;display:flex}.badge{border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{color:var(--emerald);background:#ecfdf5}.badge-blue{color:var(--primary);background:#eff6ff}.badge-gray{color:var(--text-secondary);background:#f3f4f6}.badge-red{color:var(--red);background:#fef2f2}.loading-screen{background:var(--canvas);justify-content:center;align-items:center;height:100vh;display:flex}@media (width<=1200px){.kpi-grid-4{grid-template-columns:repeat(2,1fr)}.bottom-split{grid-template-columns:1fr}}@media (width<=900px){.sidebar{width:200px;min-width:200px}.topbar-search{width:280px}}@media (width<=720px){.app-shell{flex-direction:column}.sidebar{width:100%;min-width:100%;max-height:200px}.kpi-grid-4,.login-card{grid-template-columns:1fr}.login-right{display:none}}.module-page{flex-direction:column;gap:20px;display:flex}.kpi-row{flex-wrap:wrap;gap:16px;display:flex}.kpi-pill{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);min-width:160px;box-shadow:var(--shadow-card);cursor:pointer;align-items:center;gap:14px;padding:16px 20px;transition:border-color .15s;display:flex}.kpi-pill:hover{border-color:var(--primary)}.kpi-pill.active{border:2px solid var(--primary)}.kpi-pill-icon{border-radius:var(--radius-md);place-items:center;width:40px;height:40px;font-size:18px;display:grid}.kpi-pill-info{flex-direction:column;display:flex}.kpi-pill-label{color:var(--text-secondary);text-transform:capitalize;font-size:12px;font-weight:600}.kpi-pill-value{color:var(--text-primary);letter-spacing:-.02em;font-size:22px;font-weight:700}.filter-bar{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:12px 16px;display:flex}.filter-search{flex:1;max-width:320px;position:relative}.filter-search input{border:1px solid var(--border);border-radius:999px;outline:none;width:100%;height:36px;padding:0 16px 0 36px;font-size:13px}.filter-search:before{content:"🔍";opacity:.4;font-size:13px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.filter-pill{border:1px solid var(--border);color:#374151;cursor:pointer;background:#fff;border-radius:999px;align-items:center;gap:6px;height:36px;padding:0 14px;font-size:13px;font-weight:500;display:flex}.module-table-wrap{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden}.module-table{border-collapse:collapse;width:100%;font-size:13px}.module-table thead tr{background:#f8fafc}.module-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);border-bottom:1px solid var(--border-light);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:700}.module-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle;padding:14px 16px}.module-table tr:hover td{background:#f8fafc}.module-table tr:last-child td{border-bottom:0}.module-table .link{color:var(--primary);cursor:pointer;font-weight:500}.module-table .link:hover{text-decoration:underline}.module-table .dim{color:var(--text-muted)}.module-table .actions{text-align:right}.module-table .actions button{padding:4px 10px;font-size:12px}.empty-state{text-align:center;color:var(--text-secondary);padding:48px;font-size:14px}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}
