@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f5f7;--surface:#fff;--surface2:#eceef1;--border:#e2e5ea;--accent:#16181d;--accent-light:#3a3f47;--accent-dim:#16181d0f;--text:#1b1e24;--text-muted:#6c727e;--green:#15803d;--green-dim:#15803d1a;--orange:#b4690e;--orange-dim:#b4690e1f;--red:#c23b3b;--red-dim:#c23b3b1a;--blue:#2563eb;--blue-dim:#2563eb1a;--client-tag:#7c3aed;--client-tag-dim:#7c3aed1a;--radius:14px;--radius-sm:8px;--shadow:0 1px 2px #1018280a,0 4px 14px #1018280d;--shadow-hover:0 2px 4px #1018280f,0 8px 24px #10182814}body{-webkit-font-smoothing:antialiased;background:#f4f5f7;background:var(--bg);color:#1b1e24;color:var(--text);font-family:Inter,sans-serif;font-size:14px;line-height:1.5;min-height:100vh}button{cursor:pointer}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f4f5f7;background:var(--bg)}::-webkit-scrollbar-thumb{background:#e2e5ea;background:var(--border);border-radius:3px}.app-layout,.login-screen{display:flex;min-height:100vh}.login-screen{align-items:center;background:var(--bg);justify-content:center;padding:20px}.login-card{border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 10px 30px #1018281a;max-width:360px;padding:32px 28px;text-align:center;width:100%}.login-card,.sidebar{background:var(--surface)}.sidebar{border-right:1px solid var(--border);bottom:0;display:flex;flex-direction:column;left:0;min-height:100vh;padding:24px 0;position:fixed;top:0;width:220px}.sidebar-brand{border-bottom:1px solid var(--border);gap:12px;margin-bottom:20px;padding:0 20px 28px}.brand-icon,.sidebar-brand{align-items:center;display:flex}.brand-icon{background:var(--accent);border-radius:8px;color:#fff;flex-shrink:0;font-size:13px;font-weight:700;height:36px;justify-content:center;width:36px}.brand-name{color:var(--text);display:flex;flex-direction:column;font-size:16px;font-weight:700;letter-spacing:.2px;line-height:1.15}.brand-sub{color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:0 12px}.nav-link{align-items:center;border-radius:var(--radius-sm);color:var(--text-muted);display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 12px;text-decoration:none;transition:all .15s}.nav-link:hover{background:var(--surface2);color:var(--text)}.nav-link.active{background:var(--accent-dim);color:var(--accent-light)}.nav-link.active svg{stroke:var(--accent-light)}.sidebar-footer{border-top:1px solid var(--border);color:var(--text-muted);font-size:11px;margin-top:auto;padding:16px 20px 0}.sidebar-backup-btn{background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;padding:8px 10px;transition:all .15s;width:100%}.sidebar-backup-btn:hover{background:var(--surface2);border-color:var(--accent);color:var(--text)}.sidebar-backup-btn:disabled{cursor:default;opacity:.6}.nav-section-label{color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:.07em;padding:14px 12px 4px;text-transform:uppercase}.nav-section-label:first-child{padding-top:2px}.nav-link{position:relative}.nav-link.active:before{background:var(--accent);border-radius:2px;bottom:8px;content:"";left:2px;position:absolute;top:8px;width:3px}.sidebar-search{margin:0 12px 6px;position:relative}.sidebar-search-icon{font-size:12px;left:10px;opacity:.7;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.sidebar-search-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;outline:none;padding:8px 10px 8px 30px;transition:border-color .15s,box-shadow .15s;width:100%}.sidebar-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.search-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);left:0;max-height:60vh;overflow-y:auto;padding:4px;position:absolute;right:0;top:calc(100% + 4px);z-index:60}.search-group-label{color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:.06em;padding:8px 8px 3px;text-transform:uppercase}.search-empty{color:var(--text-muted);font-size:13px;padding:12px 10px}.search-item{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--text);display:flex;font-size:13px;gap:8px;padding:7px 8px;text-align:left;width:100%}.search-item:hover{background:var(--surface2)}.search-item-icon{flex:0 0 auto;font-size:13px}.search-item-text{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-item-sub{color:var(--text-muted);font-weight:400}.sidebar-collapse-toggle{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);display:flex;font-size:13px;font-weight:500;gap:10px;margin:4px 12px 0;padding:10px 12px}.sidebar-collapse-toggle:hover{background:var(--surface2);color:var(--text)}.collapse-chevron{flex:0 0 auto;font-size:15px;font-weight:700;text-align:center;width:18px}.app-layout.sidebar-collapsed .sidebar{width:64px}.app-layout.sidebar-collapsed .main-content{margin-left:64px}.app-layout.sidebar-collapsed .brand-name,.app-layout.sidebar-collapsed .nav-label,.app-layout.sidebar-collapsed .nav-section-label,.app-layout.sidebar-collapsed .sidebar-footer{display:none}.app-layout.sidebar-collapsed .sidebar-brand{justify-content:center;padding:0 0 20px}.app-layout.sidebar-collapsed .nav-link,.app-layout.sidebar-collapsed .sidebar-collapse-toggle{justify-content:center;padding:10px}.app-layout.sidebar-collapsed .nav-link.active:before{display:none}.app-layout.sidebar-collapsed .nav-badge{position:absolute;right:6px;top:4px}@keyframes flashHighlight{0%{box-shadow:0 0 0 3px var(--accent)}to{box-shadow:0 0 0 0 #0000}}.flash-highlight{animation:flashHighlight 1.6s ease-out}.main-content{flex:1 1;margin-left:220px;max-width:1400px;padding:32px 40px}.timer-bar{align-items:center;background:var(--green-dim);border-bottom:1px solid var(--green);color:var(--green);display:flex;font-size:13px;gap:12px;margin:-32px -40px 24px;padding:12px 40px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.timer-bar-dot{animation:timer-pulse 1.6s infinite;background:var(--green);border-radius:50%;box-shadow:0 0 0 0 var(--green);height:9px;width:9px}@keyframes timer-pulse{0%{box-shadow:0 0 0 0 #22c55e80}70%{box-shadow:0 0 0 7px #22c55e00}to{box-shadow:0 0 0 0 #22c55e00}}.timer-bar-label,.timer-bar-time{color:var(--text)}.timer-bar-time{font-feature-settings:"tnum";font-size:15px;font-variant-numeric:tabular-nums;font-weight:700;margin-left:auto}.timer-bar-stop{background:var(--green);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:5px 12px}.timer-bar-stop:hover{filter:brightness(.95)}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:28px}.page-title{color:var(--text);font-size:28px;font-weight:600;letter-spacing:-.01em}.page-subtitle{color:var(--text-muted);font-size:13px;margin-top:3px}.kpi-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));margin-bottom:24px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:7px;padding:16px 18px;transition:box-shadow .15s,transform .15s,border-color .15s}.kpi-card.clickable{cursor:pointer}.kpi-card.clickable:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}.kpi-card.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.kpi-num{color:var(--text);font-size:26px;font-weight:600;letter-spacing:-.01em;line-height:1}.kpi-label{color:var(--text-muted);font-size:12px;font-weight:600}.kpi-icon{font-size:13px}.kpi-card.alert .kpi-num{color:var(--red)}.kpi-card.warn .kpi-num{color:var(--orange)}.kpi-card.info .kpi-num{color:var(--blue)}.kpi-card.good .kpi-num{color:var(--green)}.kpi-card.bank .kpi-num{color:var(--client-tag)}.btn{align-items:center;border:none;border-radius:var(--radius-sm);display:inline-flex;font-size:13px;font-weight:600;gap:7px;padding:9px 16px;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light)}.btn-ghost{background:#0000;border:1px solid var(--border);color:var(--text-muted)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--red-dim);border:1px solid #0000;color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-sm{font-size:12px;padding:6px 10px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.card-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:600;letter-spacing:0;padding:3px 10px}.badge-recurrence{background:var(--accent-dim);color:var(--accent-light)}.badge-client-task{background:var(--client-tag-dim);color:var(--client-tag)}.badge-oneoff{background:var(--surface2);color:var(--text-muted)}.badge-carried{background:var(--orange-dim);color:var(--orange)}.badge-not_started{background:var(--surface2);color:var(--text-muted)}.badge-in_progress{background:var(--blue-dim);color:var(--blue)}.badge-waiting_for_client{background:var(--orange-dim);color:var(--orange)}.badge-complete,.badge-priority-low{background:var(--green-dim);color:var(--green)}.badge-priority-medium{background:var(--surface2);color:var(--text-muted)}.badge-priority-high{background:var(--orange-dim);color:var(--orange)}.badge-priority-critical{background:var(--red-dim);color:var(--red)}.priority-select{background:var(--bg);border:1px solid var(--border);border-radius:12px;color:var(--text-muted);cursor:pointer;font-size:11px;padding:3px 8px}.priority-select:focus{border-color:var(--accent);outline:none}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 32px #1018282e;max-height:90vh;max-width:560px;overflow-y:auto;padding:28px;width:100%}.modal-title{font-size:17px;font-weight:700;margin-bottom:22px}.modal-footer{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px}.form-group{margin-bottom:16px}.form-label{color:var(--text-muted);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:7px;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;padding:9px 12px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);outline:none}.form-select{-webkit-appearance:none;appearance:none;cursor:pointer}.form-textarea{min-height:80px;resize:vertical}.task-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.task-row{align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;gap:8px;padding:8px 10px}.task-row input[type=text]{background:#0000;border:none;color:var(--text);flex:1 1;font-size:13px}.task-row input[type=text]:focus{outline:none}.task-client-toggle{align-items:center;background:#0000;border:1px solid var(--border);border-radius:12px;color:var(--text-muted);cursor:pointer;display:flex;font-size:11px;gap:5px;padding:3px 7px;transition:all .15s;white-space:nowrap}.task-client-toggle.active{background:var(--client-tag-dim);border-color:var(--client-tag);color:var(--client-tag)}.task-remove{background:none;border:none;border-radius:4px;color:var(--text-muted);font-size:16px;padding:2px 4px;transition:color .15s}.task-remove:hover{color:var(--red)}.work-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:border-color .15s}.work-card:hover{border-color:var(--accent)}.work-card-header{align-items:flex-start;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 20px}.work-card-title{font-size:15px;font-weight:600;margin-bottom:4px}.work-card-meta{align-items:center;color:var(--text-muted);display:flex;font-size:12px;gap:10px}.work-card-actions{align-items:center;display:flex;gap:6px}.work-avatar{align-items:center;border-radius:50%;display:flex;flex:0 0 auto;font-size:12px;font-weight:700;height:34px;justify-content:center;letter-spacing:.02em;-webkit-user-select:none;user-select:none;width:34px}.due-pill{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:2px 8px}.due-pill.overdue{background:var(--red-dim);color:var(--red)}.due-pill.due-soon{background:var(--orange-dim);color:var(--orange)}.due-pill.on-track{background:var(--green-dim);color:var(--green)}.kebab-wrap{position:relative}.kebab-btn{align-items:center;background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);display:flex;font-size:18px;height:30px;justify-content:center;line-height:1;transition:background .15s,border-color .15s;width:30px}.kebab-btn:hover{background:var(--surface2);color:var(--text)}.kebab-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);display:flex;flex-direction:column;min-width:168px;padding:4px;position:absolute;right:0;top:calc(100% + 4px);z-index:20}.kebab-menu button{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--text);display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 10px;text-align:left}.kebab-menu button:hover{background:var(--surface2)}.kebab-menu button.danger{color:var(--red)}.kebab-menu button.danger:hover{background:var(--red-dim)}.work-task-delete{color:var(--red)}.work-task-delete:hover{background:var(--red-dim);border-color:var(--red)}.md-editor{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.md-editor:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.md-editor-area{background:#0000;border:none;color:var(--text);display:block;font-family:inherit;line-height:1.5;outline:none;resize:vertical;width:100%}.md-editor-area,.md-editor-preview{font-size:13px;min-height:150px;padding:10px 12px}.md-editor-preview{max-height:360px;overflow:auto}.md-editor-toolbar{align-items:center;background:var(--surface2);border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:2px;padding:5px 6px}.md-tool-btn{background:#0000;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:13px;min-width:30px;padding:5px 8px}.md-tool-btn:hover{background:var(--surface);color:var(--text)}.md-tool-spacer{flex:1 1}.markdown{font-size:inherit;line-height:1.5}.markdown>:first-child{margin-top:0}.markdown>:last-child{margin-bottom:0}.markdown .md-p{margin:6px 0}.markdown .md-h{color:var(--text);font-weight:700;line-height:1.3;margin:10px 0 4px}.markdown .md-h1{font-size:1.15em}.markdown .md-h2{font-size:1.08em}.markdown .md-h3{font-size:1em}.markdown .md-h4{color:var(--text-muted);font-size:.95em;letter-spacing:.03em;text-transform:uppercase}.markdown .md-list{margin:6px 0;padding-left:20px}.markdown .md-list .md-list,.markdown .md-list li{margin:2px 0}.markdown code{background:var(--surface2);border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;padding:1px 5px}.markdown a{color:var(--blue);text-decoration:underline}.markdown strong{font-weight:700}.attach-modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 12px 40px #10182838;display:flex;flex-direction:column;height:min(88vh,1000px);overflow:hidden;width:min(900px,94vw)}.attach-modal-head{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:12px;justify-content:space-between;padding:12px 14px}.attach-modal-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-modal-body{align-items:center;background:var(--surface2);display:flex;flex:1 1;justify-content:center;min-height:0}.attach-modal-body img{max-height:100%;max-width:100%;object-fit:contain}.attach-modal-body iframe{background:#fff;border:none;height:100%;width:100%}.attach-modal-fallback{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-size:14px;gap:12px;text-align:center}.timeline-row{align-items:flex-start;display:flex;gap:10px;padding:10px 12px}.timeline-row+.timeline-row{border-top:1px solid var(--border)}.timeline-icon{flex:0 0 auto;font-size:14px;line-height:1.4}.timeline-summary{font-size:13px;font-weight:600}.timeline-detail{color:var(--text-muted);font-size:12px;margin-top:2px}.timeline-when{color:var(--text-muted);flex:0 0 auto;font-size:11px;white-space:nowrap}.doc-row{align-items:center;border-radius:var(--radius-sm);display:flex;gap:12px;justify-content:space-between;padding:9px 12px}.doc-row:hover{background:var(--surface2)}.doc-row+.doc-row{border-top:1px solid var(--border)}.doc-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-meta{color:var(--text-muted);font-size:11px;margin-top:1px}.client-tabs{border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px}.client-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--text-muted);font-size:13px;font-weight:600;margin-bottom:-1px;padding:10px 14px;transition:color .15s,border-color .15s}.client-tab:hover{color:var(--text)}.client-tab.active{border-bottom-color:var(--accent);color:var(--accent)}.client-row:hover{box-shadow:var(--shadow-hover)}.badge-review{color:var(--orange)}.badge-review,.task-group-count.review,.work-task-item.review{background:var(--orange-dim)}.task-group-count.review{color:var(--orange)}.task-group-label{align-items:center;color:var(--text-muted);display:flex;font-size:11px;font-weight:700;gap:8px;letter-spacing:.04em;padding:12px 20px 4px;text-transform:uppercase}.task-group-label:first-child{padding-top:6px}.task-group-count{background:var(--surface2);border-radius:20px;color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:0;padding:1px 8px;text-transform:none}.task-drag-handle{align-self:center;color:var(--text-muted);cursor:grab;font-size:14px;line-height:1;opacity:.35;padding:0 2px;transition:opacity .15s;-webkit-user-select:none;user-select:none}.work-task-wrap:hover .task-drag-handle{opacity:.7}.task-drag-handle:hover{opacity:1}.task-drag-handle:active{cursor:grabbing}.work-task-wrap.dragging{opacity:.45}.month-end-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin:12px 20px 0;padding:12px 14px}.month-end-title{align-items:center;color:var(--text-muted);display:flex;font-size:11px;font-weight:700;justify-content:space-between;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.month-end-count{color:var(--text);font-weight:600;letter-spacing:0;text-transform:none}.month-end-hint{color:var(--orange);font-size:12px;margin-bottom:8px}.month-end-row{align-items:center;border-bottom:1px solid var(--border);display:flex;font-size:13px;justify-content:space-between;padding:7px 0}.month-end-row:last-child{border-bottom:none}.month-end-name{color:var(--text);font-weight:600}.month-end-status{align-items:center;display:flex;gap:10px}.month-end-missing,.month-end-progress{color:var(--text-muted);font-size:12px}.month-end-missing{font-style:italic}.recon-row{align-items:center;border-bottom:1px solid var(--border);display:flex;font-size:13px;justify-content:space-between;padding:7px 0}.recon-row:last-child{border-bottom:none}.recon-row-label{color:var(--text)}.recon-status{font-size:12px;font-weight:600}.recon-status.recon-done{color:var(--green)}.recon-status.recon-partial{color:var(--orange)}.recon-status.recon-none{color:var(--text-muted)}.recon-direction{margin-top:14px}.recon-direction:first-of-type{margin-top:6px}.recon-direction-head{font-size:12px;font-weight:800;letter-spacing:.02em;padding:4px 0 8px;text-transform:uppercase}.recon-direction-in{color:var(--green)}.recon-direction-out{color:var(--text-muted)}.recon-summary-link{cursor:pointer;transition:border-color .15s,background .15s}.recon-summary-link:hover{background:var(--surface2);border-color:var(--accent)}.recon-summary-link:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.recon-summary .month-end-title{align-items:center;display:flex;justify-content:space-between}.recon-summary-open{color:var(--accent);font-size:11px;font-weight:700;white-space:nowrap}.recon-card-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.recon-name{color:var(--text);font-size:15px;font-weight:700}.recon-saved{color:var(--green);font-size:12px;font-weight:600}.recon-fields{display:flex;flex-wrap:wrap;gap:16px}.recon-field{flex:1 1 220px}.recon-notify-row{align-items:center;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;padding-top:12px}.recon-last-notified{color:var(--text-muted);font-size:12px}.recon-quarter{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;padding:14px}.recon-quarter:last-child{margin-bottom:0}.recon-quarter.overdue{background:var(--red-dim);border-color:var(--red)}.recon-quarter.recon-focus{animation:recon-focus-pulse 2.6s ease-out}@keyframes recon-focus-pulse{0%,30%{border-color:var(--accent);box-shadow:0 0 0 3px #5082ff40;box-shadow:0 0 0 3px var(--accent-dim,#5082ff40)}to{box-shadow:0 0 0 0 #0000}}.recon-quarter-head{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.recon-quarter-label{color:var(--text);font-size:14px;font-weight:700}.recon-lines{margin:12px 0}.recon-lines-head{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}.recon-lines-count{color:var(--text-muted);font-size:12px}.recon-lines-msg{color:var(--green);font-size:12px}.recon-lines-empty{border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;line-height:1.5}.recon-lines-empty,.recon-report{background:var(--surface2);padding:12px}.recon-report{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px}.recon-report-summary{color:var(--green);font-size:13px;font-weight:600;margin-bottom:8px}.recon-report-quarters{color:var(--text-muted);font-size:12px;margin-bottom:8px}.recon-answered-list{list-style:none;margin:6px 0 0;padding:0}.recon-answered-item{border-top:1px solid var(--border);padding:8px 0}.recon-answered-item:first-child{border-top:none}.recon-answered-label{font-size:12px;font-weight:600}.recon-answered-reply{color:var(--text-muted);font-size:12px;font-style:italic;margin:2px 0 6px}.recon-answered-actions{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.recon-answered-actions .recon-line-note{flex:1 1 200px}.recon-answered-status{color:var(--green);font-size:12px;font-weight:700}.bank-acct-badge{border-radius:999px;font-size:11px;font-weight:700;padding:2px 9px;white-space:nowrap}.bank-acct-badge.approved{background:var(--green-dim);color:var(--green)}.bank-acct-badge.pending{background:var(--orange-dim);color:var(--orange)}.client-bank-acct{padding:2px 0}.client-bank-addname{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;font-weight:600;padding:0;text-align:left}.client-bank-addname:hover{text-decoration:underline}.client-bank-aliases{align-items:center;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:11px;gap:6px;margin:2px 0 0 4px}.client-bank-alias{align-items:center;background:var(--surface2);border-radius:999px;display:inline-flex;gap:4px;padding:1px 8px}.client-bank-alias-x{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;line-height:1;padding:0}.client-bank-alias-x:hover{color:var(--red)}.client-bank-link{margin:4px 0 0 4px}.client-bank-link select{font-size:12px;max-width:320px}.recon-account-raw{color:var(--text-muted);font-size:12px;font-weight:400}.coded-archive{border-top:1px dashed var(--border);margin-top:12px;padding-top:10px}.coded-archive-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:700;padding:4px 0}.coded-archive-toggle:hover{color:var(--text)}.coded-archive-q{margin-top:8px}.coded-archive-qlabel{color:var(--text-muted);font-size:11px;font-weight:800;letter-spacing:.02em;margin:6px 0 4px;text-transform:uppercase}.coded-archive-line{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;padding:8px 10px}.coded-archive-top{align-items:center;display:flex;flex-wrap:wrap;font-size:13px;gap:10px}.coded-archive-acct{color:var(--text-muted);font-size:11px}.coded-archive-top .recon-line-desc{flex:1 1}.coded-archive-top .btn,.nav-badge{margin-left:auto}.nav-badge{align-items:center;background:var(--orange);border-radius:999px;color:#fff;display:inline-flex;font-size:11px;font-weight:800;height:18px;justify-content:center;min-width:18px;padding:0 5px}.recon-warn{border-radius:8px;font-size:12px;line-height:1.5;margin-top:8px;padding:9px 11px}.recon-warn.warn{background:var(--red-dim);color:var(--text)}.recon-warn.warn strong{color:var(--red)}.recon-warn.info{background:var(--orange-dim);color:var(--text)}.recon-warn.info strong{color:var(--orange)}.recon-warn ul{margin:6px 0 0;padding-left:18px}.recon-warn li{margin:2px 0}.recon-report-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;margin-top:10px;padding:0;text-decoration:underline}.recon-report-dismiss:hover{color:var(--text)}.recon-account{margin-top:10px}.recon-account-head{color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:.03em;margin-bottom:4px;text-transform:uppercase}.recon-line,.recon-line-table{display:flex;flex-direction:column}.recon-line{border-top:1px solid var(--border);font-size:13px;gap:6px;padding:9px 0}.recon-line-top{align-items:center;display:flex;gap:10px}.recon-line.coded{opacity:.5}.recon-line.coded .recon-line-desc strong{text-decoration:line-through}.recon-line-date{color:var(--text-muted);min-width:76px;white-space:nowrap}.recon-line-desc{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recon-line-ref{color:var(--text-muted);font-weight:400}.recon-line-amt{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600;min-width:92px;text-align:right;white-space:nowrap}.recon-line-amt.in{color:var(--green)}.recon-line-amt.out{color:var(--text)}.recon-line-note{box-sizing:border-box;width:calc(100% - 28px)}.recon-line-answer,.recon-line-note{font-size:12px;margin-left:28px;padding:6px 9px}.recon-line-answer{background:var(--green-dim);border-radius:6px;color:var(--text)}.recon-line-answer strong{color:var(--green)}.recon-thread{display:flex;flex-direction:column;gap:5px;margin-left:28px}.recon-msg{border-radius:6px;color:var(--text);font-size:12px;padding:6px 9px}.recon-msg-staff{background:var(--surface2)}.recon-msg-client{background:var(--green-dim)}.recon-msg-client strong{color:var(--green)}.recon-receipt-dl{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--accent);cursor:pointer;display:inline-block;font-size:11px;font-weight:600;margin-left:8px;padding:2px 8px;text-decoration:none}.recon-receipt-dl:hover{border-color:var(--accent)}.recon-assignee{background:var(--client-tag-dim);border-radius:999px;color:var(--client-tag);font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.recon-client-head{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:12px}.client-contacts{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.client-contacts-head{color:var(--text);font-size:12px;font-weight:700;margin-bottom:8px}.client-contact-row{align-items:center;display:flex;font-size:13px;gap:10px;padding:5px 0}.client-contact-name{font-weight:600}.client-contact-del{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0 2px}.client-contact-del:hover{color:var(--red)}.client-contact-add{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.client-contact-add .form-input{flex:1 1;min-width:120px;width:auto}.portal-line-assignee{background:var(--client-tag-dim);border-radius:999px;color:var(--client-tag);font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.portal-reallocate{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.portal-reallocate-label{color:var(--text-muted);font-size:12px}.portal-reallocate-select{flex:1 1;font-size:12px;min-width:160px;padding:6px 9px;width:auto}.recon-ask{align-items:center;display:flex;gap:8px;margin-left:28px}.recon-ask .recon-line-note{flex:1 1;margin-left:0;width:auto}.recon-dext-badge{background:var(--green-dim);border-radius:999px;color:var(--green);font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.recon-line-del{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:17px;line-height:1;padding:0 4px}.recon-line-del:hover{color:var(--red)}.recon-line-link{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--accent);cursor:pointer;font-size:11px;font-weight:600;padding:2px 8px;white-space:nowrap}.recon-line-link:hover{border-color:var(--accent)}.portal-account{margin-bottom:14px}.portal-account-head{color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:.03em;margin:8px 0 4px;text-transform:uppercase}.portal-line{border-top:1px solid var(--border);padding:10px 0}.portal-line.done .portal-line-desc{color:var(--text-muted);text-decoration:line-through}.portal-line.done .portal-line-date{color:var(--text-muted)}.portal-line.done .portal-line-amt{color:var(--text-muted)!important}.portal-line-check{color:var(--green);font-weight:800}.portal-line.collapsed{padding:8px 0}.portal-line-flash{animation:portal-flash 2.2s ease-out;border-radius:8px}@keyframes portal-flash{0%,30%{background:var(--accent-dim);box-shadow:0 0 0 2px var(--accent)}to{background:#0000;box-shadow:0 0 0 2px #0000}}.portal-line-chev{color:var(--text-muted);font-size:11px;margin-left:2px}.portal-line-top{align-items:baseline;display:flex;gap:10px}.portal-line-date{color:var(--text-muted);font-size:12px;white-space:nowrap}.portal-line-desc{flex:1 1;font-size:14px;font-weight:600;min-width:0}.portal-line-amt{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:700;white-space:nowrap}.portal-line-amt.in{color:var(--green)}.portal-line-amt.out{color:var(--text)}.portal-line-ref{color:var(--text-muted);font-size:12px;margin-top:2px}.portal-line-q{color:var(--accent);font-size:13px;font-weight:600;margin-top:8px}.portal-line-q:before{content:"❓ "}.portal-line-note{font-size:13px;margin-top:6px;padding:8px 10px;width:100%}.portal-dext{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-size:13px;font-weight:600;margin-top:8px;padding:7px 12px}.portal-dext:hover{border-color:var(--accent)}.portal-dext.on{background:var(--green-dim);border-color:var(--green);color:var(--green)}.portal-line-handled{align-items:center;color:var(--green);display:flex;flex-wrap:wrap;font-size:13px;font-weight:600;gap:10px;margin-top:8px}.portal-line-answer{color:var(--text);font-weight:500}.portal-line-needs{background:var(--orange-dim);border-radius:999px;color:var(--orange);font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.portal-thread{display:flex;flex-direction:column;gap:8px;margin-top:8px}.portal-msg{border-radius:10px;font-size:13px;max-width:88%;padding:8px 11px}.portal-msg-staff{align-self:flex-start;background:var(--accent-dim)}.portal-msg-client{align-self:flex-end;background:var(--green-dim)}.portal-msg-from{color:var(--text-muted);display:block;font-size:11px;font-weight:700;margin-bottom:2px}.portal-msg-body{color:var(--text);line-height:1.4;white-space:pre-wrap}.portal-reply{margin-top:8px}.portal-reply-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.portal-line-undo{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;padding:0;text-decoration:underline}.portal-line-undo:hover{color:var(--text)}.notice-banner.notice-error{background:var(--red-dim);border-color:var(--red);color:var(--red)}.work-task-list{display:flex;flex-direction:column;gap:6px;padding:12px 20px}.btn.timer-on{border-color:var(--green);color:var(--green)}.time-panel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin:0 20px 14px;padding:12px 14px}.time-panel-head{align-items:center;font-size:13px;gap:10px;justify-content:space-between}.time-entries,.time-panel-head{display:flex;margin-bottom:10px}.time-entries{flex-direction:column;gap:4px}.time-empty{color:var(--text-muted);font-size:12px;font-style:italic}.time-entry{align-items:center;border-bottom:1px solid var(--border);display:flex;font-size:13px;gap:10px;padding:5px 0}.time-entry:last-child{border-bottom:none}.time-entry-mins{font-weight:700;min-width:56px}.time-entry-meta{color:var(--text-muted);flex:1 1;font-size:12px}.time-entry-del{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:15px}.time-entry-del:hover{color:var(--red)}.time-add{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.time-add .time-mins{width:80px}.time-add .time-date{width:150px}.time-add .form-input{flex:1 1 120px}.time-report-row{align-items:center;display:flex;gap:10px;justify-content:space-between;padding:5px 0}.work-add-task-btn{align-self:flex-start;margin-top:4px}.work-task-text{cursor:text}.work-task-text:hover{color:var(--accent-light)}.work-task-instructions{color:var(--text-muted);font-size:12px;line-height:1.45;margin-top:3px;white-space:pre-wrap}.work-task-blocked{color:var(--orange);font-size:12px;font-weight:600;margin-top:3px}.work-task-item.blocked{opacity:.7}.work-task-item.blocked input[type=checkbox]{cursor:not-allowed}.work-task-edit-box{background:var(--bg);border:1px solid var(--accent);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:8px;margin:2px 0;padding:10px}.work-task-edit{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;padding:6px 8px;text-decoration:none;width:100%}.work-task-edit:focus{border-color:var(--accent);outline:none}.work-task-edit-instructions{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:12px;min-height:48px;padding:6px 8px;resize:vertical;width:100%}.work-task-edit-instructions:focus{border-color:var(--accent);outline:none}.work-task-edit-actions{display:flex;gap:8px;justify-content:flex-end}.task-row-group{display:flex;flex-direction:column;gap:6px}.task-instructions-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:12px;min-height:44px;padding:6px 10px;resize:vertical}.task-instructions-input:focus{border-color:var(--accent);outline:none}.task-dep-row{align-items:center;color:var(--text-muted);display:flex;font-size:12px;gap:8px;margin-top:6px}.task-dep-row select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex:1 1;font-size:12px;min-width:0;padding:5px 8px}.task-instructions-text{color:var(--text-muted);font-size:12px;line-height:1.45;margin-top:2px;white-space:pre-wrap}.notice-banner{align-items:center;background:var(--green-dim);border:1px solid var(--green);border-radius:var(--radius-sm);color:var(--green);display:flex;font-size:13px;font-weight:600;gap:12px;justify-content:space-between;margin-bottom:16px;padding:10px 14px}.notice-banner button{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;line-height:1}.task-comments-toggle{background:#0000;border:1px solid var(--border);border-radius:20px;color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:600;padding:2px 10px;white-space:nowrap}.task-comments-toggle:hover{border-color:var(--accent);color:var(--text)}.task-comments-toggle.has-comments{border-color:var(--accent);color:var(--accent-light)}.task-comments{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:8px;margin:4px 0 12px 25px;padding:10px}.task-comments-empty{color:var(--text-muted);font-size:12px;font-style:italic}.comment{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}.comment-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.comment-time{color:var(--text-muted);font-size:11px}.comment-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:15px;line-height:1;padding:0 4px}.comment-remove:hover{color:var(--red)}.comment-body{color:var(--text);font-size:13px;line-height:1.45;white-space:pre-wrap}.comment.from-client{background:var(--client-tag-dim);border-color:var(--client-tag)}.comment-file{color:var(--accent-light);display:inline-block;font-size:13px;font-weight:600;margin-top:6px}.comment-image{border:1px solid var(--border);border-radius:6px;cursor:zoom-in;display:block;margin-top:6px;max-height:150px;max-width:100%}.comment-compose{display:flex;flex-direction:column;gap:8px}.comment-compose textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:13px;min-height:56px;padding:8px;resize:vertical;width:100%}.comment-compose textarea:focus{border-color:var(--accent);outline:none}.comment-compose-actions{align-items:center;display:flex;gap:8px;justify-content:flex-end}.comment-compose-actions label{cursor:pointer}.comment-image-preview{align-self:flex-start;position:relative}.comment-image-preview img{border:1px solid var(--border);border-radius:6px;display:block;max-height:100px}.comment-image-preview .comment-remove{align-items:center;background:#0009;border-radius:50%;color:#fff;display:flex;font-size:14px;height:20px;justify-content:center;position:absolute;right:3px;top:3px;width:20px}.client-portal{align-items:flex-start;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:48px 20px}.client-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 30px #10182814;max-width:560px;padding:32px;width:100%}.client-header{align-items:center;display:flex;gap:14px;margin-bottom:18px}.client-title{color:var(--text);font-size:20px;font-weight:700}.client-sub{color:var(--text-muted);font-size:13px;margin-top:2px}.client-intro{color:var(--text-muted);font-size:14px;line-height:1.5;margin-bottom:16px}.client-due{background:var(--orange-dim);border-radius:20px;color:var(--orange);display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.client-due,.client-progress{margin-bottom:20px}.client-progress-label{color:var(--text-muted);display:flex;font-size:12px;font-weight:600;justify-content:space-between;margin-bottom:6px}.client-progress-bar{background:var(--border);border-radius:999px;height:8px;overflow:hidden}.client-progress-fill{background:var(--green);height:100%;transition:width .4s ease}.client-card.portal-wide{max-width:900px}.portal-welcome{margin-bottom:20px}.portal-welcome-hi{color:var(--text);font-size:20px;font-weight:600;margin-bottom:12px}.portal-stats{display:flex;flex-wrap:wrap;gap:12px}.portal-stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex:1 1 130px;flex-direction:column;gap:2px;min-width:120px;padding:12px 14px}.portal-stat-num{color:var(--text);font-size:26px;font-weight:700;line-height:1}.portal-stat-label{color:var(--text-muted);font-size:12px}.portal-stat.urgent{background:var(--red-dim);border-color:#0000}.portal-stat.urgent .portal-stat-num{color:var(--red)}.portal-stat.done{background:var(--green-dim);border-color:#0000}.portal-stat.done .portal-stat-num{color:var(--green)}.portal-stat.bank{background:var(--blue-dim);border-color:#0000}.portal-stat.bank .portal-stat-num{color:var(--blue)}.portal-stat.clickable{cursor:pointer;transition:box-shadow .15s}.portal-stat.clickable:hover{box-shadow:var(--shadow)}.portal-section-label{color:var(--text);font-size:13px;font-weight:700;margin:18px 0 10px}.portal-bankrec-card{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:14px;margin-bottom:18px;padding:14px 16px;transition:all .15s}.portal-bankrec-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.portal-bankrec-icon{font-size:22px}.portal-bankrec-body{flex:1 1;min-width:0}.portal-bankrec-title{color:var(--text);font-size:14px;font-weight:600}.portal-bankrec-sub{color:var(--text-muted);font-size:12px;margin-top:2px}.portal-bankrec-arrow{color:var(--text-muted);font-size:18px}.portal-dropzone{align-items:center;border:1.5px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:7px 12px}.portal-dropzone.dragover,.portal-dropzone:hover{border-color:var(--accent);color:var(--text)}.portal-dropzone.dragover{background:var(--accent-dim)}.portal-due-badge{border-radius:999px;font-size:11px;font-weight:700;padding:2px 9px;white-space:nowrap}.portal-due-badge.overdue{background:var(--red-dim);color:var(--red)}.portal-due-badge.due-soon{background:var(--orange-dim);color:var(--orange)}.portal-due-badge.ontrack{background:var(--surface2);color:var(--text-muted)}.portal-allclear{padding:36px 16px;text-align:center}.portal-allclear-emoji{font-size:40px}.portal-allclear-title{color:var(--text);font-size:18px;font-weight:600;margin-top:10px}.portal-allclear-sub{color:var(--text-muted);font-size:13px;margin-top:4px}.portal-toast{animation:portal-toast-in .25s ease;background:var(--green);border-radius:999px;bottom:24px;box-shadow:var(--shadow-hover);color:#fff;font-size:14px;font-weight:600;left:50%;padding:12px 20px;position:fixed;transform:translateX(-50%);z-index:100}@keyframes portal-toast-in{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.client-tasks{display:flex;flex-direction:column;gap:10px}.client-task{align-items:flex-start;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:12px;padding:14px;transition:border-color .15s}.client-task:hover{border-color:var(--accent)}.client-task input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;height:18px;margin-top:1px;width:18px}.client-task-title{color:var(--text);font-size:14px;font-weight:600}.client-task-desc{color:var(--text-muted);font-size:13px;line-height:1.45;margin-top:4px;white-space:pre-wrap}.client-task.done .client-task-title{color:var(--text-muted);text-decoration:line-through}.client-empty{color:var(--text-muted);font-size:14px;padding:16px 0}.client-done-banner{background:var(--green-dim);border:1px solid var(--green);border-radius:var(--radius-sm);color:var(--green);font-size:14px;font-weight:600;margin-top:18px;padding:12px;text-align:center}.client-footer{color:var(--text-muted);font-size:11px;margin-top:24px;text-align:center}.portal-direction{margin-bottom:8px}.portal-direction-head{font-size:12px;font-weight:800;letter-spacing:.02em;margin:14px 0 8px;text-transform:uppercase}.portal-direction-in{color:var(--green)}.portal-direction-out{color:var(--text-muted)}.portal-line-prompt{color:var(--text);font-size:13px;font-weight:600;margin-bottom:8px}.portal-link-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;padding:0;text-align:left;text-decoration:underline}.portal-link-btn:hover{color:var(--text)}.portal-login-cta{background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--radius-sm);margin-top:22px;padding:16px}.portal-login-cta-title{color:var(--text);font-size:15px;font-weight:700}.portal-login-cta-sub{color:var(--text-muted);font-size:13px;line-height:1.5;margin:4px 0 12px}.portal-login-cta-row{display:flex;flex-wrap:wrap;gap:8px}.portal-login-cta-row .form-input{flex:1 1 180px}.portal-login-cta-err{color:var(--red);font-size:12px;margin-top:8px}.portal-login-cta.done{background:var(--green-dim);border:1px solid var(--green);border-radius:var(--radius-sm)}.portal-login-cta.done,.portal-other-callout{color:var(--text);font-size:14px;margin-top:22px;padding:14px 16px}.portal-other-callout{align-items:flex-start;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:10px}.portal-work-head{align-items:center;border-bottom:1px solid var(--border);color:var(--text);display:flex;font-size:13px;font-weight:700;gap:10px;justify-content:space-between;margin:0 0 8px;padding-bottom:6px}.portal-work-due{color:var(--orange);font-size:11px;font-weight:600}.client-task-wrap{margin-bottom:10px}.portal-comments{display:flex;flex-direction:column;gap:6px;margin:6px 0 0 30px}.portal-comment{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;padding:8px 10px}.portal-comment.mine{border-color:var(--accent)}.portal-comment-from{color:var(--text-muted);font-size:10px;letter-spacing:.5px;margin-bottom:3px;text-transform:uppercase}.portal-comment-body{line-height:1.45;white-space:pre-wrap}.portal-comment-img{border:1px solid var(--border);border-radius:6px;display:block;margin-top:6px;max-height:140px;max-width:100%}.portal-comment-file{color:var(--accent-light);display:inline-block;font-size:13px;margin-top:4px}.portal-comment-toggle{align-self:flex-start;background:#0000;border:1px solid var(--border);border-radius:20px;color:var(--text-muted);cursor:pointer;font-size:12px;padding:5px 12px}.portal-comment-toggle:hover{border-color:var(--accent);color:var(--text)}.portal-compose{display:flex;flex-direction:column;gap:8px}.portal-compose textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:13px;min-height:52px;padding:8px;resize:vertical;width:100%}.portal-compose textarea:focus{border-color:var(--accent);outline:none}.portal-file-chip{align-items:center;color:var(--text-muted);display:flex;font-size:12px;gap:6px}.portal-file-chip button{background:none;border:none;color:var(--red);cursor:pointer;font-size:15px}.portal-compose-actions{align-items:center;display:flex;gap:8px;justify-content:space-between}.portal-attach-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;padding:7px 12px}.portal-send-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 18px}.portal-send-btn:disabled{cursor:default;opacity:.5}.client-task.task-highlight{animation:taskHighlight 2.4s ease}@keyframes taskHighlight{0%,to{border-color:var(--border);box-shadow:none}15%,60%{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}}.request-client-head{align-items:flex-start;border-bottom:1px solid var(--border);display:flex;gap:12px;justify-content:space-between;margin-bottom:6px;padding-bottom:14px}.request-client-name{color:var(--text);font-size:16px;font-weight:700}.request-client-email{color:var(--text-muted);font-size:12px;margin-top:2px}.request-client-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.request-work{border-bottom:1px solid var(--border);padding:12px 0}.request-work:last-child{border-bottom:none;padding-bottom:0}.request-work-head{justify-content:space-between;margin-bottom:8px}.request-work-head,.request-work-title{align-items:center;display:flex;gap:10px}.request-work-title{color:var(--text);flex-wrap:wrap;font-size:13px;font-weight:600}.request-work-due{color:var(--orange);font-size:11px;font-weight:500}.request-work-meta{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:11px;gap:14px;margin:-2px 0 8px}.request-task-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0 0 0 4px}.request-task-list li{font-size:13px;padding-left:16px;position:relative}.request-task-list li:before{color:var(--text-muted);content:"☐";left:0;position:absolute;top:0}.request-task-title{color:var(--text)}.request-task-desc{color:var(--text-muted);font-size:12px;line-height:1.45;margin-top:2px;white-space:pre-wrap}.work-task-wrap{border-bottom:1px solid var(--border)}.work-task-wrap:last-of-type{border-bottom:none}.work-task-item{align-items:center;display:flex;font-size:13px;gap:10px;padding:6px 0}.work-task-item input[type=checkbox]{accent-color:var(--accent);cursor:pointer;height:15px;width:15px}.work-task-item.done{color:var(--text-muted);text-decoration:line-through}.empty-state{color:var(--text-muted);padding:60px 20px;text-align:center}.empty-state h3{color:var(--text);font-size:16px;margin-bottom:6px}.empty-state p{font-size:14px}.status-select{background:#0000;border:1px solid var(--border);border-radius:20px;color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:600;padding:3px 10px}.mobile-topbar,.sidebar-overlay{display:none}.work-card-meta{flex-wrap:wrap}@media (max-width:768px){.mobile-topbar{align-items:center;background:var(--surface);border-bottom:1px solid var(--border);display:flex;gap:12px;height:54px;left:0;padding:0 14px;position:fixed;right:0;top:0;z-index:60}.hamburger{background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex-shrink:0;font-size:18px;height:40px;line-height:1;width:40px}.mobile-brand{align-items:center;color:var(--text);display:flex;font-size:15px;font-weight:600;gap:8px}.mobile-brand .brand-icon{font-size:11px;height:28px;width:28px}.sidebar{box-shadow:2px 0 18px #00000073;transform:translateX(-100%);transition:transform .22s ease;width:250px;z-index:70}.sidebar.open{transform:translateX(0)}.nav-link{font-size:15px;padding:13px 12px}.sidebar-overlay{background:#0000008c;display:block;inset:0;position:fixed;z-index:65}.main-content{margin-left:0;max-width:100%;padding:70px 14px 16px}.page-header{align-items:stretch;flex-direction:column;gap:12px;margin-bottom:20px}.page-header .btn{align-self:flex-start}.page-title{font-size:20px}.card-grid{grid-template-columns:1fr}.work-card-header{align-items:stretch;flex-direction:column;gap:10px;padding:14px}.work-card-actions{flex-wrap:wrap}.work-card-actions .status-select{flex:1 1 auto}.work-task-list{padding:12px 14px}.month-end-section{margin:12px 14px 0}.modal-overlay{align-items:flex-start;padding:12px}.modal{max-height:calc(100vh - 24px);padding:20px}.request-client-head{align-items:stretch;flex-direction:column;gap:10px}.request-client-actions{justify-content:flex-start}.client-portal{padding:20px 12px}.client-card{padding:22px 18px}.client-task{padding:13px}.client-task input[type=checkbox]{height:22px;width:22px}}@media (max-width:400px){.work-card-actions .btn-sm{padding:6px 8px}.modal{padding:16px}.client-card{padding:18px 14px}}
/*# sourceMappingURL=main.9ed76b15.css.map*/