:root{font-feature-settings:"cv11", "ss01", "ss03", "cv02", "cv03", "cv04";letter-spacing:-.005em;color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f1f5f9;font-family:Inter,Inter var,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:400;line-height:1.4}code,pre,kbd,samp{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}*{box-sizing:border-box}body{margin:0}button,input,select,textarea,::placeholder{font:inherit;letter-spacing:inherit}.app-shell{color:#0f172a;width:100%;margin:0;padding:10px 12px}.app-header{justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:12px;display:flex}.app-header h1{letter-spacing:-.02em;color:#0f172a;margin:0;font-size:1.45rem;font-weight:700}.app-header p{color:#475569;letter-spacing:-.005em;margin:4px 0 0;font-size:.9rem}.header-actions{align-items:center;gap:8px;display:flex}.header-user{align-items:center;margin-left:2px;display:inline-flex}.header-user .cl-userButtonAvatarBox,.header-user .cl-avatarBox{width:32px;height:32px}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:10px;padding:12px;box-shadow:0 1px 2px #0f172a0a}.panel h2{letter-spacing:.02em;text-transform:uppercase;color:#475569;margin:0 0 8px;font-size:.85rem;font-weight:600}.client-search{color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:.85rem;transition:border-color .15s,box-shadow .15s;display:inline-flex;position:relative}.client-search:focus-within{color:#1d4ed8;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.client-search-icon{flex-shrink:0}.client-search input{color:#0f172a;background:0 0;border:none;outline:none;width:180px;padding:0;font-size:.85rem}.client-search input::placeholder{color:#94a3b8}.csv-import{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;padding:7px 10px;font-size:.85rem;font-weight:500;display:inline-flex;position:relative;overflow:hidden}.csv-import input{opacity:0;cursor:pointer;position:absolute;inset:0}.header-button{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;gap:6px;padding:7px 10px;font-size:.85rem;font-weight:500;transition:border-color .15s,background .15s,box-shadow .15s;display:inline-flex}.header-button:hover{background:#f8fafc;border-color:#94a3b8}.header-button.primary{color:#fff;background:#2563eb;border-color:#2563eb;font-weight:600}.header-button.primary:hover{background:#1d4ed8;border-color:#1d4ed8}.header-button-plus{font-size:1rem;font-weight:700;line-height:1}.add-client-modal{width:min(440px,100%)}.add-client-field{color:#374151;flex-direction:column;gap:4px;font-size:.8rem;font-weight:600;display:flex}.add-client-field input{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:8px 10px;font-size:.9rem;font-weight:400}.add-client-field input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #2563eb26}.modal-footer button.primary{color:#fff;background:#2563eb;border-color:#2563eb;font-weight:600}.modal-footer button.primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8}table{border-collapse:collapse;table-layout:fixed;width:100%}th,td{text-align:left;border:1px solid #e5e7eb;padding:6px;font-size:.82rem;overflow:hidden}tbody td{padding:3px}thead th{z-index:1;color:#0f172a;vertical-align:top;letter-spacing:-.005em;background:#f8fafc;font-weight:700;position:sticky;top:0}tbody tr{transition:background-color .12s}tbody tr:hover{background:#f8fafc}col.col-client-code{width:78px}col.col-name{width:20%}col.col-source{width:18%}col.col-notes{width:auto}col.col-tracking{width:72px}.notes-cell{position:relative}.notes-cell input{padding-right:32px}.delete-client-button{color:#94a3b8;cursor:pointer;opacity:0;pointer-events:none;background:0 0;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;padding:0;transition:color .16s,background-color .16s,border-color .16s,opacity .18s,transform .24s cubic-bezier(.22,1,.36,1);display:inline-flex;position:absolute;top:50%;right:6px;overflow:hidden;transform:translateY(-50%)translate(8px)}tbody tr:hover .delete-client-button,.notes-cell:focus-within .delete-client-button,.delete-client-button:focus-visible{opacity:1;pointer-events:auto;transform:translateY(-50%)translate(0)}.delete-client-button:hover:not(:disabled),.delete-client-button:focus-visible:not(:disabled){color:#b91c1c;background:#fef2f2;border-color:#fecaca;outline:none}.delete-client-button:disabled{opacity:.6;cursor:not-allowed}.delete-client-icon{display:block}.delete-client-spinner{color:#94a3b8;justify-content:center;align-items:center;font-size:.85rem;display:inline-flex}.tracking-col-header{padding:4px 2px}.tracking-col-header-title{text-align:center;word-break:break-word;white-space:normal;flex-direction:column;justify-content:center;align-items:center;gap:2px;font-weight:700;line-height:1.15;display:flex;position:relative}.tracking-col-header-title .tracking-col-label{flex-direction:column;align-items:center;line-height:1.15;display:flex}.period-pill{text-align:center;color:#0e7490;word-break:break-word;background:#ecfeff;border:1px solid #a5f3fc;border-radius:4px;justify-content:center;align-items:center;margin-top:4px;padding:2px 6px;font-size:.72rem;font-weight:600;line-height:1.2;display:flex}.period-pill-due{color:inherit;white-space:nowrap}.period-pill-empty{color:#6b7280;background:#f3f4f6;border-color:#e5e7eb;font-weight:500}button.period-pill{cursor:pointer;width:100%;font-family:inherit}button.period-pill:hover{border-color:#67e8f9}.period-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.period-bar-actions{align-items:center;gap:8px;display:flex}.period-selector{align-items:center;gap:8px;display:inline-flex}.period-nav{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.8rem;display:inline-flex}.period-nav:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.period-nav:disabled{opacity:.4;cursor:not-allowed}.period-current{flex-direction:column;align-items:center;min-width:150px;display:inline-flex}.period-month-select{color:#0f172a;letter-spacing:-.01em;cursor:pointer;text-align:center;background:0 0;border:1px solid #0000;border-radius:6px;padding:2px 6px;font-size:.95rem;font-weight:700}.period-month-select:hover,.period-month-select:focus-visible{background:#fff;border-color:#cbd5e1;outline:none}.period-quarter-context{color:#64748b;margin-top:1px;font-size:.72rem}.history-notice{color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin:0 0 10px;padding:8px 12px;font-size:.82rem}tbody td input[type=text],tbody td input:not([type]){width:100%}td input{background:0 0;border:1px solid #0000;border-radius:4px;padding:2px 6px;font-size:.82rem}td input:focus{background:#eff6ff;border-color:#60a5fa;outline:none}.checkbox-cell{text-align:center;padding:0}.checkbox-cell.not-applicable{color:#9ca3af;background:repeating-linear-gradient(45deg,#f9fafb,#f9fafb 4px,#f3f4f6 4px 8px)}.checkbox-cell.period-not-ended{color:#94a3b8;cursor:help;background:#f8fafc;font-size:.85rem}.checkbox-cell.applicability-cell.applicable,.checkbox-cell.lodge-cell.lodged{background:#d1fae5}.cell-toggle-button{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;width:100%;height:100%;min-height:28px;padding:0;display:inline-flex}.toggleable-cell{cursor:pointer}.cell-toggle-button:hover,.cell-toggle-button:focus-visible{color:#1d4ed8;background:#2563eb14;outline:none}.checkbox-cell.lodge-cell.lodged .cell-toggle-button{color:#047857}.checkbox-cell.lodge-cell.lodged .cell-toggle-button:hover,.checkbox-cell.lodge-cell.lodged .cell-toggle-button:focus-visible{background:#05966924}.cell-tick{pointer-events:none;font-size:.95rem;font-weight:700;line-height:1}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.mode-toggle{background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;display:inline-flex;overflow:hidden}.mode-toggle button{color:#1f2937;cursor:pointer;background:0 0;border:none;padding:6px 10px;font-size:.8rem;font-weight:500}.mode-toggle button+button{border-left:1px solid #cbd5e1}.mode-toggle button.active{color:#fff;background:#2563eb;font-weight:700}.empty-state{text-align:center;color:#6b7280;padding:16px}.status{color:#1e40af;margin-top:4px;font-size:.82rem}.modal-backdrop{z-index:50;background:#0f172a73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:10px;width:min(600px,100%);max-height:calc(100vh - 48px);overflow:auto;box-shadow:0 15px 40px #0f172a40}.modal-header{justify-content:space-between;align-items:center;padding:14px 18px 8px;display:flex}.modal-header h2{color:#111827;margin:0;font-size:1rem}.modal-close{cursor:pointer;color:#6b7280;background:0 0;border:none;font-size:1.3rem;line-height:1}.modal-body{flex-direction:column;gap:12px;padding:4px 18px 12px;display:flex}.modal-hint{color:#6b7280;margin:0;font-size:.8rem;line-height:1.4}.due-dates-grid{flex-direction:column;gap:8px;display:flex}.due-dates-row{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;grid-template-columns:1.4fr 1fr;align-items:center;gap:8px;padding:8px 10px;display:grid}.due-dates-label{color:#111827;flex-direction:column;font-size:.85rem;font-weight:600;display:flex}.due-dates-period{color:#6b7280;margin-top:2px;font-size:.72rem;font-weight:400}.due-dates-row input[type=date]{background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:6px 8px;font-size:.85rem}.modal-error{color:#b91c1c;margin:0;font-size:.82rem}.modal-footer{background:#f9fafb;border-top:1px solid #f3f4f6;justify-content:flex-end;gap:8px;padding:10px 18px 14px;display:flex}.modal-footer button{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:7px 14px;font-size:.85rem;font-weight:500}.modal-footer button.danger{color:#fff;background:#dc2626;border-color:#dc2626;font-weight:700}.modal-footer button:disabled{opacity:.6;cursor:not-allowed}.toast-stack{z-index:60;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:16px;right:16px}.toast{pointer-events:auto;color:#0f172a;text-align:left;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;min-width:160px;max-width:320px;padding:8px 12px;font-size:.82rem;font-weight:500;animation:.16s ease-out both toast-in;display:inline-flex;box-shadow:0 8px 20px #0f172a24}.toast:hover{border-color:#cbd5e1}.toast-loading{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.toast-success{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.toast-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.toast-indicator{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-weight:700;display:inline-flex}.toast-success .toast-indicator{color:#047857}.toast-error .toast-indicator{color:#b91c1c}.toast-spinner{border:2px solid #cbd5e1;border-top-color:#2563eb;border-radius:50%;width:12px;height:12px;animation:.7s linear infinite toast-spin}.toast-message{line-height:1.2}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-spin{to{transform:rotate(360deg)}}@media (width<=960px){.app-header{flex-direction:column;align-items:flex-start}.period-bar{flex-direction:column;align-items:stretch}}.csv-wizard-card{width:min(960px,100%)}.csv-wizard-step-indicator{color:#6b7280;margin-top:2px;font-size:.78rem}.csv-wizard-body{min-height:280px}.csv-wizard-step{flex-direction:column;gap:12px;display:flex}.csv-wizard-helper{color:#374151;margin:0;font-size:.85rem;line-height:1.4}.csv-wizard-footnote{color:#6b7280;margin:0;font-size:.75rem}.csv-wizard-muted{color:#94a3b8}.csv-wizard-footer{align-items:center;display:flex}.csv-wizard-footer-spacer{flex:1}.csv-wizard-upload{align-items:flex-start}.csv-wizard-file-picker{color:#1f2937;cursor:pointer;background:#f8fafc;border:1px dashed #94a3b8;border-radius:8px;align-items:center;gap:6px;padding:14px 18px;font-size:.9rem;font-weight:500;display:inline-flex;position:relative}.csv-wizard-file-picker input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.csv-wizard-file-picker:hover{background:#eff6ff;border-color:#2563eb}.csv-wizard-table-scroll{border:1px solid #e5e7eb;border-radius:8px;max-height:360px;overflow:auto}.csv-wizard-preview-table{border-collapse:collapse;width:100%;font-size:.82rem}.csv-wizard-preview-table th,.csv-wizard-preview-table td{text-align:left;vertical-align:top;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:6px 8px}.csv-wizard-preview-table thead th{color:#374151;z-index:1;background:#f9fafb;font-weight:600;position:sticky;top:0}.csv-wizard-preview-table tbody tr:hover{background:#f8fafc}.csv-wizard-cell{text-overflow:ellipsis;max-width:240px;overflow:hidden}.csv-wizard-header-table tbody tr{cursor:pointer}.csv-wizard-row-skipped td{color:#94a3b8;background:#f8fafc;font-style:italic}.csv-wizard-row-header-pick td{color:#1e3a8a;background:#eff6ff;border-top:2px solid #2563eb;font-weight:600}.csv-wizard-radio-cell{text-align:center;width:32px}.csv-wizard-row-number{color:#6b7280;font-variant-numeric:tabular-nums;width:48px}.csv-wizard-mapping-list{background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:6px;padding:8px;display:flex}.csv-wizard-mapping-row{border-radius:6px;grid-template-columns:1fr 1fr 1.1fr;align-items:center;gap:10px;padding:6px 8px;display:grid}.csv-wizard-mapping-row+.csv-wizard-mapping-row{border-top:1px solid #f1f5f9}.csv-wizard-mapping-header{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-size:.72rem;font-weight:600;border-top:none!important}.csv-wizard-mapping-source strong{color:#111827;font-size:.88rem}.csv-wizard-mapping-sample{color:#475569;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;overflow:hidden}.csv-wizard-mapping-select{background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:6px 8px;font-size:.85rem}.csv-wizard-mapping-select:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #2563eb26}.csv-wizard-mapping-errors{background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;flex-direction:column;gap:4px;padding:8px 12px;display:flex}.csv-wizard-mapping-errors p{color:#991b1b;margin:0;font-size:.82rem}.csv-wizard-preview-summary{color:#1f2937;background:#f1f5f9;border-radius:6px;flex-wrap:wrap;align-items:center;gap:16px;padding:8px 10px;font-size:.85rem;display:flex}.csv-wizard-preview-error-count{color:#b91c1c;font-weight:600}.csv-wizard-tick-cell{text-align:center;color:#047857;font-weight:700}.csv-wizard-error-list{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:8px 12px}.csv-wizard-error-list h3{color:#991b1b;margin:0 0 6px;font-size:.85rem}.csv-wizard-error-list ul{color:#7f1d1d;margin:0;padding-left:18px;font-size:.82rem}.csv-wizard-error-list li{line-height:1.4}@media (width<=720px){.csv-wizard-mapping-row{grid-template-columns:1fr}}.auth-loading{color:#4b5563;justify-content:center;align-items:center;min-height:100vh;font-size:.95rem;display:flex}.auth-signin-screen{background:#f1f5f9;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-signin-card{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:440px;display:flex}.auth-signin-title{color:#111827;margin:0;font-size:1.6rem}.auth-signin-subtitle{color:#4b5563;margin:0 0 8px;font-size:.9rem}
