@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;600;700&display=swap";:root{--primary:#000482;--primary-600:#00067a;--primary-700:#00065e;--primary-tint:oklch(96% .03 270);--primary-tint-2:oklch(92% .05 270);--on-primary:#fff;--present:#0e8f78;--present-bg:oklch(94% .04 175);--absent:#c4304b;--absent-bg:oklch(95% .035 20);--half:#b07712;--half-bg:oklch(96% .06 85);--custom:#4c2db8;--custom-bg:oklch(95% .04 295);--holiday:#b04415;--holiday-bg:oklch(95% .045 55);--offday:oklch(55% .01 75);--offday-bg:oklch(95% .005 75);--bg:oklch(98.5% .008 80);--bg-2:oklch(97% .01 75);--surface:#fff;--surface-2:oklch(99% .005 80);--surface-dark:oklch(18% .04 270);--surface-darker:oklch(13% .05 270);--ink:oklch(22% .025 270);--ink-2:oklch(40% .02 270);--muted:oklch(55% .01 80);--faint:oklch(70% .008 80);--on-dark:oklch(98% .005 80);--on-dark-2:oklch(78% .015 80);--border:oklch(92% .01 75);--border-strong:oklch(86% .012 75);--border-dark:oklch(28% .04 270);--r-xs:6px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--r-pill:999px;--sh-1:0 1px 0 oklch(92% .01 75/.6), 0 1px 2px oklch(20% .02 270/.04);--sh-2:0 1px 0 oklch(92% .01 75/.7), 0 6px 18px -8px oklch(20% .02 270/.08);--sh-3:0 1px 0 oklch(92% .01 75/.7), 0 12px 32px -10px oklch(20% .02 270/.12);--row-py:14px;--font-sans:"Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace}[data-theme=slate]{--bg:oklch(97% .005 250);--bg-2:oklch(95% .008 250);--border:oklch(90% .01 250);--border-strong:oklch(82% .012 250);--ink:oklch(20% .03 260);--ink-2:oklch(38% .02 260)}[data-theme=sand]{--bg:oklch(97.5% .015 80);--bg-2:oklch(95% .022 80);--primary:#1a3c6e;--primary-600:#14315a;--primary-700:#0e2543;--primary-tint:oklch(95% .025 240);--border:oklch(91% .018 80);--border-strong:oklch(85% .022 80)}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-sans);color:var(--ink);background:var(--bg);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}button{font:inherit;color:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}.tnum{font-variant-numeric:tabular-nums}.app{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.app[data-rail=icons]{grid-template-columns:76px 1fr}.sidebar{background:var(--surface-darker);color:var(--on-dark);border-right:1px solid var(--border-dark);flex-direction:column;gap:18px;height:100vh;padding:22px 14px 18px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar .brand{border-bottom:1px solid var(--border-dark);align-items:center;gap:10px;padding:6px 10px 14px;display:flex}.sidebar .brand-mark{background:var(--primary);color:#fff;letter-spacing:.5px;border-radius:10px;flex:none;place-items:center;width:36px;height:36px;font-size:13px;font-weight:800;display:grid;box-shadow:inset 0 0 0 1px oklch(100% 0 0/.06)}.sidebar .brand-name{letter-spacing:.2px;font-size:16px;font-weight:800}.sidebar .brand-sub{color:var(--on-dark-2);text-transform:uppercase;letter-spacing:1.2px;margin-top:2px;font-size:10.5px}.sidebar .nav{flex-direction:column;flex:1;gap:4px;display:flex}.sidebar .nav-label{text-transform:uppercase;letter-spacing:1.3px;color:oklch(60% .02 270);padding:14px 12px 6px;font-size:10.5px}.sidebar .nav-item{color:var(--on-dark-2);text-align:left;background:0 0;border:0;border-radius:10px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar .nav-item:hover{color:#fff;background:oklch(100% 0 0/.04)}.sidebar .nav-item.active{background:var(--primary);color:#fff;box-shadow:inset 0 0 0 1px oklch(100% 0 0/.08), 0 6px 14px -8px var(--primary)}.sidebar .nav-item .ic{opacity:.9;flex:none;width:18px;height:18px}.sidebar .nav-item .badge{color:#fff;background:oklch(100% 0 0/.12);border-radius:999px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:600}.sidebar .admin-card{border:1px solid var(--border-dark);background:oklch(100% 0 0/.04);border-radius:12px;align-items:center;gap:10px;padding:10px;display:flex}.sidebar .admin-card .who{line-height:1.15}.sidebar .admin-card .who .nm{color:#fff;font-size:13px;font-weight:600}.sidebar .admin-card .who .rl{color:var(--on-dark-2);font-size:11px}.app[data-rail=icons] .sidebar{padding:18px 10px}.app[data-rail=icons] .sidebar .brand-name,.app[data-rail=icons] .sidebar .brand-sub,.app[data-rail=icons] .sidebar .nav-label,.app[data-rail=icons] .sidebar .nav-item span:not(.ic-wrap),.app[data-rail=icons] .sidebar .admin-card .who,.app[data-rail=icons] .sidebar .nav-item .badge{display:none}.app[data-rail=icons] .sidebar .brand{justify-content:center;padding:6px 0 14px}.app[data-rail=icons] .sidebar .nav-item{justify-content:center;padding:10px 0}.app[data-rail=icons] .sidebar .admin-card{justify-content:center;padding:8px}.main{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border);background:var(--bg);z-index:5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:center;gap:16px;padding:18px 28px;display:flex;position:sticky;top:0}.topbar .title{letter-spacing:-.01em;font-size:20px;font-weight:700}.topbar .sub{color:var(--muted);margin-top:2px;font-size:13px}.topbar .spacer{flex:1}.topbar .search{background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:8px;width:320px;max-width:100%;padding:8px 14px;display:flex}.topbar .search input{background:0 0;border:0;outline:none;width:100%;font-size:13.5px}.topbar .search input::placeholder{color:var(--faint)}.content{width:100%;max-width:1400px;padding:24px 28px 80px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);box-shadow:var(--sh-1)}.card.flat{box-shadow:none}.card-dark{background:var(--surface-dark);color:var(--on-dark);border:1px solid var(--border-dark);border-radius:var(--r-2xl)}.stats{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat{padding:18px 18px 16px;position:relative;overflow:hidden}.stat .lbl{color:var(--muted);letter-spacing:.01em;align-items:center;gap:8px;font-size:12.5px;font-weight:500;display:flex}.stat .lbl .dot{border-radius:50%;width:8px;height:8px}.stat .num{letter-spacing:-.025em;margin-top:6px;font-size:38px;font-weight:700;line-height:1}.stat .sub{color:var(--ink-2);margin-top:6px;font-size:12px}.stat.featured{background:linear-gradient(180deg, var(--present-bg) 0%, oklch(97% .03 175) 100%);border:1px solid oklch(86% .05 175)}.stat.featured .lbl{color:var(--ink-2)}.stat.featured .num{color:var(--present)}.stat.featured .sub{color:oklch(42% .08 175)}.btn{background:var(--surface);color:var(--ink);border:1px solid var(--border-strong);border-radius:var(--r-pill);white-space:nowrap;align-items:center;gap:8px;padding:9px 14px;font-size:13.5px;font-weight:600;transition:background .15s,transform 50ms,border-color .15s;display:inline-flex}.btn:hover{background:var(--bg-2)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 6px 16px -8px var(--primary)}.btn-primary:hover{background:var(--primary-600)}.btn-dark{background:var(--surface-darker);color:var(--on-dark);border-color:var(--surface-darker)}.btn-dark:hover{background:oklch(22% .04 270)}.btn-ghost{color:var(--ink-2);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-2)}.btn-sm{padding:6px 10px;font-size:12.5px}.btn-icon{aspect-ratio:1;justify-content:center;padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.actions{align-items:center;gap:6px;display:flex}.act{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);color:var(--ink-2);align-items:center;gap:6px;padding:6px 10px;font-size:12.5px;font-weight:600;transition:all .15s;display:inline-flex}.act:hover{background:var(--bg-2);border-color:var(--border-strong);color:var(--ink)}.act .swatch{border-radius:50%;width:8px;height:8px}.act.active.present{background:var(--present-bg);color:var(--present);border-color:#0000}.act.active.absent{background:var(--absent-bg);color:var(--absent);border-color:#0000}.act.active.half{background:var(--half-bg);color:var(--half);border-color:#0000}.act.active.custom{background:var(--custom-bg);color:var(--custom);border-color:#0000}.pill{border-radius:var(--r-pill);letter-spacing:.01em;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.pill .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.pill.present{color:var(--present);background:var(--present-bg)}.pill.absent{color:var(--absent);background:var(--absent-bg)}.pill.half{color:var(--half);background:var(--half-bg)}.pill.custom{color:var(--custom);background:var(--custom-bg)}.pill.offday{color:var(--offday);background:var(--offday-bg)}.pill.holiday{color:var(--holiday);background:var(--holiday-bg)}.pill.unmarked{color:var(--muted);background:var(--bg-2);border:1px dashed var(--border-strong)}[data-pill=chip] .pill{text-transform:uppercase;letter-spacing:.06em;border-radius:6px;padding:3px 8px;font-size:11.5px;font-weight:600}[data-pill=chip] .pill .dot{display:none}[data-pill=dot] .pill{border:0;gap:8px;padding:0;background:0 0!important}[data-pill=dot] .pill .dot{width:8px;height:8px;display:inline-block}.avatar{color:#fff;letter-spacing:.02em;border-radius:50%;flex:none;place-items:center;width:36px;height:36px;font-size:12.5px;font-weight:700;display:inline-grid;box-shadow:inset 0 0 0 1px oklch(100% 0 0/.15)}.avatar.lg{border-radius:18px;width:64px;height:64px;font-size:22px}.avatar.xl{border-radius:22px;width:88px;height:88px;font-size:30px}.avatar.sm{width:28px;height:28px;font-size:10.5px}.att-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);flex-direction:column;display:flex;overflow:hidden}.att-row{padding:var(--row-py) 18px;border-top:1px solid var(--border);grid-template-columns:minmax(220px,1.4fr) 160px 140px auto;align-items:center;gap:18px;transition:background .12s;display:grid}.att-row:first-child{border-top:0}.att-row:hover{background:var(--bg-2)}.att-row.is-off{opacity:.6}.att-row .who{align-items:center;gap:12px;min-width:0;display:flex}.att-row .who .nm{font-size:14px;font-weight:600;line-height:1.2}.att-row .who .rl{color:var(--muted);margin-top:2px;font-size:12px}.att-row .shift{color:var(--ink-2);flex-direction:column;gap:2px;font-size:12.5px;display:flex}.att-row .shift .time{font-family:var(--font-mono);font-size:12px}.att-row .status-cell{flex-direction:column;gap:4px;display:flex}.att-row .marked-at{color:var(--faint);font-size:11px;font-family:var(--font-mono)}[data-row=compact]{--row-py:10px}[data-row=compact] .att-row .avatar{width:30px;height:30px;font-size:11px}[data-row=compact] .att-row .who .nm{font-size:13px}[data-row=compact] .att-row .who .rl{font-size:11px}[data-row=card] .att-list{background:0 0;border:0;gap:10px;display:grid}[data-row=card] .att-row{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);box-shadow:var(--sh-1);padding:14px 16px}[data-row=card] .att-row+.att-row{border-top:1px solid var(--border)}.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 14px;display:flex}.toolbar.dark{background:var(--surface-darker);color:var(--on-dark);border-color:var(--border-dark)}.toolbar.dark .seg{background:oklch(100% 0 0/.06);border-color:oklch(100% 0 0/.08)}.toolbar.dark .seg button{color:var(--on-dark-2)}.toolbar.dark .seg button.on{background:var(--primary);color:#fff}.seg{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-pill);gap:2px;padding:3px;display:inline-flex}.seg button{border-radius:var(--r-pill);color:var(--ink-2);background:0 0;border:0;padding:6px 12px;font-size:12.5px;font-weight:600}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--sh-1)}.tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:13.5px}.tbl thead th{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:left;border-bottom:1px solid var(--border);background:var(--surface-2);padding:12px 16px;font-size:11px;font-weight:600}.tbl tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:14px 16px}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover td{background:var(--bg-2)}.tog{background:var(--border-strong);border:0;border-radius:999px;flex:none;width:36px;height:20px;padding:0;transition:background .15s;position:relative}.tog:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .15s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px oklch(20% 0 0/.2)}.tog.on{background:var(--primary)}.tog.on:after{transform:translate(16px)}.daypat{gap:4px;display:inline-flex}.daypat .d{background:var(--bg-2);width:22px;height:22px;color:var(--muted);border:1px solid var(--border);border-radius:6px;place-items:center;font-size:10px;font-weight:700;display:grid}.daypat .d.on{background:var(--primary);color:#fff;border-color:var(--primary)}.daypat .d.off{background:var(--absent-bg);color:var(--absent);border-color:#0000}.scrim{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:50;background:oklch(15% .03 270/.4);place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--r-2xl);width:min(520px,100%);box-shadow:var(--sh-3);flex-direction:column;gap:14px;max-height:90vh;padding:22px;display:flex;overflow-y:auto}.modal h3{letter-spacing:-.01em;margin:0;font-size:18px;font-weight:700}.field{flex-direction:column;gap:6px;display:flex}.field label,.field .lbl{color:var(--muted);font-size:12px;font-weight:500}.field input,.field select,.field textarea{background:var(--bg-2);border:1px solid var(--border-strong);border-radius:10px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s,background .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);background:#fff}.toast-stack{z-index:60;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:22px;right:22px}.toast{background:var(--surface-darker);color:var(--on-dark);box-shadow:var(--sh-3);border:1px solid var(--border-dark);pointer-events:auto;border-radius:14px;align-items:center;gap:12px;min-width:280px;padding:12px 16px;animation:.25s ease-out toast-in;display:flex}.toast .tic{background:oklch(100% 0 0/.08);border-radius:10px;place-items:center;width:32px;height:32px;display:grid}.toast .ttitle{font-size:13px;font-weight:600}.toast .tsub{color:var(--on-dark-2);margin-top:1px;font-size:11.5px}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.heatmap{grid-template-columns:repeat(15,1fr);gap:4px;display:grid}.heatmap .cell{aspect-ratio:1;background:var(--bg-2);border-radius:5px}.heatmap .cell.present{background:var(--present)}.heatmap .cell.half{background:var(--half)}.heatmap .cell.absent{background:var(--absent)}.heatmap .cell.custom{background:var(--custom)}.heatmap .cell.offday{background:oklch(92% .005 80)}.heatmap .cell.holiday{background:var(--holiday)}.holiday-banner{border-radius:var(--r-xl);background:linear-gradient(135deg,oklch(96% .04 55) 0%,oklch(94% .06 35) 100%);border:1px solid oklch(86% .06 55);align-items:center;gap:14px;margin-top:18px;padding:14px 18px;display:flex}.holiday-banner .ic{width:44px;height:44px;color:var(--holiday);background:oklch(100% 0 0/.5);border-radius:14px;flex:none;place-items:center;font-size:22px;display:grid}.holiday-banner .nm{color:var(--ink);font-size:15.5px;font-weight:700}.holiday-banner .sub{color:var(--ink-2);margin-top:2px;font-size:12.5px}.bulkbar{background:var(--surface-darker);color:var(--on-dark);border:1px solid var(--border-dark);box-shadow:var(--sh-3);border-radius:999px;align-items:center;gap:10px;width:fit-content;min-width:480px;max-width:100%;margin:18px auto 0;padding:10px 12px 10px 18px;display:flex;position:sticky;bottom:16px}.bulkbar .ct{background:var(--primary);color:#fff;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.section-title{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:24px 4px 12px;font-size:13px;font-weight:600}.drawer-scrim{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:oklch(15% .03 270/.35);justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:var(--bg);border-left:1px solid var(--border);width:min(560px,100%);height:100vh;animation:.22s ease-out drawer-in;overflow-y:auto}@keyframes drawer-in{0%{opacity:.6;transform:translate(20px)}to{opacity:1;transform:none}}.drawer .head{background:var(--surface-darker);color:var(--on-dark);align-items:flex-start;gap:16px;padding:24px 24px 22px;display:flex;position:relative}.drawer .head .close{color:#fff;background:oklch(100% 0 0/.08);border:0;border-radius:10px;place-items:center;width:32px;height:32px;display:grid;position:absolute;top:14px;right:14px}.drawer .head .nm{letter-spacing:-.015em;font-size:22px;font-weight:700}.drawer .head .rl{color:var(--on-dark-2);margin-top:2px;font-size:13px}.drawer .head .meta{color:var(--on-dark-2);gap:14px;margin-top:10px;font-size:12.5px;display:flex}.drawer .body{flex-direction:column;gap:18px;padding:22px 24px 80px;display:flex}.menu-btn{display:none}@media (width<=880px){.app{grid-template-columns:1fr}.sidebar{height:auto;padding:8px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--border-dark);z-index:40;border-right:0;flex-direction:row;gap:4px;position:fixed;inset:auto 0 0}.sidebar .brand,.sidebar .nav-label,.sidebar .admin-card{display:none}.sidebar .nav{flex-direction:row;flex:1;justify-content:space-around}.sidebar .nav-item{text-align:center;border-radius:12px;flex-direction:column;gap:4px;padding:8px 10px;font-size:11px}.sidebar .nav-item .badge{display:none}.main{padding-bottom:80px}.topbar{gap:10px;padding:14px 16px}.topbar .search{flex:1;width:auto}.topbar .sub{display:none}.content{padding:16px 16px 100px}.stats{grid-template-columns:repeat(2,1fr);gap:10px}.stat .num{font-size:30px}.att-row{grid-template-columns:1fr;gap:10px}.att-row .shift{display:none}.att-row .actions{flex-wrap:wrap}.bulkbar{width:calc(100% - 32px);min-width:0}.menu-btn{border:1px solid var(--border);background:var(--surface);border-radius:12px;place-items:center;width:38px;height:38px;display:inline-grid}}
