:root{--brand: oklch(58% .18 252);--brand-2: oklch(64% .16 252);--brand-soft: oklch(96% .025 252);--brand-fg: #ffffff;--accent-emerald: oklch(64% .14 160);--accent-amber: oklch(75% .14 70);--accent-rose: oklch(66% .18 12);--accent-violet: oklch(60% .18 295);--ink-1: oklch(20% .01 250);--ink-2: oklch(38% .01 250);--ink-3: oklch(55% .008 250);--ink-4: oklch(72% .005 250);--bg-app: oklch(98.5% .004 250);--bg-surface: #ffffff;--bg-elev: #ffffff;--bg-sunken: oklch(96.5% .004 250);--bg-soft: oklch(95% .005 250);--line: oklch(91% .006 250);--line-soft: oklch(94% .005 250);--line-strong: oklch(82% .008 250);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 12px -2px rgba(15, 23, 42, .08), 0 2px 4px -1px rgba(15, 23, 42, .04);--shadow-lg: 0 16px 40px -8px rgba(15, 23, 42, .14), 0 4px 12px -2px rgba(15, 23, 42, .06);--shadow-xl: 0 24px 64px -12px rgba(15, 23, 42, .22);--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 22px;--radius-pill: 999px;--font-zh: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", system-ui, sans-serif;--font-en: "Plus Jakarta Sans", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Roboto Mono", ui-monospace, monospace}[data-theme=dark]{--brand: oklch(70% .16 252);--brand-2: oklch(76% .13 252);--brand-soft: oklch(28% .07 252);--brand-fg: #0b1020;--ink-1: oklch(96% .005 250);--ink-2: oklch(80% .008 250);--ink-3: oklch(64% .012 250);--ink-4: oklch(48% .012 250);--bg-app: oklch(16% .012 252);--bg-surface: oklch(20% .012 252);--bg-elev: oklch(23% .012 252);--bg-sunken: oklch(14% .012 252);--bg-soft: oklch(25% .012 252);--line: oklch(30% .012 252);--line-soft: oklch(26% .012 252);--line-strong: oklch(38% .012 252);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px -2px rgba(0, 0, 0, .4);--shadow-lg: 0 16px 40px -8px rgba(0, 0, 0, .5);--shadow-xl: 0 24px 64px -12px rgba(0, 0, 0, .6);--accent-emerald: oklch(72% .14 160);--accent-amber: oklch(80% .14 70);--accent-rose: oklch(72% .17 12);--accent-violet: oklch(70% .17 295)}html,body{margin:0;padding:0;font-family:var(--font-zh);font-feature-settings:"tnum";background:var(--bg-app)!important;color:var(--ink-1);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none;padding:0}a{color:inherit;text-decoration:none}::selection{background:color-mix(in oklch,var(--brand) 30%,transparent)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:color-mix(in oklch,var(--ink-3) 20%,transparent);border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:color-mix(in oklch,var(--ink-3) 35%,transparent);background-clip:padding-box;border:2px solid transparent}*::-webkit-scrollbar-track{background:transparent}.app{display:grid;grid-template-columns:auto 1fr;min-height:100vh}.sidebar{width:232px;background:var(--bg-surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .25s cubic-bezier(.3,.7,.2,1)}.sidebar.collapsed{width:68px}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid var(--line-soft)}.brand-mark{width:32px;height:32px;flex:0 0 32px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--accent-violet));display:grid;place-items:center;color:#fff;font-weight:800;font-family:var(--font-en);font-size:15px;letter-spacing:-.02em;box-shadow:0 4px 12px -2px color-mix(in oklch,var(--brand) 50%,transparent)}.brand-text{display:flex;flex-direction:column;line-height:1.1;overflow:hidden}.brand-text strong{font-size:15px;letter-spacing:.02em}.brand-text span{font-size:11px;color:var(--ink-3);font-family:var(--font-en);letter-spacing:.06em}.sidebar.collapsed .brand-text{display:none}.nav{padding:12px 10px;flex:1;overflow-y:auto}.nav-group-label{font-size:10.5px;color:var(--ink-4);letter-spacing:.12em;padding:14px 10px 6px;text-transform:uppercase;font-family:var(--font-en);font-weight:600}.sidebar.collapsed .nav-group-label{display:none}.nav-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:9px;color:var(--ink-2);font-size:13.5px;font-weight:500;margin-bottom:2px;cursor:pointer;position:relative;white-space:nowrap;transition:background .12s,color .12s}.nav-item:hover{background:var(--bg-sunken);color:var(--ink-1)}.nav-item.active{background:var(--brand-soft);color:var(--brand);font-weight:600}.nav-item .ico{width:18px;height:18px;flex:0 0 18px;opacity:.85}.nav-item .ico svg{width:18px;height:18px}.nav-item.active .ico{opacity:1}.nav-item .badge{margin-left:auto;min-width:18px;height:18px;padding:0 6px;border-radius:999px;font-size:10.5px;font-weight:700;display:grid;place-items:center;background:var(--accent-rose);color:#fff}.sidebar.collapsed .nav-item{justify-content:center;padding:9px}.sidebar.collapsed .nav-item .label,.sidebar.collapsed .nav-item .badge{display:none}.sidebar-footer{border-top:1px solid var(--line-soft);padding:12px;display:flex;align-items:center;gap:10px;cursor:pointer}.sidebar-footer:hover{background:var(--bg-sunken)}.sidebar-footer .ava{width:32px;height:32px;border-radius:999px;background:linear-gradient(135deg,var(--accent-emerald),var(--brand));color:#fff;font-weight:700;display:grid;place-items:center;font-size:12px;flex:0 0 32px}.sidebar-footer .meta{display:flex;flex-direction:column;line-height:1.2;flex:1;overflow:hidden}.sidebar-footer .meta strong{font-size:13px}.sidebar-footer .meta span{font-size:11px;color:var(--ink-3)}.sidebar.collapsed .sidebar-footer .meta,.sidebar.collapsed .sidebar-footer .caret{display:none}.sidebar.collapsed .sidebar-footer{justify-content:center}.main{display:flex;flex-direction:column;min-width:0;min-height:100vh}.topbar{height:60px;display:flex;align-items:center;gap:16px;padding:0 22px;background:color-mix(in oklch,var(--bg-app) 80%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}.icon-btn{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:var(--ink-2);position:relative}.icon-btn:hover{background:var(--bg-sunken);color:var(--ink-1)}.icon-btn .dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:999px;background:var(--accent-rose);border:2px solid var(--bg-app);box-sizing:content-box}.crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3)}.crumb strong{color:var(--ink-1);font-weight:600}.search{flex:1;max-width:440px;margin-left:auto;position:relative}.search input{width:100%;height:36px;border-radius:9px;background:var(--bg-sunken);border:1px solid transparent;padding:0 12px 0 36px;font-size:13px;color:var(--ink-1);transition:all .15s}.search input::placeholder{color:var(--ink-4)}.search input:focus{outline:none;background:var(--bg-surface);border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in oklch,var(--brand) 20%,transparent)}.search .search-ico{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-3);width:16px;height:16px}.search .kbd{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:var(--font-en);font-size:10.5px;color:var(--ink-3);background:var(--bg-surface);border:1px solid var(--line);border-radius:5px;padding:1px 6px}.role-switch{display:flex;align-items:center;background:var(--bg-sunken);border-radius:9px;padding:3px;gap:2px}.role-switch button{font-size:12px;font-weight:600;padding:6px 12px;border-radius:7px;color:var(--ink-3);display:flex;align-items:center;gap:6px;transition:all .18s}.role-switch button.on{background:var(--bg-surface);color:var(--ink-1);box-shadow:var(--shadow-sm)}.role-switch button .dot{width:6px;height:6px;border-radius:999px;background:currentColor;opacity:.7}.role-switch button.on.role-hr .dot{color:var(--brand);opacity:1}.role-switch button.on.role-manager .dot{color:var(--accent-emerald);opacity:1}.role-switch button.on.role-admin .dot{color:var(--accent-violet);opacity:1}.content{padding:24px 28px 64px;flex:1;min-width:0}.card{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-head{display:flex;align-items:center;gap:10px;padding:16px 18px 0}.card-head h3{margin:0;font-size:14px;font-weight:700;letter-spacing:.01em}.card-head .sub{font-size:12px;color:var(--ink-3)}.card-head .more{margin-left:auto}.section-title{display:flex;align-items:baseline;gap:12px;margin:8px 0 16px}.section-title h1{font-size:22px;margin:0;font-weight:700;letter-spacing:-.01em}.section-title .sub{font-size:13px;color:var(--ink-3)}.section-title .actions{margin-left:auto;display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 14px;border-radius:9px;font-size:13px;font-weight:600;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--brand);color:var(--brand-fg);box-shadow:0 1px 2px #0000000f,inset 0 1px #ffffff2e}.btn-primary:hover{background:color-mix(in oklch,var(--brand) 92%,black)}.btn-ghost{background:var(--bg-surface);border:1px solid var(--line-strong);color:var(--ink-1)}.btn-ghost:hover{background:var(--bg-sunken)}.btn-soft{background:var(--bg-sunken);color:var(--ink-1)}.btn-soft:hover{background:var(--bg-soft)}.btn-sm{height:30px;padding:0 10px;font-size:12px;border-radius:7px}.chip{display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-sunken);color:var(--ink-2);white-space:nowrap}.chip.dot:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}.chip.success{background:color-mix(in oklch,var(--accent-emerald) 18%,transparent);color:color-mix(in oklch,var(--accent-emerald) 70%,black)}.chip.warn{background:color-mix(in oklch,var(--accent-amber) 22%,transparent);color:color-mix(in oklch,var(--accent-amber) 60%,black)}.chip.danger{background:color-mix(in oklch,var(--accent-rose) 18%,transparent);color:color-mix(in oklch,var(--accent-rose) 70%,black)}.chip.info{background:color-mix(in oklch,var(--brand) 14%,transparent);color:color-mix(in oklch,var(--brand) 75%,black)}.chip.violet{background:color-mix(in oklch,var(--accent-violet) 16%,transparent);color:color-mix(in oklch,var(--accent-violet) 70%,black)}[data-theme=dark] .chip.success{color:#6fdea7}[data-theme=dark] .chip.warn{color:#ffc580;color:oklch(86% .14 70)}[data-theme=dark] .chip.danger{color:#ff9eaa;color:oklch(80% .15 12)}[data-theme=dark] .chip.info{color:#98c8ff;color:oklch(82% .12 252)}[data-theme=dark] .chip.violet{color:#c8b7ff;color:oklch(82% .14 295)}.ava{border-radius:999px;display:inline-grid;place-items:center;font-weight:700;color:#fff;font-size:12px;flex:0 0 auto}.ava.sm{width:24px;height:24px;font-size:10px}.ava.md{width:32px;height:32px}.ava.lg{width:44px;height:44px;font-size:15px}.ava-stack{display:inline-flex}.ava-stack .ava{margin-left:-8px;border:2px solid var(--bg-surface)}.ava-stack .ava:first-child{margin-left:0}.hero{display:grid;grid-template-columns:1fr auto;gap:20px;background:linear-gradient(125deg,color-mix(in oklch,var(--brand) 12%,var(--bg-surface)) 0%,var(--bg-surface) 55%,color-mix(in oklch,var(--accent-violet) 8%,var(--bg-surface)) 100%);border:1px solid var(--line);border-radius:var(--radius-xl);padding:24px 28px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;border-radius:999px;background:radial-gradient(circle,color-mix(in oklch,var(--brand) 18%,transparent),transparent 65%);pointer-events:none}.hero-left h1{font-size:26px;margin:0 0 6px;font-weight:700;letter-spacing:-.01em}.hero-left .sub{color:var(--ink-2);font-size:13.5px;max-width:56ch}.hero-meta{display:flex;gap:18px;margin-top:16px;flex-wrap:wrap}.hero-meta .meta-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2)}.hero-meta .meta-item strong{color:var(--ink-1);font-weight:600}.hero-meta .meta-item .ico{width:14px;height:14px;color:var(--brand)}.weather-card{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 18px;display:flex;align-items:center;gap:14px;min-width:200px}.weather-card .temp{font-size:28px;font-weight:700;font-family:var(--font-en);letter-spacing:-.02em}.weather-card .info{display:flex;flex-direction:column;line-height:1.3}.weather-card .info strong{font-size:13px}.weather-card .info span{font-size:11.5px;color:var(--ink-3)}.weather-card .icon{width:40px;height:40px;display:grid;place-items:center;background:linear-gradient(135deg,#eca851,#e77b60);border-radius:12px;color:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:20px}.kpi{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 18px;position:relative;overflow:hidden}.kpi .label{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-3);font-weight:500}.kpi .label .ico{width:22px;height:22px;border-radius:7px;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand)}.kpi .value{font-family:var(--font-en);font-size:28px;font-weight:700;margin:8px 0 4px;letter-spacing:-.02em}.kpi .delta{font-size:11.5px;display:inline-flex;align-items:center;gap:4px;color:var(--accent-emerald);font-weight:600}.kpi .delta.down{color:var(--accent-rose)}.kpi .spark{position:absolute;right:12px;bottom:12px;width:84px;height:28px;opacity:.85}.kpi.violet .label .ico{background:color-mix(in oklch,var(--accent-violet) 16%,transparent);color:var(--accent-violet)}.kpi.emerald .label .ico{background:color-mix(in oklch,var(--accent-emerald) 16%,transparent);color:var(--accent-emerald)}.kpi.amber .label .ico{background:color-mix(in oklch,var(--accent-amber) 22%,transparent);color:color-mix(in oklch,var(--accent-amber) 60%,black)}[data-theme=dark] .kpi.amber .label .ico{color:#ffc075;color:oklch(85% .14 70)}.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;margin-top:20px}.dash-col{display:flex;flex-direction:column;gap:18px;min-width:0}.todo-tabs{display:flex;gap:4px;padding:14px 18px 0}.todo-tab{padding:8px 12px;border-radius:8px;font-size:12.5px;color:var(--ink-3);font-weight:600;display:flex;align-items:center;gap:6px}.todo-tab:hover{background:var(--bg-sunken);color:var(--ink-1)}.todo-tab.on{background:var(--brand-soft);color:var(--brand)}.todo-tab .count{background:color-mix(in oklch,currentColor 15%,transparent);border-radius:999px;padding:1px 6px;font-size:10.5px;font-family:var(--font-en)}.todo-list{padding:8px 8px 12px}.todo-row{display:grid;grid-template-columns:28px 1fr auto;gap:12px;padding:12px 10px;border-radius:10px;align-items:center;cursor:pointer}.todo-row:hover{background:var(--bg-sunken)}.todo-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:#fff;background:var(--brand)}.todo-icon.amber{background:linear-gradient(135deg,#e9a03e,#e4762c)}.todo-icon.violet{background:linear-gradient(135deg,var(--accent-violet),oklch(54% .16 275))}.todo-icon.emerald{background:linear-gradient(135deg,var(--accent-emerald),oklch(56% .13 175))}.todo-icon.rose{background:linear-gradient(135deg,var(--accent-rose),oklch(58% .18 25))}.todo-icon.blue{background:linear-gradient(135deg,var(--brand),var(--brand-2))}.todo-body{min-width:0}.todo-body .title{font-size:13.5px;font-weight:600;color:var(--ink-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.todo-body .meta{font-size:12px;color:var(--ink-3);margin-top:2px;display:flex;align-items:center;gap:8px}.todo-body .meta .sep{width:3px;height:3px;border-radius:999px;background:var(--ink-4)}.todo-actions{display:flex;gap:6px;align-items:center}.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:14px 18px 18px}.quick-tile{background:var(--bg-sunken);border-radius:12px;padding:14px 12px;text-align:left;display:flex;flex-direction:column;gap:10px;transition:all .15s;border:1px solid transparent}.quick-tile:hover{background:var(--bg-surface);border-color:var(--line-strong);transform:translateY(-1px);box-shadow:var(--shadow-md)}.quick-tile .ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--brand);color:#fff}.quick-tile.violet .ico{background:var(--accent-violet)}.quick-tile.emerald .ico{background:var(--accent-emerald)}.quick-tile.amber .ico{background:#e58212}.quick-tile.rose .ico{background:var(--accent-rose)}.quick-tile.cyan .ico{background:#00a6ad;background:oklch(66% .13 200)}.quick-tile .label{font-size:13px;font-weight:600}.quick-tile .desc{font-size:11px;color:var(--ink-3)}.feed{padding:8px 18px 18px}.feed-row{display:grid;grid-template-columns:32px 1fr auto;gap:12px;padding:10px 0;align-items:flex-start;border-bottom:1px solid var(--line-soft)}.feed-row:last-child{border-bottom:none}.feed-row .body{font-size:13px;color:var(--ink-2);line-height:1.55}.feed-row .body strong{color:var(--ink-1);font-weight:600}.feed-row .time{font-size:11.5px;color:var(--ink-4);font-family:var(--font-en);white-space:nowrap}.upcoming{padding:8px 8px 14px}.upcoming-row{display:grid;grid-template-columns:46px 1fr auto;gap:12px;padding:10px;border-radius:10px;align-items:center}.upcoming-row:hover{background:var(--bg-sunken)}.upcoming-date{display:flex;flex-direction:column;align-items:center;background:var(--bg-sunken);border-radius:9px;padding:6px 0;line-height:1}.upcoming-date .month{font-size:10px;color:var(--ink-3);font-weight:600;font-family:var(--font-en);text-transform:uppercase;letter-spacing:.08em}.upcoming-date .day{font-size:17px;font-weight:700;margin-top:4px;font-family:var(--font-en)}.upcoming-body .title{font-size:13px;font-weight:600}.upcoming-body .meta{font-size:11.5px;color:var(--ink-3);margin-top:2px}.notif-list{padding:6px 10px 12px}.notif{padding:10px;display:grid;grid-template-columns:8px 1fr;gap:10px;align-items:start;border-radius:8px}.notif .marker{width:8px;height:8px;border-radius:999px;background:var(--brand);margin-top:6px}.notif.read .marker{background:var(--line-strong)}.notif .title{font-size:13px;font-weight:600;line-height:1.4}.notif .desc{font-size:12px;color:var(--ink-3);margin-top:2px}.notif .time{font-size:11px;color:var(--ink-4);margin-top:4px;font-family:var(--font-en)}.clock-card{padding:18px;display:flex;flex-direction:column;gap:16px}.clock-time{font-family:var(--font-en);font-size:40px;font-weight:600;letter-spacing:-.02em;line-height:1}.clock-date{font-size:12.5px;color:var(--ink-3);margin-top:4px}.clock-state{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-sunken);border-radius:12px}.clock-state .icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:color-mix(in oklch,var(--accent-emerald) 18%,transparent);color:var(--accent-emerald)}.clock-state .info{display:flex;flex-direction:column;line-height:1.3}.clock-state .info strong{font-size:13px}.clock-state .info span{font-size:11.5px;color:var(--ink-3);font-family:var(--font-en)}.clock-state .info span.tag{font-family:var(--font-zh);display:inline-block;padding:1px 6px;background:color-mix(in oklch,var(--accent-emerald) 20%,transparent);color:color-mix(in oklch,var(--accent-emerald) 80%,black);border-radius:4px;font-weight:600;margin-top:3px;align-self:flex-start}[data-theme=dark] .clock-state .info span.tag{color:#6fdea7}.clock-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.clock-row .clock-state{background:var(--bg-sunken)}.clock-btn{width:100%;height:44px;background:var(--brand);color:var(--brand-fg);border-radius:12px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px -4px color-mix(in oklch,var(--brand) 50%,transparent)}.clock-btn:hover{background:color-mix(in oklch,var(--brand) 92%,black)}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.table thead th{text-align:left;font-size:11.5px;font-weight:600;color:var(--ink-3);padding:12px 14px;border-bottom:1px solid var(--line);background:var(--bg-surface);white-space:nowrap;letter-spacing:.03em}.table tbody td{padding:12px 14px;border-bottom:1px solid var(--line-soft);color:var(--ink-1);vertical-align:middle}.table tbody tr:hover td{background:var(--bg-sunken)}.table tbody tr.selected td{background:var(--brand-soft)}.table .num{font-family:var(--font-en)}.table input[type=checkbox]{width:14px;height:14px;accent-color:var(--brand)}.id-cell{display:flex;align-items:center;gap:10px}.id-cell .nm{font-weight:600}.id-cell .em{font-size:11.5px;color:var(--ink-3);font-family:var(--font-en)}.filters{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}.tabs{display:flex;gap:2px;background:var(--bg-sunken);padding:3px;border-radius:8px}.tabs button{padding:6px 12px;border-radius:6px;font-size:12.5px;font-weight:600;color:var(--ink-3)}.tabs button.on{background:var(--bg-surface);color:var(--ink-1);box-shadow:var(--shadow-sm)}.tabs button .count{font-family:var(--font-en);margin-left:4px;color:var(--ink-4);font-weight:500}.field{display:flex;align-items:center;gap:6px;height:34px;padding:0 10px;background:var(--bg-surface);border:1px solid var(--line-strong);border-radius:8px;font-size:12.5px;color:var(--ink-2);cursor:pointer;white-space:nowrap}.field:hover{border-color:var(--brand)}.scrim{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;animation:fadein .18s ease}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes slideR{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes popup{0%{transform:translateY(12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;width:640px;max-width:92vw;background:var(--bg-surface);z-index:110;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:slideR .28s cubic-bezier(.3,.7,.2,1)}.drawer-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:14px}.drawer-head .ava{width:56px;height:56px;font-size:18px}.drawer-head h2{font-size:18px;margin:0;font-weight:700;letter-spacing:-.01em}.drawer-head .meta{font-size:12.5px;color:var(--ink-3);margin-top:4px;display:flex;align-items:center;gap:8px}.drawer-head .close{margin-left:auto}.drawer-tabs{display:flex;gap:2px;padding:0 22px;border-bottom:1px solid var(--line)}.drawer-tabs button{padding:12px;font-size:13px;font-weight:600;color:var(--ink-3);position:relative;border-bottom:2px solid transparent;margin-bottom:-1px}.drawer-tabs button.on{color:var(--brand);border-bottom-color:var(--brand)}.drawer-body{flex:1;overflow-y:auto;padding:22px}.drawer-foot{display:flex;align-items:center;gap:8px;padding:14px 22px;border-top:1px solid var(--line);background:var(--bg-surface)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}.form-grid .full{grid-column:1 / -1}.form-row label{display:block;font-size:11.5px;font-weight:600;color:var(--ink-3);margin-bottom:6px;letter-spacing:.03em}.form-row input,.form-row select,.form-row textarea{width:100%;height:38px;padding:0 12px;border:1px solid var(--line-strong);border-radius:9px;background:var(--bg-surface);font-size:13px;color:var(--ink-1);transition:all .15s}.form-row textarea{height:auto;padding:10px 12px;min-height:80px;resize:vertical}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in oklch,var(--brand) 18%,transparent)}.fieldset-card{background:var(--bg-sunken);border-radius:12px;padding:16px;margin-bottom:16px}.fieldset-card h4{margin:0 0 14px;font-size:13px;font-weight:700}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:720px;max-width:94vw;max-height:90vh;background:var(--bg-surface);border-radius:var(--radius-xl);z-index:110;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:popup .22s cubic-bezier(.3,.7,.2,1);overflow:hidden}.modal-head{padding:18px 22px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}.modal-body{flex:1;overflow-y:auto;padding:22px}.modal-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;align-items:center;gap:8px}.payslip-hero{background:linear-gradient(120deg,color-mix(in oklch,var(--brand) 16%,var(--bg-surface)),color-mix(in oklch,var(--accent-violet) 10%,var(--bg-surface)));border-radius:var(--radius-lg);padding:22px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}.payslip-hero .label{font-size:12px;color:var(--ink-2);letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-en);font-weight:600}.payslip-hero .amount{font-family:var(--font-en);font-size:36px;font-weight:700;letter-spacing:-.02em;margin-top:4px}.payslip-hero .meta{font-size:12.5px;color:var(--ink-2);margin-top:8px}.payslip-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}.payslip-grid h4{font-size:12px;text-transform:uppercase;font-family:var(--font-en);letter-spacing:.06em;color:var(--ink-3);font-weight:700;margin:0 0 10px}.kv{display:flex;align-items:center;padding:8px 0;border-bottom:1px dashed var(--line);font-size:13px}.kv:last-child{border-bottom:none}.kv .k{color:var(--ink-2)}.kv .v{margin-left:auto;font-family:var(--font-en);font-weight:600}.kv.total{padding-top:12px;border-top:1px solid var(--line);margin-top:6px}.kv.total .v{font-size:15px}.timeline{padding:18px}.t-step{display:grid;grid-template-columns:28px 1fr;gap:14px;position:relative}.t-step:before{content:"";position:absolute;left:13.5px;top:28px;bottom:-10px;width:1.5px;background:var(--line)}.t-step:last-child:before{display:none}.t-step .marker{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:var(--bg-sunken);color:var(--ink-3);font-size:12px;font-weight:700;border:2px solid var(--bg-surface);box-shadow:0 0 0 1.5px var(--line)}.t-step.done .marker{background:var(--accent-emerald);color:#fff;box-shadow:0 0 0 1.5px var(--accent-emerald)}.t-step.current .marker{background:var(--brand);color:#fff;box-shadow:0 0 0 1.5px var(--brand)}.t-step .body{padding-bottom:18px}.t-step .nm{font-size:13.5px;font-weight:600}.t-step .role{font-size:12px;color:var(--ink-3)}.t-step .note{font-size:12.5px;color:var(--ink-2);margin-top:6px;padding:8px 10px;background:var(--bg-sunken);border-radius:8px;border-left:3px solid var(--line-strong)}.t-step.current .note{border-left-color:var(--brand)}.t-step.done .note{border-left-color:var(--accent-emerald)}.t-step .time{font-size:11.5px;color:var(--ink-4);font-family:var(--font-en);margin-top:4px}.empty{padding:60px 20px;text-align:center;color:var(--ink-3)}.empty .ico{width:56px;height:56px;border-radius:16px;background:var(--bg-sunken);margin:0 auto 12px;display:grid;place-items:center;color:var(--ink-3)}.empty h4{color:var(--ink-1);margin:4px 0;font-size:15px}.org-card{background:var(--bg-surface);border:1px solid var(--line);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:10px}.org-card .meta{display:flex;flex-direction:column;line-height:1.3}.org-card .meta strong{font-size:13px}.org-card .meta span{font-size:11.5px;color:var(--ink-3)}.bar-chart{display:flex;align-items:flex-end;gap:10px;height:160px;padding:16px 18px}.bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.bar .col{width:100%;max-width:26px;background:linear-gradient(180deg,var(--brand),var(--brand-2));border-radius:5px 5px 0 0;min-height:4px}.bar .col.alt{background:linear-gradient(180deg,var(--accent-violet),oklch(54% .16 275))}.bar .lbl{font-size:10.5px;color:var(--ink-3)}.donut{width:140px;height:140px;flex:0 0 140px;position:relative}.donut .center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}.donut .center strong{font-family:var(--font-en);font-size:22px;font-weight:700;display:block}.donut .center span{font-size:11px;color:var(--ink-3);display:block;margin-top:2px}.legend{display:flex;flex-direction:column;gap:8px;padding-left:8px}.legend .row{display:flex;align-items:center;gap:8px;font-size:12.5px}.legend .dot{width:10px;height:10px;border-radius:999px}.legend .val{margin-left:auto;font-family:var(--font-en);font-weight:600;color:var(--ink-1)}.pagination{display:flex;align-items:center;gap:6px;padding:14px 18px;border-top:1px solid var(--line-soft)}.pagination .info{font-size:12px;color:var(--ink-3)}.pagination .pages{margin-left:auto;display:flex;gap:4px;align-items:center}.page-btn{min-width:30px;height:30px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--ink-2);font-family:var(--font-en);display:grid;place-items:center;padding:0 8px}.page-btn:hover{background:var(--bg-sunken)}.page-btn.on{background:var(--brand);color:var(--brand-fg)}.org-tree{padding:20px;display:flex;flex-direction:column;gap:12px}.org-tree .level{display:flex;gap:14px;flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.flex{display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.muted{color:var(--ink-3)}.nav-toggle{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:var(--ink-2)}.nav-toggle:hover{background:var(--bg-sunken);color:var(--ink-1)}@media(max-width:1200px){.dash-grid{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}}*{box-sizing:border-box}body{margin:0;font-family:PingFang TC,Microsoft JhengHei,Arial,sans-serif}
