:root{--background:#f8f9ff;--surface:#ffffff;--surface-low:#eff4ff;--surface-mid:#e5eeff;--surface-high:#d3e4fe;--text:#0b1c30;--muted:#484457;--outline:#c9c3da;--outline-strong:#797488;--primary:#4a00e1;--primary-strong:#6333ff;--primary-soft:#e6deff;--secondary:#5c5c79;--tertiary:#842261;--success:#059669;--success-soft:#d1fae5;--warning:#b45309;--warning-soft:#fef3c7;--danger:#ba1a1a;--danger-soft:#ffdad6;--sidebar:#0f172a;--shadow:0 10px 30px rgba(15,23,42,0.08);--radius:8px}*{box-sizing:border-box}body,html{min-height:100%;margin:0;background:var(--background);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}button,input,select,textarea{font:inherit}a,button{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,rgba(99,51,255,.08),rgba(211,228,254,.5)),var(--background)}.login-panel{width:min(420px,100%);background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px}.login-logo{display:block;max-width:170px;height:auto;margin:0 auto 24px}.login-panel h1{margin:0;text-align:center;font-size:28px;line-height:36px}.login-panel p{margin:8px 0 28px;text-align:center;color:var(--muted)}.field,.login-form{display:flex;flex-direction:column;gap:12px}.field label,.login-form label{display:flex;flex-direction:column;gap:8px;color:var(--muted);font-size:12px;font-weight:600}input,select,textarea{width:100%;border:1px solid var(--outline);border-radius:6px;background:var(--surface);color:var(--text);padding:10px 12px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}textarea{resize:vertical;min-height:120px}input:focus,select:focus,textarea:focus{border-color:var(--primary-strong);box-shadow:0 0 0 3px rgba(99,51,255,.12)}.ghost-button,.ghost-icon,.link-button,.primary-button,.secondary-button{border:0;cursor:pointer}.ghost-button,.primary-button,.secondary-button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:6px;padding:8px 14px;font-size:13px;font-weight:700;white-space:nowrap}.primary-button{background:var(--primary);color:white}.primary-button:hover{background:var(--primary-strong)}.secondary-button{background:var(--primary-soft);color:var(--primary);border:1px solid rgba(99,51,255,.18)}.ghost-button{background:var(--surface);color:var(--text);border:1px solid var(--outline)}.ghost-button:disabled,.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.55}.ghost-icon{width:36px;height:36px;border-radius:50%;background:transparent;color:var(--muted)}.link-button{padding:0;background:transparent;color:var(--primary);font-weight:700}.full{width:100%}.error-box,.seed-note,.success-box{margin-top:16px;border-radius:6px;padding:12px;font-size:12px;line-height:18px}.seed-note{display:flex;flex-direction:column;gap:4px;background:var(--surface-low);color:var(--muted)}.success-box{border:1px solid #86efac;background:var(--success-soft);color:#065f46}.error-box{border:1px solid #fca5a5;background:var(--danger-soft);color:var(--danger)}.app-shell{min-height:100vh;display:flex;background:var(--background)}.sidebar{position:fixed;inset:0 auto 0 0;width:240px;display:flex;flex-direction:column;padding:24px 10px;background:var(--sidebar);color:#e2e8f0;z-index:30;overflow-y:auto}.brand-block{display:flex;align-items:center;gap:12px;padding:0 14px 24px}.brand-mark{width:34px;height:34px;border-radius:8px;background:var(--primary-strong);display:grid;place-items:center;color:white;font-size:12px;font-weight:900}.brand-block strong{display:block;color:white;font-size:18px}.brand-block span{display:block;color:#94a3b8;font-size:12px}.side-nav{display:flex;flex-direction:column;gap:3px}.side-nav button,.sidebar-footer a,.sidebar-footer button{min-height:40px;display:flex;align-items:center;gap:12px;width:100%;border:0;border-radius:6px;background:transparent;color:#94a3b8;padding:10px 14px;font-size:13px;text-align:left;cursor:pointer}.side-nav button:hover,.sidebar-footer a:hover,.sidebar-footer button:hover{background:rgba(30,41,59,.85);color:white}.side-nav button.active{background:rgba(30,41,59,.9);border-left:4px solid var(--primary-strong);color:white;font-weight:800}.sidebar-footer{margin-top:auto;padding:20px 4px 0;border-top:1px solid rgba(148,163,184,.2)}.sidebar-footer .upgrade-button{justify-content:center;margin-bottom:10px;background:var(--primary-strong);color:white;font-weight:800}.workspace{min-width:0;flex:1 1;margin-left:240px;display:flex;flex-direction:column}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 24px;background:rgba(255,255,255,.86);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,195,218,.72)}.button-row,.chip-row,.toolbar,.topbar-left,.topbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.project-switcher{display:flex;align-items:center;gap:8px}.project-switcher span{color:var(--muted);font-size:12px;font-weight:700}.project-switcher select{width:210px;background:var(--surface-low)}.search-box{width:min(330px,28vw);position:relative}.search-box span{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--outline-strong);pointer-events:none}.search-box input{padding-left:36px;background:var(--surface-low)}.role-pill{border:1px solid rgba(99,51,255,.2);border-radius:999px;background:var(--primary-soft);color:var(--primary);padding:6px 10px;font-size:12px;font-weight:800;white-space:nowrap}.avatar{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--outline);border-radius:50%;background:var(--surface-mid);color:var(--primary);font-weight:900}.page-root{flex:1 1;padding:24px;display:flex;flex-direction:column;gap:20px;max-width:1600px;width:100%;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;border-bottom:1px solid rgba(201,195,218,.7);padding-bottom:18px}.page-header h2{margin:0;font-size:28px;line-height:36px;letter-spacing:0}.page-header p{margin:6px 0 0;color:var(--muted);font-size:14px}.card-grid,.grid-2,.metric-grid{display:grid;grid-gap:16px;gap:16px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-grid.mini{grid-template-columns:repeat(2,minmax(0,1fr))}.metric-grid.mini .metric-card{min-height:124px}.grid-2{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr)}.card-grid{grid-template-columns:repeat(4,minmax(220px,1fr))}.card,.panel{background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius);box-shadow:0 4px 14px rgba(15,23,42,.04)}.metric-card{position:relative;overflow:hidden;padding:16px;min-height:142px}.metric-foot,.metric-label{color:var(--muted);font-size:12px;font-weight:700}.metric-value{margin:18px 0 14px;font-size:34px;line-height:38px;font-weight:900}.panel{overflow:hidden}.panel>:not(.panel-header){margin:16px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(201,195,218,.6);background:var(--surface-low)}.panel-header h3{margin:0;font-size:15px}.panel-header span{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:600}.table-wrap{overflow-x:auto}table{width:100%;min-width:680px;border-collapse:collapse;font-size:13px}td,th{padding:11px 12px;border-bottom:1px solid rgba(201,195,218,.52);text-align:left;vertical-align:middle}th{background:var(--surface-low);color:var(--muted);font-size:12px;font-weight:800}tr:hover td{background:rgba(239,244,255,.56)}.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:4px;border:1px solid transparent;padding:3px 7px;font-size:11px;font-weight:800;white-space:nowrap}.badge.green{background:var(--success-soft);color:#065f46;border-color:#86efac}.badge.amber{background:var(--warning-soft);color:var(--warning);border-color:#fcd34d}.badge.red{background:var(--danger-soft);color:var(--danger);border-color:#fca5a5}.badge.purple{background:var(--primary-soft);color:var(--primary);border-color:rgba(99,51,255,.24)}.badge.blue{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.badge.gray{background:var(--surface-low);color:var(--muted);border-color:var(--outline)}.activity-list{display:flex;flex-direction:column;gap:10px}.alert-list,.message-list,.ops-list{display:flex;flex-direction:column;gap:12px}.message-list.compact{gap:10px}.alert-card,.message-card,.ops-row,.sync-card{border:1px solid rgba(201,195,218,.65);border-radius:6px;background:var(--surface);padding:12px}.alert-top,.message-head,.ops-row{display:flex;align-items:center;gap:10px;justify-content:space-between}.alert-top strong,.message-head strong{margin-right:auto}.alert-card p,.message-card p{margin:10px 0 0;color:var(--text);font-size:13px;line-height:20px}.muted{color:var(--muted)!important}.ops-row div{display:flex;min-width:0;flex-direction:column;gap:4px}.ops-row strong{font-size:13px}.message-head span,.ops-row span,.sync-card small,.sync-card span{color:var(--muted);font-size:12px}.sync-card small{width:100%;overflow-wrap:anywhere}.sync-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.sync-card{display:flex;min-height:120px;flex-direction:column;align-items:flex-start;gap:10px}.sync-card strong{font-size:16px}.activity-row{display:grid;grid-template-columns:90px 96px 1fr auto;grid-gap:12px;gap:12px;align-items:center;border:1px solid rgba(201,195,218,.55);border-radius:6px;padding:10px;background:var(--surface);font-size:13px}.activity-row em{color:var(--primary);font-style:normal;font-weight:700}.activity-row small{color:var(--outline-strong)}.chart-panel{overflow:visible}.line-chart{height:300px;margin:16px 16px 4px;border:1px solid rgba(201,195,218,.58);border-radius:6px;background:linear-gradient(180deg,#fff,#fbfcff);padding:12px}.line-chart svg{width:100%;height:100%;overflow:visible}.chart-grid-line{stroke:rgba(201,195,218,.55);stroke-width:.35}.chart-grid-line,.chart-line{vector-effect:non-scaling-stroke}.chart-line{fill:none;stroke-width:2.2}.chart-axis{justify-content:space-between;gap:8px;margin:0 18px 10px;color:var(--outline-strong);font-size:11px}.chart-axis,.chart-legend{display:flex;font-weight:700}.chart-legend{flex-wrap:wrap;gap:10px 16px;margin:0 16px 16px;color:var(--muted);font-size:12px}.chart-legend span{display:inline-flex;align-items:center;gap:6px}.chart-legend i{width:9px;height:9px;border-radius:50%}.report-list{display:flex;flex-direction:column;gap:14px}.report-detail{border:1px solid rgba(201,195,218,.65);border-radius:6px;background:var(--surface);padding:14px}.report-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.report-head h3{margin:0 0 4px;font-size:16px}.report-detail p,.report-head span{color:var(--muted);font-size:13px;line-height:20px}.report-detail p{margin:12px 0}.report-columns{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:12px;gap:12px}.report-columns div{display:flex;flex-direction:column;gap:6px;border-radius:6px;background:var(--surface-low);padding:10px;color:var(--muted);font-size:12px;line-height:18px}.report-columns strong{color:var(--text);font-size:13px}.mini-switch{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:12px;font-weight:800}.mini-switch input{width:16px;height:16px;accent-color:var(--primary)}.kanban{min-height:calc(100vh - 170px);display:grid;grid-template-columns:repeat(5,minmax(240px,1fr));grid-gap:14px;gap:14px;overflow-x:auto;padding-bottom:10px}.kanban-col{display:flex;flex-direction:column;gap:10px;min-width:240px}.kanban-head{display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase}.kanban-head b{border-radius:999px;background:var(--surface-mid);padding:2px 8px}.task-card{display:flex;flex-direction:column;gap:10px;border:1px solid var(--outline);border-radius:var(--radius);background:var(--surface);padding:14px}.task-card.doing{border-left:4px solid var(--primary-strong)}.task-card.overdue{border-left:4px solid var(--danger)}.task-card.done{opacity:.68}.task-card h4{margin:0;font-size:14px;line-height:20px}.task-card p{margin:0;color:var(--muted);font-size:12px}.progress{height:5px;border-radius:999px;background:var(--surface-mid);overflow:hidden}.progress span{display:block;height:100%;background:var(--primary-strong)}.asset-card,.channel-card,.report-card{min-height:190px;display:flex;flex-direction:column;gap:12px;padding:16px}.asset-card h3,.channel-card h3,.report-card h3{margin:0;font-size:16px}.asset-card p,.channel-card p,.report-card p{margin:0;color:var(--muted);font-size:13px;line-height:20px}.asset-card button,.channel-card a,.report-card button{margin-top:auto}.asset-thumb{height:90px;display:grid;place-items:center;border:1px dashed var(--outline);border-radius:6px;background:var(--surface-low);color:var(--primary);font-size:24px;font-weight:900}.chip{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;padding:4px 10px;color:var(--muted);font-size:12px}.chip,.toast{border:1px solid var(--outline);background:var(--surface);font-weight:700}.toast{position:fixed;right:24px;bottom:24px;z-index:60;max-width:min(420px,calc(100vw - 48px));border-radius:var(--radius);color:var(--text);box-shadow:var(--shadow);padding:12px 14px;font-size:13px}.toast.success{border-color:#86efac}.toast.warn{border-color:#fcd34d}.modal-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:20px;background:rgba(15,23,42,.36);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:min(620px,100%);max-height:calc(100vh - 40px);overflow:auto;border:1px solid var(--outline);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.modal-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--outline);padding:14px 16px;background:var(--surface-low)}.modal-head h3{margin:0}.modal-body{padding:16px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px}.form-grid label{display:flex;flex-direction:column;gap:8px;color:var(--muted);font-size:12px;font-weight:800}.form-grid .context-box,.form-grid .modal-foot,.form-grid label:first-of-type{grid-column:1/-1}.context-box{border:1px solid rgba(99,51,255,.22);border-radius:6px;background:var(--primary-soft);color:var(--primary);padding:10px;font-size:12px;line-height:18px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.mobile-only{display:none}@media (max-width:1180px){.card-grid,.grid-2,.metric-grid,.metric-grid.mini,.metric-grid.three,.sync-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.search-box{display:none}}@media (max-width:820px){.mobile-only{display:inline-grid}.sidebar{transform:translateX(-100%);transition:transform .18s ease}.app-shell.menu-open .sidebar{transform:translateX(0)}.workspace{margin-left:0}.topbar{align-items:flex-start;flex-direction:column;min-height:auto;padding:12px}.page-header,.topbar-left,.topbar-right{width:100%}.topbar-right{justify-content:space-between}.project-switcher select{width:min(56vw,220px)}.page-root{padding:16px}.page-header{align-items:flex-start;flex-direction:column}.card-grid,.form-grid,.grid-2,.metric-grid,.metric-grid.mini,.metric-grid.three,.sync-grid{grid-template-columns:1fr}.line-chart{height:240px}.chart-axis{overflow-x:auto}.report-head{flex-direction:column}.report-columns{grid-template-columns:1fr}.kanban{grid-template-columns:repeat(5,260px)}.activity-row{grid-template-columns:1fr}}@media (max-width:480px){.login-panel{padding:24px}.page-header h2{font-size:24px;line-height:32px}.metric-value{font-size:30px}.role-pill{max-width:120px;overflow:hidden;text-overflow:ellipsis}}