:root{--ink: #0f172a;--ink-soft: #334155;--muted: #64748b;--line: #e2e8f0;--surface: #ffffff;--surface-sunken: #f5f7fa;--surface-raised: #ffffff;--accent: #4f46e5;--accent-strong: #4338ca;--accent-soft: #eef2ff;--accent-contrast: #ffffff;--status-notstarted: #475569;--status-notstarted-bg: #eef2f7;--status-progress: #2563eb;--status-progress-bg: #eff6ff;--status-hold: #b45309;--status-hold-bg: #fffbeb;--status-cancelled: #64748b;--status-cancelled-bg: #f1f5f9;--status-completed: #15803d;--status-completed-bg: #f0fdf4;--danger: #dc2626;--danger-bg: #fef2f2;--overdue: #dc2626;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "SF Mono", "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 16px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .18);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:var(--font-body);color:var(--ink);background:var(--surface-sunken);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}button{font-family:inherit;cursor:pointer}a{color:var(--accent)}.app-shell{min-height:100%;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-3) var(--sp-5);background:var(--surface);border-bottom:1px solid var(--line)}.topbar .brand{font-weight:700;letter-spacing:-.01em;font-size:16px;display:flex;align-items:center;gap:var(--sp-2)}.topbar .brand .dot{width:10px;height:10px;border-radius:3px;background:var(--accent)}.topbar .spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:var(--sp-4)}.topbar-menu{display:none;position:relative}.hamburger{font-size:20px;line-height:1;padding:6px 10px}.tb-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30}.tb-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:31;min-width:200px;display:flex;flex-direction:column;gap:2px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--sp-2)}.tb-menu-user{padding:8px 10px;margin-bottom:4px;border-bottom:1px solid var(--line)}.tb-menu-name{font-weight:600;font-size:14px}.tb-menu-item{text-align:left;border:0;background:transparent;color:var(--ink);font-size:14px;font-weight:500;padding:10px;border-radius:var(--radius-sm)}.tb-menu-item:hover{background:var(--surface-sunken)}.container{width:100%;max-width:1280px;margin:0 auto;padding:var(--sp-5)}.btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:13px;font-weight:600;transition:background .12s,border-color .12s}.btn:hover{background:var(--surface-sunken)}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast)}.btn.primary:hover{background:var(--accent-strong)}.btn.ghost{border-color:transparent;background:transparent}.btn.danger{color:var(--danger);border-color:var(--line)}.btn.danger:hover{background:var(--danger-bg)}.btn:disabled{opacity:.5;cursor:not-allowed}.stats-bar{margin-bottom:var(--sp-4)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-5)}.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--sp-4);box-shadow:var(--shadow-sm);text-align:left;font:inherit;color:inherit;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .06s}.stat:hover{border-color:var(--accent)}.stat:active{transform:translateY(1px)}.stat.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.stat .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;display:flex;align-items:center;gap:6px}.stat.active .label:after{content:"✓";color:var(--accent)}.quick-note{display:flex;align-items:center;gap:var(--sp-2);margin:calc(var(--sp-5) * -1 + var(--sp-2)) 0 var(--sp-4);color:var(--ink-soft);font-size:13px}.stat .value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;margin-top:var(--sp-1)}.stat.alert .value{color:var(--overdue)}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4)}.filters{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:flex-end;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--sp-4);margin-bottom:var(--sp-4)}.filter-btn{display:inline-flex}.filter-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-strong)}.filter-btn.primary.active{background:var(--accent-strong);border-color:var(--accent-strong);color:var(--accent-contrast)}.filter-panel{display:none}.filter-panel.open{display:block}.filter-sheet-backdrop,.filter-sheet-head,.filter-sheet-foot{display:none}.page-search{margin-bottom:var(--sp-4);max-width:480px}.page-search input{width:100%;font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink)}.page-search input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.field{display:flex;flex-direction:column;gap:4px;min-width:150px}.field label{font-size:12px;font-weight:600;color:var(--muted)}.field input,.field select,.field textarea{font-family:inherit;font-size:14px;padding:8px 10px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink)}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.field textarea{resize:vertical;min-height:72px}.field .err{color:var(--danger);font-size:12px}.segmented{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}.segmented button{border:0;background:var(--surface);padding:8px 12px;font-size:13px;font-weight:600;color:var(--muted)}.segmented button.active{background:var(--accent-soft);color:var(--accent-strong)}.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:auto;box-shadow:var(--shadow-sm)}table.smart{width:100%;border-collapse:collapse;font-size:13px}table.smart th{text-align:left;padding:10px 14px;background:var(--surface-sunken);border-bottom:1px solid var(--line);color:var(--ink-soft);font-weight:600;white-space:nowrap;position:sticky;top:0;-webkit-user-select:none;user-select:none}table.smart th.sortable{cursor:pointer}table.smart th .arrow{color:var(--accent);margin-left:4px}table.smart td{padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:top}table.smart tbody tr:hover{background:var(--surface-sunken)}table.smart tbody tr.overdue td:first-child{box-shadow:inset 3px 0 0 var(--overdue)}.num{font-variant-numeric:tabular-nums}.due.is-overdue{color:var(--overdue);font-weight:600}.smarttable{display:flex;flex-direction:column;gap:var(--sp-3)}.st-controls{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.st-menu-wrap{position:relative}.st-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30}.st-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:31;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--sp-2);min-width:220px}.st-menu-hint{font-size:11px;padding:4px 8px 8px}.st-menu-row{display:flex;align-items:center;gap:var(--sp-2);padding:6px 8px;border-radius:var(--radius-sm);cursor:grab}.st-menu-row:hover{background:var(--surface-sunken)}.st-menu-row.dragging{opacity:.5;background:var(--accent-soft)}.st-menu-row label{display:flex;align-items:center;gap:var(--sp-2);font-size:13px;font-weight:500;cursor:pointer;flex:1}.st-grip{color:var(--muted);cursor:grab}.st-pagesize{display:flex;align-items:center;gap:var(--sp-2);font-size:13px;color:var(--muted)}.st-pagesize select{font-family:inherit;padding:6px 8px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}.st-pager{display:flex;align-items:center;justify-content:center;gap:var(--sp-4)}.admin-section{padding:var(--sp-4) 0;border-bottom:1px solid var(--line)}.admin-section:last-of-type{border-bottom:0}.admin-section h3{margin:0 0 var(--sp-2);font-size:14px}.admin-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-3)}.chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface-sunken);border:1px solid var(--line);border-radius:999px;padding:3px 6px 3px 10px;font-size:12px;font-weight:500}.chip.disabled{opacity:.55;text-decoration:line-through;text-decoration-color:var(--muted)}.chip-toggle{border:0;background:transparent;color:var(--muted);font-size:11px;font-weight:600;padding:1px 6px;border-radius:999px;text-decoration:none}.chip-toggle:hover{background:var(--surface);color:var(--accent)}.chip.disabled .chip-toggle{color:var(--accent)}.admin-add{display:flex;gap:var(--sp-2)}.admin-add input{flex:1;font-family:inherit;font-size:14px;padding:8px 10px;border:1px solid var(--line);border-radius:var(--radius-sm)}.admin-add input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.admin-user-form{display:flex;flex-wrap:wrap;gap:var(--sp-2);align-items:center}.admin-user-form input[type=text],.admin-user-form>input{font-family:inherit;font-size:14px;padding:8px 10px;border:1px solid var(--line);border-radius:var(--radius-sm);flex:1;min-width:140px}.admin-admin-check{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;white-space:nowrap}.email-form{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-3)}.email-form .full{grid-column:1 / -1}.email-form .field label{font-size:12px;font-weight:600;color:var(--muted)}.email-form .field input,.email-form .field select{font-family:inherit;font-size:14px;padding:8px 10px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);width:100%}.email-form .field input:focus,.email-form .field select:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.email-actions{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}@media (max-width: 640px){.email-form{grid-template-columns:1fr}}.badge{display:inline-block;padding:3px 8px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.badge.NOT_STARTED{color:var(--status-notstarted);background:var(--status-notstarted-bg)}.badge.IN_PROGRESS{color:var(--status-progress);background:var(--status-progress-bg)}.badge.ON_HOLD{color:var(--status-hold);background:var(--status-hold-bg)}.badge.CANCELLED{color:var(--status-cancelled);background:var(--status-cancelled-bg)}.badge.COMPLETED{color:var(--status-completed);background:var(--status-completed-bg)}.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-3)}.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--sp-4);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--sp-2)}.tile.clickable{cursor:pointer;transition:border-color .12s,box-shadow .12s}.tile.clickable:hover{border-color:var(--accent);box-shadow:var(--shadow)}.tile.overdue{border-left:3px solid var(--overdue)}.tile .tile-head{display:flex;justify-content:space-between;align-items:start;gap:var(--sp-2)}.tile .tile-title{font-weight:700}.tile-desc{color:var(--ink-soft);font-size:13px}.tile-meta{display:flex;flex-wrap:wrap;align-items:center;gap:4px var(--sp-2);font-size:12px;color:var(--muted)}.tile-meta>span:not(:last-child):after{content:"·";margin-left:var(--sp-2);color:var(--line)}.tile .tile-actions{display:flex;gap:var(--sp-2);margin-top:var(--sp-1)}.kanban{display:flex;gap:var(--sp-3);align-items:flex-start;overflow-x:auto;padding-bottom:var(--sp-2);-webkit-overflow-scrolling:touch}.kanban-col{flex:1 0 260px;min-width:260px;display:flex;flex-direction:column;background:var(--surface-sunken);border:1px solid var(--line);border-radius:var(--radius)}.kanban-col.drag-over{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.kanban-col-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3);border-bottom:1px solid var(--line)}.kanban-hint{font-size:11px;text-transform:uppercase;letter-spacing:.04em}.kanban-col-body{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-3);min-height:90px}.kanban-card{display:flex;flex-direction:column;gap:var(--sp-2);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:var(--sp-3);box-shadow:var(--shadow-sm);cursor:grab;transition:border-color .12s,box-shadow .12s}.kanban-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.kanban-card:active{cursor:grabbing}.kanban-card.overdue{border-left:3px solid var(--overdue)}.kanban-card-title{font-weight:700}.kanban-card-foot{display:flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-1)}.kanban-status-select{flex:1;font-family:inherit;font-size:12px;padding:6px 8px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink)}.kanban-dropzone,.kanban-empty{font-size:13px;text-align:center;padding:var(--sp-4) var(--sp-2);border:1px dashed var(--line);border-radius:var(--radius-sm)}.cal{display:flex;flex-direction:column;gap:var(--sp-2)}.tl-note{font-size:13px}.cal-week{display:flex;align-items:stretch;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.cal-week-label{flex:0 0 120px;display:flex;align-items:center;padding:var(--sp-2) var(--sp-3);border-right:1px solid var(--line);background:var(--surface-sunken);font-weight:600;font-size:12px;position:sticky;left:0;z-index:2}.cal-days{flex:1;display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.cal-day{display:flex;flex-direction:column;min-height:88px;border-left:1px solid var(--line)}.cal-day:first-child{border-left:0}.cal-day.is-weekend{background:var(--surface-sunken)}.cal-day.is-today{background:var(--accent-soft)}.cal-day.drag-over{box-shadow:inset 0 0 0 2px var(--accent)}.cal-day-head{display:flex;gap:4px;align-items:baseline;padding:4px 6px;border-bottom:1px solid var(--line);font-size:11px;color:var(--muted)}.cal-day.is-today .cal-day-head{color:var(--accent-strong);font-weight:700}.cal-day-body{display:flex;flex-direction:column;gap:3px;padding:4px}.cal-pill{display:block;width:100%;text-align:left;font:inherit;font-size:11px;font-weight:600;padding:3px 6px;border:1px solid;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-pill.NOT_STARTED{background:var(--status-notstarted-bg);border-color:var(--status-notstarted);color:var(--status-notstarted)}.cal-pill.IN_PROGRESS{background:var(--status-progress-bg);border-color:var(--status-progress);color:var(--status-progress)}.cal-pill.ON_HOLD{background:var(--status-hold-bg);border-color:var(--status-hold);color:var(--status-hold)}.cal-pill.COMPLETED{background:var(--status-completed-bg);border-color:var(--status-completed);color:var(--status-completed)}.cal-pill.CANCELLED{background:var(--status-cancelled-bg);border-color:var(--status-cancelled);color:var(--status-cancelled)}.cal-pill.overdue{border-color:var(--overdue);box-shadow:0 0 0 2px var(--danger-bg)}.cal-more{align-self:flex-start;border:0;background:transparent;color:var(--accent);font-size:11px;font-weight:600;cursor:pointer;padding:2px 4px}@media (max-width: 900px){.cal-week-label{flex-basis:96px;font-size:11px}.cal-days{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch}.cal-day{flex:0 0 132px}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:var(--sp-5);overflow:auto;z-index:50}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:640px;margin-top:40px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--line)}.modal-head h2{margin:0;font-size:17px}.modal-body{padding:var(--sp-5);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.modal-body .full{grid-column:1 / -1}.modal-foot{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--line)}.history{display:flex;flex-direction:column;gap:var(--sp-2);max-height:240px;overflow:auto}.history .entry{border-left:2px solid var(--accent-soft);padding:2px 0 2px var(--sp-3)}.history .entry .when{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3) var(--sp-4)}.detail-grid .k{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}.detail-grid .v{font-size:14px}.pin-screen{min-height:100%;display:flex;align-items:center;justify-content:center;padding:var(--sp-5)}.pin-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:var(--sp-6);width:100%;max-width:360px;text-align:center}.pin-card h1{font-size:20px;margin:0 0 var(--sp-2)}.pin-card p{color:var(--muted);margin:0 0 var(--sp-5)}.pin-input{width:100%;text-align:center;letter-spacing:.4em;font-size:24px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);font-variant-numeric:tabular-nums}.pin-input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.muted{color:var(--muted)}.empty{text-align:center;padding:var(--sp-6);color:var(--muted)}.toast{position:fixed;bottom:var(--sp-5);left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:10px 16px;border-radius:var(--radius);box-shadow:var(--shadow);z-index:100;font-size:13px}@media (max-width: 900px){.topbar-actions{display:none}.topbar-menu{display:block}.summary-grid{display:flex;flex-wrap:nowrap;gap:var(--sp-2);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}.summary-grid::-webkit-scrollbar{display:none}.summary-grid .stat{flex:0 0 auto;width:158px;scroll-snap-align:start;padding:8px 12px}.summary-grid .stat .value{font-size:20px;margin-top:0}.summary-grid .stat .label{font-size:11px}.filters .field{flex:1 1 calc(50% - var(--sp-3));min-width:0}.page-search{max-width:none;margin-bottom:var(--sp-3)}.toolbar .spacer{display:none}.toolbar .filter-btn{order:1}.toolbar .excel-btn{order:2}.toolbar .segmented{order:3}.filter-sheet-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:50}.filter-sheet{position:fixed;left:0;right:0;bottom:0;z-index:51;display:flex;flex-direction:column;max-height:85vh;background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-lg)}.filter-sheet-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4);border-bottom:1px solid var(--line)}.filter-sheet-head h2{margin:0;font-size:16px}.filter-sheet .filters{flex:1 1 auto;overflow-y:auto;margin:0;border:0;border-radius:0;box-shadow:none;background:transparent}.filter-sheet-foot{display:flex;justify-content:space-between;gap:var(--sp-2);padding:var(--sp-4);border-top:1px solid var(--line)}}@media (max-width: 600px){.container,.topbar{padding:var(--sp-3)}.toolbar{gap:var(--sp-2)}.toolbar .btn,.toolbar .segmented button{padding:6px 10px;font-size:12px}.filters{padding:var(--sp-3);gap:var(--sp-2)}.filters .field{min-width:0;flex:1 1 100%}table.smart{font-size:12px}table.smart th,table.smart td{padding:6px 8px}.overlay{padding:var(--sp-3)}.modal{margin-top:var(--sp-3)}.modal-body,.detail-grid{grid-template-columns:1fr}.modal-body{padding:var(--sp-4)}.modal-head,.modal-foot{padding:var(--sp-3) var(--sp-4)}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}
