:root{--bg:#fafaf7;--bg-elev:#fff;--bg-subtle:#f4f3ee;--border:#e8e6df;--border-strong:#d6d3c8;--text:#18181b;--text-muted:#6b6b66;--text-subtle:#9a9a92;--accent:#18181b;--accent-hover:#2a2a2d;--success:#16a34a;--success-bg:#dcfce7;--success-text:#15803d;--danger:#dc2626;--danger-bg:#fee2e2;--danger-text:#991b1b;--warn:#d97706;--warn-bg:#fef3c7;--warn-text:#92400e;--info-bg:#e0e7ff;--info-text:#3730a3;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;--r-pill:999px;--shadow-sm:0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 16px rgba(0,0,0,.06);--sidebar-w:240px}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg-elev);border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column;gap:4px;position:-webkit-sticky;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 22px;font-weight:700;font-size:15px;letter-spacing:-.2px}.sidebar-brand .logo{width:30px;height:30px;background:var(--accent);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;letter-spacing:.5px}.sidebar-section{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-subtle);padding:12px 8px 6px}.nav-link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-md);color:var(--text-muted);font-weight:500;font-size:14px;transition:background .12s,color .12s}.nav-link.active,.nav-link:hover{background:var(--bg-subtle);color:var(--text)}.nav-link.active{font-weight:600}.nav-link .icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:15px}.sidebar-bottom{margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px}.sidebar-user .name{font-size:13px;font-weight:600}.sidebar-user .role{font-size:12px;color:var(--text-subtle)}.main{flex:1 1;min-width:0}.page{max-width:1180px;margin:0 auto;padding:32px 36px 64px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{font-size:24px;font-weight:700;letter-spacing:-.4px}.page-subtitle{font-size:14px;color:var(--text-muted);margin-top:4px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;margin-bottom:16px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.card-title{font-size:15px;font-weight:600;color:var(--text)}.card-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}h1{font-size:24px;font-weight:700;letter-spacing:-.4px}h2{font-weight:600;color:var(--text);margin-bottom:14px}.btn,h2{font-size:14px}.btn{background:var(--accent);color:#fff;border:0;border-radius:var(--r-md);padding:9px 16px;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:background .12s,transform .06s}.btn:hover{background:var(--accent-hover)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-elev);color:var(--text);border:1px solid var(--border-strong)}.btn-secondary:hover{background:var(--bg-subtle)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:6px 12px;font-size:13px}.btn-ghost{background:transparent;color:var(--text-muted);border:0}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text)}input,select,textarea{background:var(--bg-elev);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:9px 12px;width:100%;font-size:14px;transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(24,24,27,.08)}input[type=checkbox]{width:auto}input[type=date],input[type=time]{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}label{display:block;font-size:12px;font-weight:500;color:var(--text-muted);margin:12px 0 6px}.field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}form{max-width:none}.checkbox-row{display:flex;align-items:center;gap:8px;margin-top:14px;font-size:14px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}td,th{text-align:left;padding:12px 10px;border-bottom:1px solid var(--border);vertical-align:middle}th{color:var(--text-subtle);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--bg-subtle)}td.numeric,th.numeric{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-subtle);color:var(--text);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.avatar.lg{width:40px;height:40px;font-size:14px}.person{display:flex;align-items:center;gap:10px}.person .meta{line-height:1.3;min-width:0}.person .name{font-weight:600;color:var(--text);font-size:14px}.person .sub{font-size:12px;color:var(--text-muted)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-pill);font-size:12px;font-weight:500}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge-on{background:var(--success-bg);color:var(--success-text)}.badge-off{background:var(--bg-subtle);color:var(--text-muted)}.badge-warn{background:var(--warn-bg);color:var(--warn-text)}.badge-info{background:var(--info-bg);color:var(--info-text)}.badge.no-dot:before{display:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:12px;gap:12px;margin-bottom:20px}.stat{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px}.stat-label{font-size:12px;color:var(--text-muted);font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:6px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.5px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.stat-trend{font-size:12px;margin-top:6px}.muted,.stat-trend{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.error{color:var(--danger)}.error,.success{font-size:13px;margin-top:8px}.success{color:var(--success-text)}.divider{height:1px;background:var(--border);margin:16px 0}.empty{padding:32px 16px;text-align:center;color:var(--text-subtle);font-size:14px}.toolbar{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.toolbar .field{flex:1 1;min-width:140px}.toolbar label{margin-top:0}.bar-row{display:grid;grid-template-columns:minmax(140px,200px) 1fr 70px;align-items:center;grid-gap:12px;gap:12px;padding:10px 0;font-size:13px}.bar-row+.bar-row{border-top:1px solid var(--border)}.bar-track{background:var(--bg-subtle);overflow:hidden;height:8px}.bar-fill,.bar-track{border-radius:var(--r-pill)}.bar-fill{background:var(--accent);height:100%}.bar-value{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600}.chip-group{display:inline-flex;gap:4px;flex-wrap:wrap}.chip{padding:4px 10px;border-radius:var(--r-pill);border:1px solid var(--border-strong);background:var(--bg-elev);color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s}.chip:hover{color:var(--text)}.chip.active,.chip:hover{border-color:var(--accent)}.chip.active{background:var(--accent);color:#fff}.day-group{display:flex;align-items:center;gap:10px;padding:14px 4px 8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-subtle);border-top:1px solid var(--border);margin-top:8px}.day-group:first-child{border-top:0;margin-top:0;padding-top:4px}.day-group .count{font-weight:500;text-transform:none;letter-spacing:0;color:var(--text-subtle)}@media (max-width:768px){.shell{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:row;overflow-x:auto;padding:10px;gap:4px}.sidebar-brand{padding:6px 10px}.sidebar-bottom,.sidebar-section{display:none}.nav-link{white-space:nowrap;padding:6px 12px}.page{padding:20px 16px 48px}}