:root{--brand-700: oklch(.36 .13 265);--brand-600: oklch(.46 .16 265);--brand-500: oklch(.56 .16 265);--brand-100: oklch(.95 .03 265);--brand-50: oklch(.98 .015 265);--ink-900: oklch(.2 .012 265);--ink-700: oklch(.36 .01 265);--ink-500: oklch(.55 .01 265);--ink-400: oklch(.68 .01 265);--ink-300: oklch(.82 .008 265);--line: oklch(.92 .006 265);--line-2: oklch(.95 .005 265);--bg: oklch(.985 .004 265);--surface: oklch(.998 .002 265);--surface-2: oklch(.975 .005 265);--green-600: oklch(.55 .13 155);--green-100: oklch(.95 .04 155);--amber-600: oklch(.66 .14 70);--amber-100: oklch(.96 .05 80);--red-600: oklch(.58 .18 25);--red-100: oklch(.95 .04 25);--blue-600: oklch(.55 .14 240);--blue-100: oklch(.95 .04 240);--violet-600: oklch(.55 .15 300);--violet-100: oklch(.95 .04 300);--shadow-sm: 0 1px 2px rgba(20,24,40,.04), 0 1px 1px rgba(20,24,40,.03);--shadow-md: 0 4px 14px rgba(20,24,40,.06), 0 2px 4px rgba(20,24,40,.04);--shadow-lg: 0 12px 40px rgba(20,24,40,.1), 0 4px 10px rgba(20,24,40,.05);--topbar-bg: rgba(255,255,255,.85);--hero-grad-1: oklch(.96 .04 265);--hero-grad-2: oklch(.99 .01 265);--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 20px}[data-theme=dark]{--brand-700: oklch(.78 .13 265);--brand-600: oklch(.68 .15 265);--brand-500: oklch(.58 .16 265);--brand-100: oklch(.32 .06 265);--brand-50: oklch(.26 .04 265);--ink-900: oklch(.96 .005 265);--ink-700: oklch(.84 .008 265);--ink-500: oklch(.65 .01 265);--ink-400: oklch(.55 .012 265);--ink-300: oklch(.4 .012 265);--line: oklch(.3 .012 265);--line-2: oklch(.26 .012 265);--bg: oklch(.17 .012 265);--surface: oklch(.21 .012 265);--surface-2: oklch(.245 .012 265);--green-600: oklch(.78 .15 155);--green-100: oklch(.3 .06 155);--amber-600: oklch(.82 .15 80);--amber-100: oklch(.32 .06 70);--red-600: oklch(.74 .16 25);--red-100: oklch(.32 .07 25);--blue-600: oklch(.74 .13 240);--blue-100: oklch(.3 .06 240);--violet-600: oklch(.74 .14 300);--violet-100: oklch(.32 .06 300);--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 4px 14px rgba(0,0,0,.45), 0 2px 4px rgba(0,0,0,.3);--shadow-lg: 0 12px 40px rgba(0,0,0,.55), 0 4px 10px rgba(0,0,0,.35);--topbar-bg: rgba(28, 30, 45, .78);--hero-grad-1: oklch(.28 .06 265);--hero-grad-2: oklch(.22 .02 265);color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--ink-900)}body{font-family:Plus Jakarta Sans,system-ui,-apple-system,Segoe UI,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100%}.mono{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--ink-300);border-radius:999px;border:2px solid var(--bg)}::-webkit-scrollbar-track{background:transparent}.app{display:grid;grid-template-columns:var(--sidebar-w, 248px) 1fr;min-height:100vh;transition:grid-template-columns .22s cubic-bezier(.4,0,.2,1)}.app.collapsed{--sidebar-w: 72px}.sidebar{background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:25}.main{display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:20;background:var(--topbar-bg);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}.content{padding:28px 36px 80px;max-width:1400px;width:100%}.footer{padding:18px 36px;border-top:1px solid var(--line);color:var(--ink-500);font-size:12.5px;display:flex;justify-content:space-between;align-items:center}.brand{display:flex;align-items:center;padding:18px 16px 14px}.brand-link{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;padding:4px;border-radius:10px;transition:background .12s;min-width:0}.brand-link:hover{background:var(--surface-2)}.brand-logo{width:36px;height:36px;object-fit:contain;border-radius:8px;background:#fff;flex-shrink:0}.brand-mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--brand-600),var(--brand-700));display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;letter-spacing:-.02em;box-shadow:var(--shadow-sm);flex-shrink:0}.brand-text{min-width:0;overflow:hidden;line-height:1.1}.brand-text .b1{font-weight:700;font-size:15px;letter-spacing:-.01em}.brand-text .b2{font-size:11px;color:var(--ink-500);font-weight:500}.sidebar-toggle{position:absolute;top:28px;right:-11px;width:22px;height:22px;border-radius:50%;border:1px solid var(--line);background:var(--surface);display:grid;place-items:center;color:var(--ink-500);cursor:pointer;z-index:2;box-shadow:var(--shadow-sm);transition:transform .22s;padding:0}.sidebar-toggle:hover{color:var(--brand-600);border-color:var(--brand-500)}.sidebar-toggle svg{width:13px;height:13px}.app.collapsed .sidebar-toggle svg{transform:rotate(180deg)}.app.collapsed .brand{justify-content:center;padding:18px 8px 14px}.app.collapsed .brand-link{padding:0;gap:0}.app.collapsed .brand-text,.app.collapsed .nav-label{display:none}.app.collapsed .nav-section{padding:14px 10px 8px}.app.collapsed .nav-item{justify-content:center;padding:10px 8px;position:relative}.app.collapsed .nav-item>span:not(.badge){display:none}.app.collapsed .nav-item .badge{position:absolute;top:4px;right:4px;margin:0;padding:0 5px;font-size:9.5px;min-width:16px;height:16px;display:grid;place-items:center;line-height:1}.app.collapsed .nav-item svg{width:19px;height:19px}.app.collapsed .nav-item:hover:after{content:attr(data-label);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%);background:var(--ink-900);color:var(--surface);padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;pointer-events:none;z-index:100;box-shadow:var(--shadow-md)}.app.collapsed .sidebar-user{padding:10px}.app.collapsed .user-chip{padding:4px;justify-content:center}.app.collapsed .user-chip .meta{display:none}.app.collapsed .user-chip>button{display:none}.nav-section{padding:8px 12px}.nav-label{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-400);padding:12px 10px 8px;font-weight:600}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;color:var(--ink-700);font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13.5px;border:none;background:transparent;width:100%;text-align:left}.nav-item:hover{background:var(--surface-2);color:var(--ink-900)}.nav-item.active{background:var(--brand-50);color:var(--brand-700)}.nav-item.active svg{color:var(--brand-600)}.nav-item svg{width:17px;height:17px;color:var(--ink-500);flex-shrink:0}.nav-item .badge{margin-left:auto;background:var(--brand-100);color:var(--brand-700);font-size:11px;padding:1px 7px;border-radius:999px;font-weight:600}.sidebar-user{margin-top:auto;padding:12px;border-top:1px solid var(--line)}.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px}.user-chip:hover{background:var(--surface-2)}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;font-size:12px;flex-shrink:0;letter-spacing:.01em}.avatar.lg{width:56px;height:56px;font-size:18px}.avatar.sm{width:26px;height:26px;font-size:10px}.user-chip .meta{min-width:0;flex:1}.user-chip .name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip .sub{font-size:11.5px;color:var(--ink-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-inner{display:flex;align-items:center;gap:12px;padding:14px 28px;min-height:64px;flex-wrap:wrap}.topbar-title{min-width:0;max-width:420px}.page-title{font-size:19px;font-weight:700;letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-sub{font-size:12.5px;color:var(--ink-500);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-spacer{flex:1;min-width:12px}.search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:7px 12px;flex:1 1 200px;min-width:180px;max-width:320px}.search input{border:0;background:transparent;outline:0;width:100%;font-size:13px}.search input::placeholder{color:var(--ink-400)}.search svg{width:15px;height:15px;color:var(--ink-500)}.icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);color:var(--ink-700);position:relative}.icon-btn:hover{background:var(--surface-2)}.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;background:var(--red-600);border-radius:50%;border:2px solid var(--surface)}.role-switch{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--line);padding:3px;border-radius:10px}.role-switch button{font-size:12px;padding:6px 10px;border-radius:7px;border:0;background:transparent;color:var(--ink-500);font-weight:500}.role-switch button.active{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-sm);font-weight:600}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-pad{padding:22px}.card-head{padding:18px 22px 0;display:flex;justify-content:space-between;align-items:start;gap:16px}.card-title{font-size:14.5px;font-weight:700;letter-spacing:-.005em}.card-sub{font-size:12.5px;color:var(--ink-500);margin-top:2px}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:9px;font-size:13px;font-weight:600;border:1px solid var(--line);background:var(--surface);color:var(--ink-900);transition:all .12s}.btn:hover{background:var(--surface-2)}.btn.primary{background:var(--brand-600);color:#fff;border-color:var(--brand-600)}.btn.primary:hover{background:var(--brand-700)}.btn.danger{background:var(--red-600);color:#fff;border-color:var(--red-600)}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover{background:var(--surface-2)}.btn.sm{padding:6px 10px;font-size:12px}.btn svg{width:15px;height:15px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:11.5px;font-weight:600;line-height:1.4}.badge.green{background:var(--green-100);color:var(--green-600)}.badge.amber{background:var(--amber-100);color:var(--amber-600)}.badge.red{background:var(--red-100);color:var(--red-600)}.badge.blue{background:var(--blue-100);color:var(--blue-600)}.badge.violet{background:var(--violet-100);color:var(--violet-600)}.badge.gray{background:var(--surface-2);color:var(--ink-700);border:1px solid var(--line)}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.input,.select,.textarea{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:9px;padding:9px 12px;font-size:13px;outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100)}.label{font-size:12px;font-weight:600;color:var(--ink-700);margin-bottom:6px;display:block}.textarea{min-height:80px;resize:vertical;font-family:inherit}.kpi{display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:12.5px;color:var(--ink-500);font-weight:500}.kpi-value{font-size:26px;font-weight:700;letter-spacing:-.02em}.kpi-delta{font-size:12px;color:var(--ink-500)}table.tbl{width:100%;border-collapse:collapse;font-size:13px}table.tbl th{text-align:left;font-weight:600;color:var(--ink-500);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;padding:11px 14px;border-bottom:1px solid var(--line);background:var(--surface-2)}table.tbl td{padding:13px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle}table.tbl tr:last-child td{border-bottom:0}table.tbl tr:hover td{background:var(--surface-2)}.progress{height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden}.progress>span{display:block;height:100%;background:var(--brand-600);border-radius:999px}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.row{display:flex;gap:12px;align-items:center}.col{display:flex;flex-direction:column;gap:12px}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a1480;z-index:40;display:grid;place-items:center;padding:40px;animation:fade .16s ease}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;overflow:hidden;animation:pop .18s cubic-bezier(.2,.8,.2,1)}.drawer{position:fixed;top:0;right:0;bottom:0;width:420px;background:var(--surface);box-shadow:var(--shadow-lg);z-index:50;animation:slide .2s cubic-bezier(.2,.8,.2,1);overflow-y:auto}.modal-head{padding:20px 22px 4px;display:flex;justify-content:space-between;align-items:start}.modal-body{padding:16px 22px 22px}.modal-foot{padding:14px 22px;border-top:1px solid var(--line);background:var(--surface-2);display:flex;justify-content:flex-end;gap:8px}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}@keyframes slide{0%{transform:translate(20px);opacity:0}to{transform:none;opacity:1}}@media(max-width:1180px){.role-switch{order:10;flex:1 1 100%;justify-content:flex-start;overflow-x:auto}.topbar-title{max-width:none;flex:1 1 auto}}@media(max-width:900px){.app{grid-template-columns:1fr}.app.collapsed{--sidebar-w: 0}.sidebar{position:fixed;left:-260px;top:0;bottom:0;width:248px;z-index:60;transition:left .2s}.sidebar.open{left:0;box-shadow:var(--shadow-lg)}.sidebar-toggle{display:none}.content{padding:20px 18px 60px}.topbar-inner{padding:12px 16px}.search{min-width:0;max-width:none;flex:1 1 100%;order:9}.grid.cols-4{grid-template-columns:repeat(2,1fr)}.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}.drawer{width:100%}.mobile-menu-toggle{display:grid!important}.sidebar-close-btn{display:inline-grid!important}}.mobile-menu-toggle,.sidebar-close-btn{display:none}.empty{padding:40px 24px;text-align:center;color:var(--ink-500);font-size:13px}.kanban{display:grid;grid-template-columns:repeat(5,minmax(220px,1fr));gap:14px;overflow-x:auto;padding-bottom:4px}.kanban-col{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:12px;min-height:200px}.kanban-col-head{display:flex;justify-content:space-between;align-items:center;padding:0 4px 10px}.kanban-col-title{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-700)}.kanban-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;transition:transform .1s,box-shadow .1s}.kanban-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card.dragging{opacity:.4}.kanban-col.drag-over{background:var(--brand-50);border-color:var(--brand-500)}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:7px;font-size:11.5px;font-weight:500;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-700)}.chip.match{background:var(--green-100);color:var(--green-600);border-color:transparent}.chip.miss{background:var(--red-100);color:var(--red-600);border-color:transparent;text-decoration:line-through;text-decoration-thickness:1px}.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-head{font-size:10.5px;letter-spacing:.06em;color:var(--ink-500);text-align:center;padding:6px 0;font-weight:600;text-transform:uppercase}.cal-cell{aspect-ratio:1.1 / 1;border-radius:8px;padding:6px;display:flex;flex-direction:column;justify-content:space-between;font-size:11.5px;border:1px solid var(--line-2);position:relative}.cal-cell.muted{opacity:.35}.cal-cell.present{background:var(--green-100);border-color:color-mix(in oklch,var(--green-600) 30%,transparent)}.cal-cell.absent{background:var(--red-100);border-color:color-mix(in oklch,var(--red-600) 30%,transparent)}.cal-cell.late{background:var(--amber-100);border-color:color-mix(in oklch,var(--amber-600) 30%,transparent)}.cal-cell.weekend{background:var(--surface-2)}.cal-cell.today{box-shadow:0 0 0 2px var(--brand-500)}.cal-num{font-weight:600;color:var(--ink-700)}.cal-tag{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-500)}.tree{display:flex;flex-direction:column;align-items:center;gap:0;padding:12px 0}.tree-node{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:10px 14px;min-width:180px;box-shadow:var(--shadow-sm);display:flex;gap:10px;align-items:center}.tree-node.self{border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100)}.tree-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}.tree-conn{width:2px;height:22px;background:var(--line)}.hero-grad{background:linear-gradient(135deg,var(--hero-grad-1),var(--hero-grad-2));border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 24px;display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap}.drop{border:2px dashed var(--line);border-radius:var(--radius-lg);padding:36px 24px;text-align:center;background:var(--surface-2);transition:all .15s;cursor:pointer}.drop:hover,.drop.active{border-color:var(--brand-500);background:var(--brand-50)}hr.sep{border:0;border-top:1px solid var(--line);margin:0}.link{color:var(--brand-600);font-weight:600;cursor:pointer}.link:hover{text-decoration:underline}
