@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap";:root{--sidebar:#0d2c47;--sidebar-2:#0a233a;--accent:#ffbf12;--bg:#f2f4f8;--card:#fff;--text:#1d2733;--muted:#7a8699;--border:#e6eaf0;--blue-badge-bg:#e7f0fb;--blue-badge-fg:#2563a8;--orange-badge-bg:#fdeede;--orange-badge-fg:#c2691a;--shadow:0 1px 3px #0d2c470f, 0 4px 12px #0d2c470f;--shadow-hover:0 6px 20px #0d2c471f}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Montserrat,system-ui,sans-serif}button{cursor:pointer;font-family:inherit}.app{min-height:100vh;display:flex}.sidebar{background:var(--sidebar);color:#fff;z-index:20;flex-direction:column;width:210px;height:100vh;padding:26px 0;display:flex;position:fixed;top:0;left:0}.logo{border-bottom:1px solid #ffffff14;margin-bottom:18px;padding:0 24px 28px}.logo-main{letter-spacing:1px;font-size:19px;font-weight:800;line-height:1.15}.logo-main span{color:var(--accent)}.logo-sub{letter-spacing:2.5px;color:#ffffff80;margin-top:8px;font-size:9.5px;font-weight:600}.nav{flex-direction:column;gap:4px;padding:0 14px;display:flex}.nav-item{color:#ffffffb8;text-align:left;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;padding:11px 14px;font-size:14px;font-weight:600;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.active{background:var(--accent);color:var(--sidebar)}.nav-icon{font-size:16px}.main{flex:1;max-width:1280px;margin-left:210px;padding:34px 40px 60px}.page-head{justify-content:space-between;align-items:center;margin-bottom:26px;display:flex}.page-title{margin:0;font-size:26px;font-weight:800}.page-sub{color:var(--muted);margin-top:4px;font-size:13px}.btn{border:none;border-radius:10px;padding:10px 18px;font-size:13.5px;font-weight:700;transition:transform .12s,box-shadow .15s,background .15s}.btn-primary{background:var(--accent);color:var(--sidebar)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #ffbf1266}.btn-ghost{color:var(--sidebar);border:1px solid var(--border);background:#fff}.btn-ghost:hover{border-color:var(--accent)}.btn-dark{background:var(--sidebar);color:#fff}.btn-dark:hover{background:var(--sidebar-2)}.back-link{color:var(--muted);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:18px;padding:0;font-size:13px;font-weight:600;display:inline-flex}.back-link:hover{color:var(--sidebar)}.grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px;display:grid}.proj-grid{grid-template-columns:1fr}.card{background:var(--card);box-shadow:var(--shadow);border:1px solid #0000;border-radius:12px;padding:20px;transition:transform .15s,box-shadow .15s;position:relative}.card.clickable{cursor:pointer}.card.clickable:hover{box-shadow:var(--shadow-hover);border-color:var(--border);transform:translateY(-2px)}.proj-top{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.proj-name{margin:0;font-size:17px;font-weight:700}.proj-desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:38px;margin:0 0 14px;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.proj-bottom{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;padding-top:13px;display:flex}.proj-dates{color:var(--muted);font-size:12.5px;font-weight:600}.proj-stats{gap:28px;display:flex}.proj-meta{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:flex-start;gap:10px 28px;padding-top:13px;display:flex}.meta-block{flex-direction:column;gap:2px;display:flex}.meta-val{font-size:15px;font-weight:700}.meta-label{letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-size:10.5px;font-weight:600}.worker-card{text-align:center;flex-direction:column;align-items:center;display:flex}.avatar{background:var(--sidebar);width:56px;height:56px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:12px;font-size:24px;font-weight:800;display:flex}.avatar.lg{width:76px;height:76px;font-size:32px}.worker-name{margin:0 0 2px;font-size:16px;font-weight:700}.worker-rate{color:var(--muted);margin-bottom:14px;font-size:12.5px}.worker-stats{border-top:1px solid var(--border);justify-content:space-around;width:100%;padding-top:13px;display:flex}.detail-head{background:var(--card);box-shadow:var(--shadow);border-radius:14px;margin-bottom:24px;padding:26px;position:relative}.card-edit-btn{background:var(--sidebar);color:#fff;border:none;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s;display:flex}.card-edit-btn:hover{background:var(--sidebar-2)}.section-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.btn-danger{color:#fff;background:#e3342f;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;display:flex}.btn-danger:hover{background:#c92a26}.field select{border:1px solid var(--border);width:100%;color:var(--text);background:#fafbfd;border-radius:9px;padding:11px 13px;font-family:inherit;font-size:14px}.field select:focus{border-color:var(--accent);background:#fff;outline:none}.detail-title{margin:0 0 8px;font-size:24px;font-weight:800}.detail-desc{color:var(--muted);max-width:640px;margin:0 0 12px;font-size:14px;line-height:1.55}.detail-date{color:var(--muted);font-size:12.5px;font-weight:600}.worker-detail-head{align-items:center;gap:20px;display:flex}.worker-detail-head .info{flex:1}.section{margin-bottom:28px}.section-title{letter-spacing:.2px;margin:0 0 14px;font-size:15px;font-weight:700}.pills{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;display:grid}.pill{background:var(--card);box-shadow:var(--shadow);border-radius:12px;padding:18px}.pill-val{margin-bottom:4px;font-size:22px;font-weight:800}.pill-label{letter-spacing:.7px;text-transform:uppercase;color:var(--muted);font-size:10.5px;font-weight:600}.table-wrap{background:var(--card);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}table{border-collapse:collapse;width:100%}thead th{text-align:left;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);background:#fafbfd;padding:13px 18px;font-size:10.5px;font-weight:700}tbody td{border-bottom:1px solid var(--border);padding:14px 18px;font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr.clickable{cursor:pointer}tbody tr.clickable:hover{background:#f8fafc}.td-name{font-weight:600}.td-right,.th-right{text-align:right}.week-nav{align-items:center;gap:12px;display:flex}.week-nav button{border:1px solid var(--border);width:32px;height:32px;color:var(--sidebar);background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.week-nav button:hover:not(:disabled){border-color:var(--accent);background:#fffdf5}.week-nav button:disabled{opacity:.35;cursor:not-allowed}.week-nav .week-name{text-align:center;min-width:96px;font-size:13px;font-weight:700}.week-header{background:var(--sidebar);color:#fff;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.week-header .wh-block{flex-direction:column;gap:3px;display:flex}.week-header .wh-val{font-size:22px;font-weight:800}.week-header .wh-val.accent{color:var(--accent)}.week-header .wh-label{letter-spacing:.8px;text-transform:uppercase;color:#ffffff8c;font-size:10px;font-weight:600}.week-body{background:var(--card);box-shadow:var(--shadow);border-radius:0 0 12px 12px;overflow:hidden}.day-group{border-bottom:1px solid var(--border)}.day-group:last-child{border-bottom:none}.day-head{background:#fafbfd;justify-content:space-between;align-items:center;padding:13px 22px;display:flex}.day-name{font-size:13.5px;font-weight:700}.day-totals{color:var(--muted);gap:18px;font-size:12.5px;font-weight:600;display:flex}.day-totals .strong{color:var(--text)}.entry{border-top:1px solid var(--border);align-items:center;gap:14px;padding:13px 22px;display:flex}.entry-proj{flex:1;min-width:0;font-size:13.5px;font-weight:600}.badges{align-items:center;gap:8px;display:flex}.badge{white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:11.5px;font-weight:700}.badge.in{background:var(--blue-badge-bg);color:var(--blue-badge-fg)}.badge.out{background:var(--orange-badge-bg);color:var(--orange-badge-fg)}.badge.progress{color:#1f9d57;background:#eafaf1}.entry-dur{text-align:right;min-width:56px;font-size:13px;font-weight:700}.arrow{color:var(--muted)}.loading{min-height:100vh;color:var(--muted);justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.empty{background:var(--card);box-shadow:var(--shadow);text-align:center;border-radius:14px;padding:56px 24px}.empty .emoji{margin-bottom:14px;font-size:42px}.empty .empty-title{margin:0 0 6px;font-size:17px;font-weight:700}.empty .empty-msg{color:var(--muted);max-width:360px;margin:0 auto;font-size:13.5px;line-height:1.5}.modal-backdrop{z-index:50;background:#0000006b;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:460px;padding:28px;box-shadow:0 20px 60px #00000040}.modal-title{margin:0 0 20px;font-size:19px;font-weight:800}.field{margin-bottom:16px}.field label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:7px;font-size:12px;font-weight:700;display:block}.field input,.field textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#fafbfd;border-radius:9px;padding:11px 13px;font-family:inherit;font-size:14px;transition:border-color .15s,background .15s}.field input:focus,.field textarea:focus{border-color:var(--accent);background:#fff;outline:none}.field textarea{resize:vertical;min-height:80px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.modal-error{color:#c0392b;background:#fdeaea;border-radius:9px;margin-bottom:16px;padding:10px 13px;font-size:12.5px;font-weight:600}.muted{color:var(--muted)}.toolbar{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:22px;display:flex}.search-input{border:1px solid var(--border);min-width:220px;color:var(--text);box-shadow:var(--shadow);background:#fff;border-radius:10px;flex:1;padding:11px 14px;font-family:inherit;font-size:14px}.search-input:focus{border-color:var(--accent);outline:none}.filter-group{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:10px;padding:3px;display:flex}.filter-btn{color:var(--muted);background:0 0;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.filter-btn:hover{color:var(--sidebar)}.filter-btn.active{background:var(--accent);color:var(--sidebar)}.status-badge{letter-spacing:.3px;white-space:nowrap;border:1.5px solid #0000;border-radius:6px;flex-shrink:0;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.status-badge.progress{border-color:var(--accent);color:#b88600;background:0 0}.status-badge.completed{color:#fff;background:#2f9e57;border-color:#2f9e57}.detail-actions{align-items:center;gap:12px;display:flex;position:absolute;top:18px;right:18px}.detail-head:not(.worker-detail-head) .detail-title{padding-right:160px}.td-icon{white-space:nowrap;text-align:right;width:1%}.icon-btn{border:1px solid var(--border);color:var(--muted);background:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.icon-btn:hover{color:var(--sidebar);border-color:var(--accent);background:#fffdf5}.delete-row{justify-content:flex-start;margin-top:8px;display:flex}.btn-danger.btn-sm,.btn-sm{gap:7px;width:auto;padding:9px 16px;font-size:13px}.modal-confirm{text-align:center;max-width:400px}.modal-confirm .modal-title{text-align:center}.confirm-text{color:var(--text);margin:0 0 4px;font-size:14px;line-height:1.5}.modal-confirm .modal-actions{justify-content:center}.row-highlight td{background:#fff7da;animation:1.6s ease-out flash-row}@keyframes flash-row{0%{background:var(--accent)}to{background:#fff7da}}.worker-row{text-align:left;align-items:center;gap:18px;display:flex}.worker-row-info{min-width:150px}.worker-row-info .worker-name{margin:0 0 2px}.worker-row-info .worker-rate{margin:0}.worker-row-stats{flex-wrap:wrap;gap:30px;margin-left:auto;display:flex}.stepper-card,.donut-card{padding:24px}.stepper{grid-template-columns:repeat(6,1fr);gap:18px 10px;display:grid}@media (width<=960px){.stepper{grid-template-columns:repeat(3,1fr)}}.step{text-align:center;background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:6px 4px;display:flex}.step:hover{background:#f8fafc}.step-dot{border:2px solid var(--border);width:38px;height:38px;color:var(--muted);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .15s;display:flex}.step-label{color:var(--muted);font-size:11px;font-weight:600;line-height:1.25}.step.done .step-dot{background:var(--accent);border-color:var(--accent);color:var(--sidebar)}.step.done .step-label{color:var(--text)}.step.current .step-dot{background:var(--sidebar);border-color:var(--sidebar);color:#fff;box-shadow:0 0 0 4px #0d2c471f}.step.current .step-label{color:var(--sidebar);font-weight:700}.donut-wrap{flex-wrap:wrap;align-items:center;gap:64px;display:flex}.donut-center{fill:var(--muted);font-size:11px;font-weight:600}.donut-center-big{fill:var(--text);font-size:20px;font-weight:800}.donut-legend{flex-direction:column;gap:10px;display:flex}.donut-legend.two-col{grid-template-columns:1fr 1fr;gap:10px 32px;display:grid}.legend-item{align-items:center;gap:10px;font-size:13px;display:flex}.legend-dot{border-radius:3px;flex-shrink:0;width:12px;height:12px}.legend-name{min-width:130px;font-weight:600}.legend-meta{color:var(--muted);font-weight:600}.head-btns{flex-shrink:0;gap:10px;display:flex}.td-caret{color:var(--muted);text-align:center;width:28px;font-size:11px}.expand-row>td{background:#f7f9fc;padding:0}.inner-table{border-collapse:collapse;width:100%}.inner-table thead th{background:#eef2f7}.inner-table td{font-size:12.5px}.subtotal-row td{color:var(--text);background:#fbfcfe;font-weight:700}.badge.manual{color:#5b6675;background:#eef0f4}.month-list{flex-direction:column;gap:10px;display:flex}.month-row{background:var(--card);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}.month-head{background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:15px 20px;font-family:inherit;display:flex}.month-head:hover{background:#f8fafc}.month-caret{color:var(--muted);font-size:12px}.month-label{font-size:14px;font-weight:700}.month-meta{color:var(--muted);margin-left:auto;font-size:13px;font-weight:700}.month-row .week-body{box-shadow:none;border-top:1px solid var(--border);border-radius:0}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:auto;padding:16px 14px 0}.logout-link{color:#ffffff8c;text-align:left;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s;display:flex}.logout-link:hover{color:#fff;background:#ffffff0f}.step.readonly{cursor:default}.step.readonly:hover{background:0 0}.copy-row{gap:8px;display:flex}.copy-row input{color:var(--muted);flex:1;font-size:12.5px}.copy-row .btn{flex-shrink:0}.login-screen{background:var(--sidebar);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:380px;padding:34px 30px;box-shadow:0 24px 70px #00000059}.login-logo{letter-spacing:1px;color:var(--sidebar);text-align:center;font-size:22px;font-weight:800}.login-logo span{color:var(--accent)}.login-sub{text-align:center;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin:8px 0 26px;font-size:11px;font-weight:600}.login-btn{justify-content:center;width:100%;margin-top:6px}.public-screen{background:var(--bg);max-width:760px;min-height:100vh;margin:0 auto;padding:40px 20px 60px}.public-logo{letter-spacing:1px;color:var(--sidebar);text-align:center;margin-bottom:26px;font-size:18px;font-weight:800}.public-logo span{color:var(--accent)}.public-card{background:var(--card);box-shadow:var(--shadow);border-radius:14px;margin-bottom:20px;padding:26px}.public-head{justify-content:space-between;align-items:center;gap:14px;margin-bottom:10px;display:flex}.drawer-backdrop{z-index:60;background:#0000006b;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:#fff;width:33vw;min-width:320px;height:100vh;padding:26px;animation:.22s ease-out drawer-in;overflow-y:auto;box-shadow:-12px 0 40px #0000002e}@keyframes drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px;display:flex}.drawer-eyebrow{letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:4px;font-size:11px;font-weight:700}.drawer-title{margin:0;font-size:20px;font-weight:800}.drawer-close{color:var(--muted);background:0 0;border:none;padding:4px;font-size:18px;line-height:1}.drawer-close:hover{color:var(--text)}.drawer-body{flex-direction:column;display:flex}.drawer-field{border-bottom:1px solid var(--border);flex-direction:column;gap:4px;padding:14px 0;display:flex}.drawer-label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-size:11px;font-weight:700}.drawer-value{color:var(--text);white-space:pre-wrap;font-size:14px}.drawer-actions{gap:10px;margin-top:22px;display:flex}.task-card{flex-direction:column;display:flex}.task-actions{gap:8px;display:flex;position:absolute;top:14px;right:14px}.task-title{margin:0 0 6px;padding-right:80px;font-size:15px;font-weight:700}.task-notes{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 14px;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.task-foot{margin-top:auto}.task-avatars{display:flex}.task-avatar{background:var(--sidebar);width:30px;height:30px;color:var(--accent);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;margin-left:-8px;font-size:13px;font-weight:800;display:flex}.task-avatar:first-child{margin-left:0}.task-unassigned{font-size:12.5px;font-weight:600}.checkbox-list{border:1px solid var(--border);background:#fafbfd;border-radius:9px;flex-direction:column;gap:2px;max-height:200px;padding:6px;display:flex;overflow-y:auto}.checkbox-item{cursor:pointer;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;font-weight:600;display:flex}.checkbox-item:hover{background:#fff}.checkbox-item input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.wb-table{border-collapse:collapse;width:100%}.wb-table td{padding:11px 16px;font-size:12.5px}.wb-table thead th{padding:12px 16px}.wb-day-row>td{padding:0}.wb-day-bar{color:var(--text);background:#eef2f7;justify-content:space-between;align-items:center;padding:9px 16px;font-size:12.5px;font-weight:700;display:flex}.wb-total-row td{color:var(--text);background:#fbfcfe;font-weight:700}.wb-highlight td{background:#dc26261f}.weeks-table td{font-size:13px}.weeks-table .td-icon{color:var(--muted);font-weight:700}.weeks-table tr.clickable:hover .td-icon{color:var(--sidebar)}.step.selected .step-dot{border-color:var(--accent);box-shadow:0 0 0 4px #ffbf1252}.step.selected .step-label{color:var(--sidebar);font-weight:700}.step.readonly.selected{cursor:pointer}.stage-hint{text-align:center;color:var(--muted);margin:16px 0 0;font-size:12px}.client-notes-card{background:#fffdf3;border:1px solid #f3e6bd;border-radius:12px;margin-top:18px;padding:18px 20px}.client-notes-title{color:var(--sidebar);margin:0 0 8px;font-size:14px;font-weight:800}.client-notes-body{color:var(--text);white-space:pre-wrap;margin:0;font-size:13.5px;line-height:1.55}.drawer-current{border-top:1px solid var(--border);margin-top:28px;padding-top:22px}.current-stage-btn{justify-content:center;width:100%}.current-stage-label{text-align:center;color:#1f9d57;background:#eafaf1;border-radius:10px;width:100%;padding:12px;font-size:13.5px;font-weight:700}.step.gray .step-dot{border-color:var(--border);color:var(--muted);background:#fff}.step.outline .step-dot{border-color:var(--accent);color:#b8860b;background:#fff}.step.filled .step-dot{background:var(--accent);border-color:var(--accent);color:var(--sidebar)}.step.active .step-dot{box-shadow:0 0 0 2px #fff,0 0 0 4px #2563eb}.step.active .step-label{color:#2563eb;font-weight:700}.btn-danger-outline{color:#e3342f;background:#fff;border:1.5px solid #e3342f}.btn-danger-outline:hover{background:#fdecec}.drawer-future-msg{text-align:center;color:var(--muted);margin:0;padding:12px;font-size:13px;font-weight:600}.icon-btn-sm{color:var(--muted);background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;padding:4px;display:inline-flex}.icon-btn-sm:hover{color:#e3342f;background:#fdecec}.mat-add{gap:8px;display:flex}.mat-add input{border:1px solid var(--border);background:#fafbfd;border-radius:9px;flex:1;min-width:0;padding:9px 11px;font-family:inherit;font-size:13px}.mat-add input:focus{border-color:var(--accent);background:#fff;outline:none}.mat-list{flex-direction:column;gap:2px;margin-top:10px;display:flex}.mat-row{border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;display:flex}.mat-row:hover{background:#f8fafc}.mat-link{color:var(--blue-badge-fg);font-weight:600;text-decoration:none}.mat-link:hover{text-decoration:underline}.cn-row{border:1px solid var(--border);background:#fff;border-radius:9px;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;padding:9px 10px;display:flex}.cn-content{white-space:pre-wrap;font-size:13.5px;line-height:1.45}.cn-actions{flex-shrink:0;gap:4px;display:flex}.cn-edit{gap:8px;margin-bottom:8px;display:flex}.cn-edit input{border:1px solid var(--border);background:#fafbfd;border-radius:9px;flex:1;min-width:0;padding:9px 11px;font-family:inherit;font-size:13px}.cn-edit input:focus{border-color:var(--accent);background:#fff;outline:none}.unread-dot{vertical-align:middle;background:#e3342f;border-radius:50%;width:9px;height:9px;margin-left:8px;display:inline-block}.msg-card{padding:0;overflow:hidden}.msg-tabs{border-bottom:1px solid var(--border);background:#fafbfd;flex-wrap:wrap;gap:4px;padding:12px 14px;display:flex}.msg-tab{border:1px solid var(--border);color:var(--muted);background:#fff;border-radius:8px;align-items:center;gap:7px;padding:7px 13px;font-size:12.5px;font-weight:700;display:inline-flex}.msg-tab:hover{color:var(--sidebar)}.msg-tab.active{background:var(--sidebar);color:#fff;border-color:var(--sidebar)}.msg-tab-badge{color:#fff;background:#e3342f;border-radius:9px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 5px;font-size:10.5px;font-weight:800;display:inline-flex}.msg-thread{flex-direction:column;gap:12px;max-height:420px;padding:20px;display:flex;overflow-y:auto}.msg{display:flex}.msg.admin{justify-content:flex-start}.msg.client{justify-content:flex-end}.msg-bubble{border-radius:14px;max-width:76%;padding:10px 14px}.msg.admin .msg-bubble{background:var(--sidebar);color:#fff;border-bottom-left-radius:4px}.msg.client .msg-bubble{background:var(--accent);color:var(--sidebar);border-bottom-right-radius:4px}.msg-author{letter-spacing:.3px;text-transform:uppercase;opacity:.75;margin-bottom:3px;font-size:10.5px;font-weight:800}.msg-content{white-space:pre-wrap;font-size:13.5px;line-height:1.45}.msg-time{opacity:.65;margin-top:5px;font-size:10.5px}.msg-empty{text-align:center;color:var(--muted);margin:0;padding:28px 20px;font-size:13px}.msg-composer{border-top:1px solid var(--border);align-items:flex-end;gap:10px;padding:14px;display:flex}.msg-composer textarea{border:1px solid var(--border);resize:vertical;background:#fafbfd;border-radius:10px;flex:1;min-height:44px;padding:10px 12px;font-family:inherit;font-size:13.5px}.msg-composer textarea:focus{border-color:var(--accent);background:#fff;outline:none}.msg-composer .btn{flex-shrink:0}.public-discussion{border-top:1px solid var(--border);margin-top:18px;padding-top:16px}.public-discussion .msg-thread,.public-card>.msg-thread{padding:4px 0 12px}.public-discussion .msg-composer,.public-card>.msg-composer{border-top:none;padding:0}.mobile-topbar,.tabbar,.logo-mono{display:none}@keyframes page-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:none}}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes modal-pop{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:none}}@keyframes backdrop-fade{0%{opacity:0}to{opacity:1}}@keyframes badge-fade{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}@media (width>=768px) and (width<=1023px){.sidebar{width:64px;padding:20px 0}.logo{text-align:center;padding:0 0 18px}.logo-main,.logo-sub{display:none}.logo-mono{letter-spacing:1px;color:var(--accent);text-align:center;font-size:20px;font-weight:800;display:block}.nav{padding:0 10px}.nav-item,.logout-link{justify-content:center;gap:0;padding:13px 0;position:relative}.nav-label{display:none}.sidebar-footer{padding:16px 10px 0}.nav-item:after,.logout-link:after{content:attr(data-tip);background:var(--sidebar-2);color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:60;box-shadow:var(--shadow);border-radius:7px;margin-left:12px;padding:6px 10px;font-size:12px;font-weight:600;transition:opacity .15s;position:absolute;top:50%;left:100%;transform:translateY(-50%)}.nav-item:hover:after,.logout-link:hover:after{opacity:1}.main{max-width:none;margin-left:64px;padding:28px 28px 44px}.proj-grid{grid-template-columns:repeat(2,1fr)}.page-anim{animation:.22s ease-out page-in}.modal{max-width:520px;animation:.25s ease-out modal-pop}.status-badge{animation:.3s badge-fade}.card{transition:transform .1s,box-shadow .15s}.card.clickable:active{transform:scale(.98)}}@media (width<=767px){.app{display:block}.sidebar{display:none}.mobile-topbar{background:var(--sidebar);color:#fff;z-index:45;justify-content:space-between;align-items:center;height:52px;padding:0 12px;display:flex;position:sticky;top:0}.mtb-logo{letter-spacing:1.2px;color:var(--accent);font-size:14px;font-weight:800}.mtb-logo span{opacity:.85}.mtb-btn{color:#fff;background:0 0;border:none;align-items:center;gap:3px;min-height:44px;padding:0 6px;font-size:14px;font-weight:700;display:inline-flex}.mtb-chevron{color:var(--accent);font-size:24px;line-height:1}.mtb-icon{font-size:18px}.tabbar{background:var(--sidebar);z-index:45;height:64px;padding-bottom:env(safe-area-inset-bottom);display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 14px #0000002e}.tabbar-item{color:#fff6;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;transition:color .2s;display:flex;position:relative}.tabbar-icon{line-height:1;display:flex}.tabbar-label{font-size:10px;font-weight:600}.tabbar-dot{background:0 0;border-radius:50%;width:5px;height:5px;transition:background .2s,transform .2s;position:absolute;top:7px}.tabbar-item.active{color:var(--accent)}.tabbar-item.active .tabbar-dot{background:var(--accent)}.main{max-width:none;margin-left:0;padding:16px 16px 80px}.page-anim{animation:.22s ease-out page-in}.page-head{flex-wrap:wrap;gap:12px}.grid,.proj-grid{grid-template-columns:1fr}.card{padding:16px;transition:transform .1s,box-shadow .15s}.card.clickable:active{transform:scale(.98)}.status-badge{animation:.3s badge-fade}.pills{grid-template-columns:repeat(2,1fr)}.stepper{grid-template-columns:repeat(4,1fr);gap:16px 6px}.step-dot{width:36px;height:36px;font-size:13px}.stepper .step-label{display:none}.step.active .step-label,.step.selected .step-label,.step.current .step-label{display:block}.donut-wrap{justify-content:center;gap:22px}.donut-wrap>svg{width:100%;max-width:220px;height:auto}.donut-legend.two-col{grid-template-columns:1fr}.week-body{-webkit-overflow-scrolling:touch;overflow-x:auto}.wb-table{min-width:640px}.wb-table td:first-child,.wb-table th:first-child{z-index:1;background:#fff;position:sticky;left:0}.wb-total-row td:first-child{background:#fbfcfe}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.worker-detail-head{flex-wrap:wrap}.head-btns{width:100%}.head-btns .btn{flex:1}.modal-backdrop{background:#00000080;align-items:flex-end;padding:0;animation:.2s backdrop-fade}.modal{width:100%;max-width:100%;max-height:90vh;padding:26px 18px calc(22px + env(safe-area-inset-bottom));border-radius:20px 20px 0 0;animation:.3s cubic-bezier(.32,.72,0,1) sheet-up;position:relative;overflow-y:auto}.modal:before,.drawer:before{content:"";background:#cfd5dd;border-radius:2px;width:32px;height:4px;position:absolute;top:9px;left:50%;transform:translate(-50%)}.modal-confirm{max-width:100%}.drawer-backdrop{background:#00000080;justify-content:center;align-items:flex-end;animation:.2s backdrop-fade}.drawer{width:100%;min-width:0;height:auto;max-height:90vh;padding:28px 18px calc(22px + env(safe-area-inset-bottom));border-radius:20px 20px 0 0;animation:.3s cubic-bezier(.32,.72,0,1) sheet-up;position:relative}input,textarea,select{font-size:16px!important}.btn,.nav-item,.tabbar-item,.mtb-btn,.filter-btn,.msg-tab{min-height:44px}.msg-bubble{max-width:84%}.toolbar{flex-direction:column;align-items:stretch}.filter-group{justify-content:space-between}}
