:root{--bg: oklch(.985 .005 250);--surface: #ffffff;--surface-2: oklch(.975 .005 250);--surface-3: oklch(.96 .005 250);--border: oklch(.92 .006 250);--border-strong: oklch(.86 .008 250);--text: oklch(.22 .02 260);--text-muted: oklch(.52 .015 260);--text-faint: oklch(.68 .01 260);--accent: oklch(.52 .17 268);--accent-hover: oklch(.46 .18 268);--accent-soft: oklch(.95 .04 268);--accent-fg: #ffffff;--warm: oklch(.78 .15 70);--warm-soft: oklch(.96 .04 70);--success: oklch(.62 .13 155);--success-soft: oklch(.95 .04 155);--warning: oklch(.72 .15 75);--warning-soft: oklch(.96 .05 75);--danger: oklch(.58 .2 25);--danger-soft: oklch(.96 .04 25);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 0 rgba(15, 23, 42, .04), 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 1px 0 rgba(15, 23, 42, .04), 0 8px 24px -12px rgba(15, 23, 42, .12);--shadow-lg: 0 1px 0 rgba(15, 23, 42, .04), 0 24px 48px -16px rgba(15, 23, 42, .18);--sidebar-w: 248px;--topbar-h: 64px;--row-h: 48px;--pad: 24px;--font-ui: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", ui-monospace, Menlo, monospace}[data-theme=dark]{--bg: oklch(.16 .012 260);--surface: oklch(.2 .012 260);--surface-2: oklch(.22 .014 260);--surface-3: oklch(.25 .014 260);--border: oklch(.3 .012 260);--border-strong: oklch(.36 .014 260);--text: oklch(.95 .005 260);--text-muted: oklch(.72 .012 260);--text-faint: oklch(.55 .012 260);--accent: oklch(.72 .16 268);--accent-hover: oklch(.78 .16 268);--accent-soft: oklch(.3 .1 268);--accent-fg: oklch(.18 .012 260);--warm-soft: oklch(.32 .08 70);--success-soft: oklch(.3 .07 155);--warning-soft: oklch(.32 .08 75);--danger-soft: oklch(.32 .1 25);--shadow-sm: 0 1px 0 rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 1px 0 rgba(0, 0, 0, .3), 0 8px 24px -12px rgba(0, 0, 0, .5);--shadow-lg: 0 1px 0 rgba(0, 0, 0, .3), 0 24px 48px -16px rgba(0, 0, 0, .6)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-feature-settings:"ss01","cv11";-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}a{color:inherit;text-decoration:none}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar-scrim,.mobile-topbar,.mobile-sidebar-close{display:none}.sidebar{border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid var(--border);height:var(--topbar-h)}.brand-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:var(--accent-fg);display:grid;place-items:center;font-weight:800;font-size:14px;letter-spacing:-.02em;box-shadow:inset 0 1px #fff3,0 4px 10px -4px var(--accent)}.brand-name{font-weight:700;letter-spacing:-.01em;font-size:15px}.brand-sub{font-size:11px;color:var(--text-muted);margin-top:-2px}.nav{display:flex;flex-direction:column;padding:12px;gap:2px;flex:1}.nav-section-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--text-faint);padding:14px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--text-muted);font-weight:500;font-size:13.5px;cursor:pointer;transition:background .12s;width:100%;text-align:left}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}[data-theme=dark] .nav-item.active{color:var(--text);background:var(--accent-soft)}.nav-item .icon{width:18px;height:18px;flex-shrink:0}.nav-item .badge{margin-left:auto;background:var(--surface-3);color:var(--text-muted);font-size:11px;font-weight:600;padding:1px 7px;border-radius:999px;font-variant-numeric:tabular-nums}.nav-item.active .badge{background:var(--accent);color:var(--accent-fg)}.user-card{margin:12px;padding:10px;border-radius:10px;border:1px solid var(--border);display:flex;align-items:center;gap:10px;position:relative;background:var(--surface);cursor:pointer;text-align:left}.user-card .avatar{width:32px;height:32px}.user-card .meta{flex:1;min-width:0;display:grid}.user-card .name,.user-card .role{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-card .name{font-weight:600;font-size:13px;line-height:1.2}.user-card .role{font-size:11.5px;color:var(--text-muted)}.user-card .more{flex:0 0 auto;color:var(--text-faint);padding:4px;border-radius:6px;cursor:pointer}.user-card .more:hover{background:var(--surface-2);color:var(--text)}.user-card.open{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.account-menu{position:absolute;left:0;right:0;bottom:calc(100% + 8px);z-index:20;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:6px}.account-menu button{width:100%;min-height:36px;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--text-muted);text-align:left}.account-menu button:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.account-menu button.danger{color:var(--danger)}.account-menu button.danger:hover{background:var(--danger-soft)}.account-menu button:disabled{cursor:not-allowed;opacity:.45}.account-menu-section{display:grid;gap:8px;padding:8px 10px 10px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:4px 0}.account-menu-label{color:var(--text-faint);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.account-theme-toggle{display:grid;grid-template-columns:1fr 1fr;gap:6px}.account-theme-toggle button{justify-content:center;min-height:32px;padding:6px 10px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted)}.account-theme-toggle button.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.main{min-width:0;display:flex;flex-direction:column}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--pad);gap:16px;background:color-mix(in srgb,var(--bg) 80%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.crumbs{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-faint)}.crumbs .sep{opacity:.4}.crumb-link{border:0;background:transparent;padding:0;color:inherit;font:inherit;cursor:pointer}.crumb-link:hover{color:var(--accent)}.crumb-link:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.crumb-current{color:var(--text);font-weight:600}.icon-btn{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;color:var(--text-muted);position:relative}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.mobile-sidebar-close,.icon-btn.mobile-menu-btn{display:none}.icon-btn .dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}.icon{flex-shrink:0}.content{padding:var(--pad);display:flex;flex-direction:column;gap:24px;min-height:0}.page-header{display:flex;align-items:flex-end;gap:16px;margin-bottom:4px}.page-header h1{font-size:26px;letter-spacing:-.02em;font-weight:800;margin:0}.page-header .sub{color:var(--text-muted);font-size:13.5px;margin-top:2px}.page-header .actions{margin-left:auto;display:flex;gap:8px}.toolbar-group{display:flex;align-items:center;gap:4px;margin-right:8px}.filter-count{font-size:12px;color:var(--text-muted)}.filter-title{font-size:13px;font-weight:700;margin-right:6px}.tabs-padded{padding-left:16px}.period-switch{display:inline-flex;align-items:center;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;max-width:100%}.period-switch button{min-height:32px;padding:6px 10px;border-radius:7px;font-size:12px;font-weight:700;color:var(--text-muted);white-space:nowrap}.period-switch button:hover{color:var(--text);background:var(--surface)}.period-switch button.active{background:var(--accent);color:var(--accent-fg);box-shadow:inset 0 1px #ffffff2e,0 1px 2px #0f172a14}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;font-weight:600;font-size:13px;border:1px solid transparent;transition:background .1s,border-color .1s,transform .05s;white-space:nowrap}.btn:active{transform:translateY(.5px)}.btn-primary{background:var(--accent);color:var(--accent-fg);box-shadow:inset 0 1px #ffffff2e,0 1px 2px #0f172a14}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{color:var(--text-muted)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-soft)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.btn-full{width:100%;justify-content:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}.card-header h3{font-size:14px;font-weight:700;margin:0;letter-spacing:-.005em}.card-header .sub{font-size:12px;color:var(--text-muted)}.card-header .actions{margin-left:auto;display:flex;gap:4px;align-items:center}.card-body{padding:20px}.card-body.flush{padding:0}.collapsible-header{cursor:pointer}.collapse-toggle{width:28px;height:28px;flex:0 0 28px;margin-left:-6px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-grid-3{grid-template-columns:repeat(3,1fr)}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;color:inherit;text-align:left;font:inherit}.kpi-clickable{cursor:pointer}.kpi-clickable:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.kpi-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.kpi-label{font-size:12px;color:var(--text-muted);font-weight:600;display:flex;align-items:center;gap:6px}.kpi-label.tone-success{color:var(--success)}.kpi-label.tone-danger{color:var(--danger)}.kpi-label.tone-warning{color:var(--warning)}.kpi-label.tone-accent{color:var(--accent)}.kpi-value{font-size:28px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-family:var(--font-ui)}.kpi-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-muted);min-width:0}.delta{display:inline-flex;align-items:center;gap:3px;max-width:100%;padding:2px 7px;border-radius:999px;font-weight:600;font-size:11.5px;font-variant-numeric:tabular-nums;line-height:1.35;white-space:normal}.delta.up{background:var(--success-soft);color:var(--success)}.delta.down{background:var(--danger-soft);color:var(--danger)}.delta.flat{background:var(--surface-2);color:var(--text-muted)}.kpi .spark{position:absolute;right:12px;bottom:12px;opacity:.9}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:600;background:var(--surface-2);color:var(--text-muted);white-space:nowrap}.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.pill.success{color:var(--success);background:var(--success-soft)}.pill.warning{color:#986600;color:oklch(.55 .15 75);background:var(--warning-soft)}.pill.danger{color:var(--danger);background:var(--danger-soft)}.pill.accent{color:var(--accent);background:var(--accent-soft)}.pill.neutral{color:var(--text-muted);background:var(--surface-3)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--surface-3);display:inline-grid;place-items:center;font-weight:700;font-size:11px;color:var(--text);flex-shrink:0;letter-spacing:.01em}.avatar.lg{width:44px;height:44px;font-size:14px}.avatar.xl{width:64px;height:64px;font-size:20px}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;font-weight:600;color:var(--text-muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle;height:var(--row-h)}.table tbody tr{transition:background .08s}.table tbody tr:hover{background:var(--surface-2);cursor:pointer}.table tbody tr:last-child td{border-bottom:none}.table .num{font-variant-numeric:tabular-nums;font-family:var(--font-mono);font-size:12.5px;text-align:right}.table .name-cell{display:flex;align-items:center;gap:10px;font-weight:600}.table .name-cell .sub{font-weight:400;color:var(--text-muted);font-size:12px}.align-right{text-align:right}.muted-cell{color:var(--text-muted)}.danger-cell{color:var(--danger)}.mono-cell,.mono-muted{font-family:var(--font-mono);font-size:12px}.mono-muted{color:var(--text-muted)}.table-empty-row:hover{background:transparent!important;cursor:default!important}.table-empty-cell{padding:0!important;height:auto!important}.table-empty-cell .empty{min-height:96px;display:grid;place-items:center;width:100%;padding:24px 16px}.table-compact th,.table-compact td{padding-left:14px;padding-right:14px}.row-actions{display:flex;gap:4px}.filter-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.filter-bar .input{display:flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:6px 10px;font-size:12.5px;color:var(--text-muted)}.filter-bar .input input{background:none;border:none;outline:none;width:200px;color:var(--text)}.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border);cursor:pointer}.chip.active{background:var(--accent-soft);color:var(--accent);border-color:transparent}.chip:hover:not(.active){background:var(--surface-3);color:var(--text)}.row{display:grid;gap:16px}.row.cols-2{grid-template-columns:1.6fr 1fr}.scheduler{display:grid;grid-template-columns:60px repeat(7,minmax(118px,1fr));border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);background:var(--surface)}.schedule-scroll{max-height:min(72vh,860px);overflow:auto;border-radius:var(--radius-lg);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;position:relative;scroll-behavior:smooth;transition:box-shadow .18s ease}.schedule-scroll.drag-active{scroll-behavior:auto;cursor:grabbing}.schedule-scroll.drag-active.edge-up{box-shadow:inset 0 22px 28px -26px var(--accent)}.schedule-scroll.drag-active.edge-down{box-shadow:inset 0 -22px 28px -26px var(--accent)}.schedule-scroll.drag-active.edge-left{box-shadow:inset 26px 0 32px -30px var(--accent)}.schedule-scroll.drag-active.edge-right{box-shadow:inset -26px 0 32px -30px var(--accent)}.schedule-scroll .scheduler{transition:transform .22s ease}.schedule-scroll.drag-active.edge-left .scheduler{transform:translate(5px)}.schedule-scroll.drag-active.edge-right .scheduler{transform:translate(-5px)}.sched-header{background:var(--surface-2);padding:10px 12px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-muted);border-right:1px solid var(--border);position:sticky;top:0;z-index:2}.sched-header.today{background:var(--accent-soft);color:var(--accent)}.sched-header .day-num{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.sched-day-label{display:flex;align-items:baseline;gap:8px}.sched-header.today .day-num{color:var(--accent)}.sched-time{font-size:10.5px;color:var(--text-faint);font-family:var(--font-mono);text-align:right;padding:4px 8px 0 0;border-right:1px solid var(--border);height:var(--slot-height, 60px);position:relative;top:-7px}.sched-time.quarter-label{color:transparent}.sched-cell{border-right:1px solid var(--border);border-top:1px solid color-mix(in oklab,var(--border) 45%,transparent);height:var(--slot-height, 60px);position:relative;transition:background .12s ease,outline-color .12s ease}.sched-cell.hour-start{border-top-color:var(--border)}.sched-cell:last-child{border-right:none}.sched-cell:hover{background:var(--surface-2);cursor:pointer}.sched-cell.drag-over{background:var(--accent-soft);outline:1px dashed var(--accent);outline-offset:-3px}.sched-event{position:absolute;z-index:1;left:4px;right:4px;border-radius:7px;padding:6px 10px;font-size:11.5px;background:var(--accent-soft);color:var(--accent);border-left:3px solid var(--accent);cursor:grab;overflow:hidden;font-weight:500;transition:opacity .12s ease,transform .12s ease,box-shadow .12s ease;will-change:transform}.sched-event:active{cursor:grabbing}.sched-event.dragging{opacity:.58;transform:scale(.98);box-shadow:var(--shadow-sm);z-index:3}.sched-event .ev-title{font-weight:700;font-size:12px}.sched-event .ev-meta{color:var(--text-muted);margin-top:2px;font-size:10.5px}.sched-event.warm{background:var(--warm-soft);color:#6c4300;color:oklch(.42 .12 70);border-color:var(--warm)}.sched-event.success{background:var(--success-soft);color:var(--success);border-color:var(--success)}.sched-event.danger{background:var(--danger-soft);color:var(--danger);border-color:var(--danger)}.sched-event.neutral{background:var(--surface-3);color:var(--text);border-color:var(--text-faint)}[data-theme=dark] .sched-event.warm{color:#ffc075;color:oklch(.85 .12 70)}.schedule-agenda{display:grid;gap:10px;padding:10px}.agenda-day{border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden}.agenda-day.today{border-color:color-mix(in oklab,var(--accent) 45%,var(--border))}.agenda-day-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--surface-2);border-bottom:1px solid var(--border)}.agenda-day.today .agenda-day-head{background:var(--accent-soft);color:var(--accent)}.agenda-events{display:grid;gap:8px;padding:10px}.agenda-event,.agenda-empty{width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-align:left}.agenda-event{display:grid;grid-template-columns:88px minmax(0,1fr);gap:10px;padding:10px;border-left:3px solid var(--accent);cursor:pointer}.agenda-event:hover,.agenda-empty:hover{background:var(--surface-2)}.agenda-event.warm{border-left-color:var(--warm)}.agenda-event.success{border-left-color:var(--success)}.agenda-event.danger{border-left-color:var(--danger)}.agenda-event.neutral{border-left-color:var(--text-faint)}.agenda-event-time{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.agenda-event-main{display:grid;gap:2px;min-width:0}.agenda-event-title{font-weight:700}.agenda-event-meta{color:var(--text-muted);font-size:12px}.agenda-empty{padding:12px;color:var(--text-muted);cursor:pointer}.now-line{position:absolute;left:0;right:0;height:1px;background:var(--danger);z-index:3}.now-line:before{content:"";position:absolute;left:-4px;top:-3px;width:7px;height:7px;border-radius:50%;background:var(--danger)}.drawer-overlay{position:fixed;inset:0;background:#0f172a52;z-index:50;animation:fadeIn .15s ease}[data-theme=dark] .drawer-overlay{background:#00000080}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:92vw;background:var(--surface);border-left:1px solid var(--border);z-index:51;display:flex;flex-direction:column;animation:slideIn .2s cubic-bezier(.2,.8,.2,1)}.drawer-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.drawer-body{flex:1;overflow:auto;padding:22px}.drawer-title-block{flex:1}.drawer-title{font-weight:700;font-size:16px}.drawer-sub{font-size:12.5px;color:var(--text-muted)}.drawer-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;background:var(--surface-2)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:560px;max-width:92vw;max-height:88vh;background:var(--surface);border-radius:var(--radius-xl);z-index:51;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;border:1px solid var(--border);overflow:hidden;animation:scaleIn .18s cubic-bezier(.2,.8,.2,1)}@keyframes scaleIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.modal-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center}.modal-header h3{margin:0;font-size:16px;font-weight:700;letter-spacing:-.01em}.modal-sub{font-size:12.5px;color:var(--text-muted);margin-top:2px}.modal-body{padding:22px;overflow:auto}.modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;background:var(--surface-2)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;min-width:0}.field label{font-size:12px;font-weight:600;color:var(--text-muted)}.field input,.field select,.field textarea{width:100%;min-width:0;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:9px 11px;font-size:13px;font-family:inherit;color:var(--text);outline:none;transition:border-color .1s,background .1s,box-shadow .1s}.field select{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}.field textarea{resize:vertical;min-height:64px;line-height:1.5}.field input[type=date],.field input[type=time]{font-variant-numeric:tabular-nums}.field-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field-row.thirds{grid-template-columns:repeat(3,minmax(0,1fr))}.form-section-label{font-size:11px;font-weight:700;color:var(--text-faint);letter-spacing:.08em;margin:4px 0 10px;text-transform:uppercase}.form-section-label:not(:first-child){margin-top:18px}.seg-chips{display:flex;gap:6px;flex-wrap:wrap}.chip-radio{padding:8px 12px;font-size:12.5px;font-weight:600;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;gap:6px;transition:all .12s}.chip-radio:hover{color:var(--text);border-color:var(--text-faint)}.chip-radio.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.toggle-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;cursor:pointer;margin-bottom:4px}.toggle-row input[type=checkbox]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid var(--text-faint);border-radius:5px;background:var(--surface);cursor:pointer;position:relative;flex-shrink:0;margin-top:1px;transition:all .12s}.toggle-row input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.toggle-row input[type=checkbox]:checked:after{content:"";position:absolute;inset:2px;background:var(--surface);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><path d='m5 12 4 4 10-10'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><path d='m5 12 4 4 10-10'/></svg>") center/contain no-repeat}.toggle-row>span{font-size:13px;line-height:1.5}.toggle-row>span .sub{font-size:12px;color:var(--text-muted);margin-top:2px;font-weight:400}.compact-toggle{align-items:center;width:max-content;min-height:38px;margin-bottom:16px;padding:8px 12px}.compact-toggle input[type=checkbox]{margin-top:0}.compact-toggle>span{font-weight:700}.modal.wide{width:680px}.modal-summary{margin-top:16px;padding:14px;background:linear-gradient(180deg,var(--accent-soft),var(--surface-2));border:1px solid var(--accent-soft);border-radius:12px}.summary-line{display:flex;align-items:center;gap:12px}.summary-line-body{flex:1;min-width:0}.summary-line-title{font-weight:700}.summary-line-sub{font-size:12.5px;color:var(--text-muted)}.summary-line-value{font-weight:800;font-size:18px;white-space:nowrap}.chip-multi{display:flex;gap:6px;flex-wrap:wrap;padding:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;min-height:38px}.chip-multi:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.chip-multi .cm-chip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:6px;background:var(--accent-soft);color:var(--accent);display:inline-flex;align-items:center;gap:5px;cursor:pointer}.chip-multi .cm-chip:hover{background:var(--accent);color:#fff}.chip-multi input{flex:1;min-width:80px;border:none!important;background:transparent!important;padding:4px!important;font-size:13px;outline:none;box-shadow:none!important}.spacer{flex:1}.tag-list{display:flex;gap:6px;flex-wrap:wrap}.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.legend .swatch{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:6px;vertical-align:-1px}.empty{padding:56px 20px;text-align:center;color:var(--text-muted);font-size:13px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--text);color:var(--surface);padding:10px 16px;border-radius:10px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);z-index:100;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}.tabs{display:flex;border-bottom:1px solid var(--border);gap:4px}.tab{padding:10px 14px;font-size:13px;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;display:flex;align-items:center;gap:6px}.tab .badge{background:var(--surface-3);color:var(--text-muted);font-size:11px;padding:1px 7px;border-radius:999px;font-variant-numeric:tabular-nums}.tab.active{color:var(--text);border-color:var(--accent)}.tab:hover:not(.active){color:var(--text)}.planning-tabs{overflow:visible;white-space:normal}.planning-create{display:flex;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border)}.planning-create input,.todo-add input{min-width:0;flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:13px;outline:none}.planning-create input:focus,.todo-add input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}.planning-board{display:grid;gap:0}.todo-list{padding:18px 20px;border-bottom:1px solid var(--border)}.todo-list:last-child{border-bottom:none}.todo-list-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.todo-list-head h3{margin:0;font-size:14px;font-weight:750}.todo-list-head span,.todo-empty{color:var(--text-muted);font-size:12px}.todo-list-head>div{flex:1;min-width:0}.todo-items{display:grid;gap:4px;margin-bottom:12px}.todo-item{display:grid;grid-template-columns:22px minmax(0,1fr) 32px;align-items:center;gap:8px;min-height:36px;padding:4px 0}.todo-check{width:18px;height:18px;border:1.5px solid var(--border-strong);border-radius:5px;display:grid;place-items:center;color:var(--accent-fg)}.todo-item.done .todo-check{background:var(--accent);border-color:var(--accent)}.todo-item span{min-width:0;overflow-wrap:anywhere;font-size:13.5px}.todo-item.done span{color:var(--text-muted);text-decoration:line-through}.todo-item .icon-btn,.todo-list-head .icon-btn,.todo-add .icon-btn{width:32px;height:32px}.todo-add{display:flex;gap:8px}.cat-list{display:flex;flex-direction:column}.cat-row{display:grid;grid-template-columns:14px 1fr auto auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px dashed var(--border);font-size:13px}.cat-row:last-child{border-bottom:none}.cat-row .swatch{width:10px;height:10px;border-radius:3px}.cat-row .num{font-variant-numeric:tabular-nums;font-weight:600}.cat-row .pct{color:var(--text-muted);font-size:12px;min-width:42px;text-align:right;font-variant-numeric:tabular-nums}.category-list-title{font-size:11.5px;font-weight:700;color:var(--text-faint);letter-spacing:.08em;margin-bottom:8px}.section-spacer{height:18px}.strong-cell{font-weight:600}.invoice-number{font-family:var(--font-mono);font-size:12.5px;font-weight:600}.amount-in{color:var(--success);font-weight:700}.amount-out{color:var(--text);font-weight:700}.subject-revenue-body{display:flex;align-items:center;gap:24px}.cat-list-fill{flex:1}.aging-total{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}.aging-total>div{font-size:30px;font-weight:800}.aging-bar{display:flex;height:14px;border-radius:7px;overflow:hidden;margin-bottom:16px}.lesson-list{display:flex;flex-direction:column}.lesson-item{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px dashed var(--border)}.lesson-item:last-child{border-bottom:none}.lesson-item .time{font-family:var(--font-mono);font-size:12px;font-weight:600;min-width:84px;color:var(--text-muted)}.lesson-item .time-sub{color:var(--text-faint)}.lesson-item .body{flex:1;min-width:0}.lesson-item .body .title{font-weight:600;font-size:13.5px}.lesson-item .body .meta{font-size:12px;color:var(--text-muted)}.lesson-item .accent{width:3px;align-self:stretch;border-radius:99px;background:var(--accent)}.lesson-item.warm .accent{background:var(--warm)}.lesson-item.success .accent{background:var(--success)}.lesson-item.neutral .accent{background:var(--text-faint)}@media(max-width:1100px){:root{--pad: 18px}.kpi-grid,.kpi-grid[style]{grid-template-columns:repeat(2,minmax(0,1fr))!important}.row.cols-2{grid-template-columns:1fr}.card-header{align-items:flex-start;flex-wrap:wrap}.card-header .actions{width:100%;margin-left:0;justify-content:flex-start;overflow-x:auto;padding-bottom:2px}}@media(max-width:760px){:root{--topbar-h: 56px;--pad: 14px}html,body{font-size:13px;overflow-x:hidden}body.sidebar-lock{overflow:hidden;touch-action:none}.app{display:block;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:min(88vw,320px);height:100dvh;z-index:80;box-shadow:var(--shadow-lg);transform:translate(-105%);transition:transform .22s cubic-bezier(.2,.8,.2,1);border-right-color:var(--border-strong)}.sidebar-open .sidebar{transform:translate(0)}.sidebar-scrim{position:fixed;inset:0;z-index:70;background:#0f172a6b;opacity:0;pointer-events:none;transition:opacity .18s ease;display:block}[data-theme=dark] .sidebar-scrim{background:#00000094}.sidebar-open .sidebar-scrim{opacity:1;pointer-events:auto}.icon-btn.mobile-sidebar-close{display:grid;margin-left:auto;flex:0 0 36px}.mobile-topbar{min-height:var(--topbar-h);display:flex;align-items:center;gap:12px;padding:max(8px,env(safe-area-inset-top)) 14px 8px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.icon-btn.mobile-menu-btn{display:grid;flex:0 0 38px;width:38px;height:38px;background:var(--surface-2);border:1px solid var(--border);color:var(--text)}.mobile-title{display:grid;min-width:0;line-height:1.15}.mobile-title span{color:var(--text-faint);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.mobile-title strong{min-width:0;overflow:hidden;color:var(--text);font-size:15px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.brand{padding:14px 16px;min-height:var(--topbar-h)}.nav{padding:10px;overflow-y:auto;-webkit-overflow-scrolling:touch}.nav-item{min-height:44px;font-size:14px}.user-card{margin:10px;margin-bottom:max(10px,env(safe-area-inset-bottom))}.main{min-width:0}.topbar{display:none}.content{gap:16px;padding:14px}.page-header{align-items:stretch;flex-direction:column;gap:12px}.page-header h1{font-size:22px;line-height:1.2;display:none}.page-header .sub{font-size:12.5px}.page-header .actions{margin-left:0;overflow-x:visible;flex-wrap:wrap;padding-bottom:2px}.page-header .actions .btn,.page-header .actions .icon-btn{flex:1 1 auto;justify-content:center}.kpi-grid,.kpi-grid[style]{grid-template-columns:1fr!important;gap:10px}.kpi{min-height:112px;padding:14px}.kpi-value{font-size:24px}.card{border-radius:10px}.card-header,.card-body,.modal-body,.drawer-body{padding:14px}.card-header .sub{flex-basis:100%}.card:has(.table){overflow-x:auto;-webkit-overflow-scrolling:touch}.card:has(.responsive-table){overflow-x:visible}.table{min-width:720px}.table.responsive-table{min-width:0;border-collapse:separate;border-spacing:0}.responsive-table thead{display:none}.responsive-table tbody{display:grid;gap:10px;padding:10px}.responsive-table tr{display:block;border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden}.responsive-table td{display:grid;grid-template-columns:minmax(92px,36%) minmax(0,1fr);align-items:center;gap:10px;width:100%;height:auto;min-height:40px;padding:8px 10px;border-bottom:1px dashed var(--border);word-break:break-word}.responsive-table td:last-child{border-bottom:0}.responsive-table td:before{content:attr(data-label);min-width:0;color:var(--text-muted);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.responsive-table td[data-label=""]:before,.responsive-table .table-empty-cell:before{content:none}.responsive-table .table-empty-row{border:0;border-radius:0;background:transparent;overflow:visible}.responsive-table .table-empty-cell{display:block;padding:0!important;border:0}.responsive-table .table-empty-cell .empty{min-height:112px;border:1px dashed var(--border);border-radius:10px;background:var(--surface)}.responsive-table .num,.responsive-table .align-right{text-align:left}.responsive-table .row-actions{justify-content:flex-start;flex-wrap:wrap}.responsive-table .name-cell,.responsive-table .tag-list{min-width:0}.table th,.table td{padding:10px 12px}.filter-bar{align-items:stretch;flex-wrap:wrap;gap:8px;padding:10px;min-width:0;overflow-x:visible}.filter-bar .input{flex:1 1 100%}.filter-bar .input input{width:100%;min-width:0}.filter-bar .spacer{display:none}.filter-bar .chip{flex:0 1 auto}.tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.planning-tabs{overflow-x:visible;white-space:normal}.tab{flex:0 0 auto}.scheduler{min-width:980px}.sched-header{padding:9px 10px}.sched-event{padding:5px 7px}.drawer{width:100vw;max-width:100vw}.mini-stat-grid{grid-template-columns:1fr}.subject-revenue-body,.summary-line{flex-direction:column;align-items:stretch}.summary-line-value{text-align:left}.drawer-header{padding:14px;align-items:flex-start}.drawer-foot,.modal-foot{padding:12px 14px;flex-wrap:wrap}.drawer-foot .btn,.modal-foot .btn{flex:1 1 auto;justify-content:center}.modal,.modal.wide{inset:auto 0 0;width:100vw;max-width:100vw;max-height:92dvh;border-radius:18px 18px 0 0;transform:none;animation:mobileSheetIn .2s cubic-bezier(.2,.8,.2,1)}.modal-header{padding:14px}.field-row,.field-row.thirds{grid-template-columns:1fr;gap:0}.seg-chips,.chip-multi{gap:7px}.chip-radio,.chip{min-height:34px;align-items:center}.lesson-item{align-items:flex-start;gap:10px}.lesson-item .time{min-width:58px}.toast{left:14px;right:14px;bottom:16px;transform:none;justify-content:center}@keyframes mobileSheetIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}}@media(max-width:420px){.btn{padding:8px 11px;gap:6px}.page-header .actions{flex-wrap:wrap}.card-header h3{font-size:13.5px}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:2px solid var(--bg)}::-webkit-scrollbar-track{background:transparent}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.auth-card{width:min(420px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:28px}.auth-card h1{margin:0 0 20px;font-size:24px;letter-spacing:-.02em}.auth-brand{height:auto;padding:0;border-bottom:none;margin-bottom:24px}.auth-dev-skip{margin-top:10px}.auth-links{display:flex;justify-content:space-between;gap:12px;margin-top:14px}.auth-links button{color:var(--text-muted);font-size:12.5px}.auth-links button:hover{color:var(--accent)}.form-message{padding:10px 12px;border-radius:8px;background:var(--accent-soft);color:var(--accent);font-size:12.5px;margin-bottom:14px;font-weight:600}.note-box{padding:12px 14px;background:var(--surface-2);border-radius:10px;font-size:13px;color:var(--text-muted);line-height:1.55;margin-bottom:20px}.settings-account-actions{display:flex;justify-content:flex-start;gap:8px;margin-top:14px}.chip-multi .cm-chip.inactive{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.modal-tabs{margin-bottom:14px}.repeat-row{margin-top:10px}.muted-input{color:var(--text-muted)!important}.preview-card{border-radius:10px}.info-grid{display:grid;gap:8px;margin-bottom:20px}.info-row{display:flex;gap:10px;font-size:13px}.info-row span{color:var(--text-muted)}.info-row strong{margin-left:auto;font-weight:600;text-align:right}.mini-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:76px;padding:12px}.mini-stat .label{color:var(--text-muted);font-size:12px;font-weight:600}.mini-stat .value{font-size:20px;font-weight:800;margin-top:6px}.mini-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}.option-list{display:grid;grid-template-columns:1fr}.option-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border)}.option-card:last-child{border-bottom:none}.option-card-main{min-width:0;display:grid;grid-template-columns:minmax(160px,.32fr) minmax(0,1fr);gap:16px;align-items:center}.option-title{font-size:13px;font-weight:700}.option-key{margin-top:2px;font-family:var(--font-mono);font-size:11px;color:var(--text-faint)}.option-preview{display:flex;flex-wrap:wrap;gap:6px;min-width:0}.option-builder{display:grid;gap:10px}.option-builder-row{display:grid;grid-template-columns:32px minmax(0,1fr) auto;gap:10px;align-items:start;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2)}.option-builder-row:has(.field:nth-of-type(3)){grid-template-columns:32px minmax(110px,.8fr) minmax(150px,1fr) minmax(110px,.7fr) minmax(150px,.9fr) auto}.option-row-index{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);font-size:12px;font-weight:700;margin-top:22px}.option-builder-row .field{margin-bottom:0}.option-row-actions{display:flex;gap:4px;align-items:center;margin-top:22px}@media(max-width:760px){.mini-stat-grid{grid-template-columns:1fr}.period-switch{width:100%;overflow-x:auto}.period-switch button{flex:1 0 auto}.option-card,.option-card-main,.option-builder-row,.option-builder-row:has(.field:nth-of-type(3)){grid-template-columns:1fr}.option-card{padding:14px;align-items:stretch}.option-card>.btn{justify-content:center}.option-card-main{gap:10px}.option-row-index,.option-row-actions{margin-top:0}.option-row-actions{justify-content:flex-end}}
