:root,:root[data-theme=light]{--bg: #f8fafc;--panel: #ffffff;--hover: #f1f5f9;--hover-strong: #e2e8f0;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: #dbeafe;--on-accent: #ffffff;--success: #15803d;--success-bg: #dcfce7;--warn: #b45309;--warn-bg: #fef3c7;--danger: #b91c1c;--danger-bg: #fee2e2;--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-strong: 0 8px 24px rgba(15, 23, 42, .15);--input-bg: var(--panel);--code-bg: #f4f4f5;--backdrop: rgba(15, 23, 42, .5);--toast-bg: #0f172a;color-scheme:light}:root[data-theme=dark]{--bg: #0b1220;--panel: #111a2e;--hover: #182338;--hover-strong: #1e2a44;--ink: #e6ecf5;--muted: #94a3b8;--line: #233149;--accent: #60a5fa;--accent-hover: #93c5fd;--accent-soft: #1e3a8a;--on-accent: #0b1220;--success: #34d399;--success-bg: #064e3b;--warn: #fbbf24;--warn-bg: #422006;--danger: #f87171;--danger-bg: #450a0a;--shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-strong: 0 8px 24px rgba(0, 0, 0, .5);--input-bg: #0f1729;--code-bg: #182338;--backdrop: rgba(0, 0, 0, .7);--toast-bg: #1e2a44;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;transition:background-color .15s ease,color .15s ease}.page-loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--muted);font-size:15px}.app-shell{display:grid;grid-template-rows:56px 1fr;height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--panel);border-bottom:1px solid var(--line);padding:0 24px;box-shadow:var(--shadow)}.brand{font-weight:700;color:var(--ink);font-size:16px;display:flex;align-items:center;gap:8px}.brand-mark{display:inline-block;width:28px;height:28px;border-radius:6px;background:var(--accent);color:var(--on-accent);font-weight:700;text-align:center;line-height:28px}.topbar-right{display:flex;align-items:center;gap:10px}.user-chip{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.user-chip .role{background:var(--hover-strong);padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;color:var(--ink)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:6px;color:var(--muted)}.theme-toggle:hover{color:var(--ink)}.theme-toggle-icon{display:inline-flex;transition:transform .25s ease}.theme-toggle:hover .theme-toggle-icon{transform:rotate(15deg)}.app-body{display:grid;grid-template-columns:220px 1fr;min-height:0}.sidenav{background:var(--panel);border-right:1px solid var(--line);padding:16px 8px;overflow-y:auto}.sidenav a{display:flex;align-items:center;padding:8px 14px;color:var(--muted);text-decoration:none;border-radius:6px;font-size:14px;font-weight:500}.sidenav a:hover{background:var(--hover);color:var(--ink)}.sidenav a.active{background:var(--accent-soft);color:var(--accent)}.sidenav-section{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:18px 14px 6px}.content{overflow-y:auto;padding:24px 32px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.page-header h1{font-size:22px;margin:0 0 4px;color:var(--ink)}.page-header .lede{color:var(--muted);font-size:13px;margin:0}button,.btn{background:var(--panel);border:1px solid var(--line);color:var(--ink);padding:7px 14px;font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:background .12s,border-color .12s,color .12s}button:hover:not(:disabled),.btn:hover:not(:disabled){background:var(--hover)}button.primary,.btn.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}button.primary:hover:not(:disabled),.btn.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.ghost{background:transparent;border-color:transparent;color:var(--muted)}button.ghost:hover:not(:disabled){background:var(--hover);color:var(--ink)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}button.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.danger:hover:not(:disabled){filter:brightness(.95)}.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:20px 24px;box-shadow:var(--shadow)}.form-row{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.form-field{display:flex;flex-direction:column;gap:4px;min-width:0}.form-field label{font-size:12px;color:var(--muted);font-weight:500}.form-field input,.form-field select,.form-field textarea{padding:7px 10px;border:1px solid var(--line);border-radius:6px;font-size:13px;background:var(--input-bg);color:var(--ink);font-family:inherit}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:2px solid var(--accent-soft);outline-offset:-1px;border-color:var(--accent)}.form-field input::placeholder{color:var(--muted)}.quick-filters{display:flex;gap:6px}.quick-filters button{padding:5px 10px;font-size:12px;background:var(--hover);border-color:transparent}.form-row.stacked{flex-direction:column;align-items:stretch}.form-row.stacked .form-field{width:100%}.field-error{color:var(--danger);font-size:12px;margin-top:4px}.status-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.status-pill .dot{width:6px;height:6px;border-radius:50%}.status-pill.success{background:var(--success-bg);color:var(--success)}.status-pill.success .dot{background:var(--success)}.status-pill.failed{background:var(--danger-bg);color:var(--danger)}.status-pill.failed .dot{background:var(--danger)}.status-pill.in_progress{background:var(--warn-bg);color:var(--warn)}.status-pill.in_progress .dot{background:var(--warn);animation:pulse 1.2s ease-in-out infinite}.status-pill.partial{background:var(--warn-bg);color:var(--warn)}.status-pill.partial .dot{background:var(--warn)}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.status-tag{display:inline-block;padding:1px 7px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.02em;background:var(--surface-2, #eef2f7);color:var(--muted, #4b5563)}.status-tag.present{background:var(--success-bg);color:var(--success)}.status-tag.absent,.status-tag.failed{background:var(--danger-bg);color:var(--danger)}.status-tag.leave{background:#ede9fe;color:#6d28d9}.status-tag.holiday{background:#dbeafe;color:#1d4ed8}.status-tag.weekend{background:var(--surface-2, #eef2f7);color:var(--muted, #6b7280)}.status-tag.extraction_failed{background:var(--danger-bg);color:var(--danger)}.att-legend{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:12px;font-size:12px}.att-legend-item{display:inline-flex;align-items:center;gap:6px}.att-legend-item .att-cell{display:inline-block;border-radius:3px}.att-matrix-wrap{overflow:auto;max-height:70vh;border:1px solid var(--border, #e5e7eb);border-radius:8px}.att-matrix{border-collapse:separate;border-spacing:0;font-size:11px}.att-matrix th,.att-matrix td{border-right:1px solid var(--border, #eef1f4);border-bottom:1px solid var(--border, #eef1f4);padding:3px 5px;text-align:center;white-space:nowrap}.att-matrix thead th{position:sticky;top:0;z-index:2;background:var(--surface, #fff);font-weight:600}.att-matrix .att-mon{font-size:9px;font-weight:400;color:var(--muted, #9ca3af)}.att-sticky-col{position:sticky;left:0;z-index:1;background:var(--surface, #fff);text-align:left!important;font-weight:600;min-width:140px;max-width:180px;overflow:hidden;text-overflow:ellipsis}.att-matrix thead .att-sticky-col{z-index:3}.att-cell{font-weight:600;min-width:34px}.att-cell.present{background:var(--success-bg, #dcfce7);color:var(--success, #16a34a)}.att-cell.absent{background:var(--danger-bg, #fee2e2);color:var(--danger, #dc2626)}.att-cell.extraction_failed{background:#ffedd5;color:#c2410c}.att-cell.leave{background:#ede9fe;color:#6d28d9}.att-cell.weekend{background:var(--surface-2, #f3f4f6);color:var(--muted, #9ca3af)}.att-cell.holiday{background:#dbeafe;color:#1d4ed8}.att-cell.empty{background:repeating-linear-gradient(45deg,transparent,transparent 4px,var(--surface-2, #f3f4f6) 4px,var(--surface-2, #f3f4f6) 8px)}.role-chip{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;letter-spacing:.04em}.role-chip.super_admin{background:var(--accent-soft);color:var(--accent)}.role-chip.admin{background:var(--warn-bg);color:var(--warn)}.role-chip.viewer{background:var(--hover-strong);color:var(--ink)}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px;background:var(--panel)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;background:var(--hover);border-bottom:1px solid var(--line);padding:10px 12px;font-weight:600;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}tbody td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle;color:var(--ink)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--hover)}tbody tr.disabled-row td{opacity:.55}.col-actions{width:1%;white-space:nowrap}.col-num{text-align:right;font-variant-numeric:tabular-nums}.muted{color:var(--muted)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.pager{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--panel);border:1px solid var(--line);border-top:none;border-radius:0 0 8px 8px;font-size:12px;color:var(--muted)}.pager .pager-controls{display:flex;gap:6px;align-items:center}.pager button{padding:4px 10px;font-size:12px}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{padding:4px 12px;border-radius:14px;font-size:12px;border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.chip.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal{background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-strong);width:460px;max-width:100%;padding:22px 24px 18px}.modal h3{margin:0 0 4px;font-size:17px}.modal .modal-sub{color:var(--muted);font-size:13px;margin:0 0 16px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.modal-form{display:flex;flex-direction:column;gap:14px}.modal-form .form-field{width:100%}.modal-form .input-with-toggle{position:relative}.modal-form .input-with-toggle input{padding-right:60px}.modal-form .input-with-toggle button{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:4px 8px;font-size:11px;background:transparent;border:none;color:var(--muted)}.modal-form .input-with-toggle button:hover{color:var(--ink);background:var(--hover)}.toast{position:fixed;bottom:20px;right:20px;background:var(--toast-bg);color:#fff;padding:10px 16px;border-radius:6px;font-size:13px;box-shadow:var(--shadow-strong);z-index:100;opacity:0;transform:translateY(8px);transition:opacity .2s,transform .2s}.toast.show{opacity:1;transform:translateY(0)}.toast.error{background:var(--danger)}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 56px);padding:40px;text-align:center}.error-page h1{font-size:64px;margin:0 0 8px;color:var(--accent)}.error-page h2{color:var(--ink)}.error-page p{color:var(--muted);margin:0 0 24px;max-width:480px}
