:root{--bg: #eceef2;--panel: #fff;--line: #c5cad4;--line-light: #dde1e8;--text: #2a2f3a;--muted: #6b7280;--fill: #e8eaef;--fill-dark: #d4d8e0;--accent: #4a6fa5;--ok: #3d7a52;--warn: #9a6b1a;--danger: #9b3d3d;--radius: 6px;--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);font-size:13px;color:var(--text);background:var(--bg)}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{background:var(--panel);border-bottom:2px solid var(--line);padding:0 16px;height:52px;display:flex;align-items:center;gap:16px;flex-shrink:0}.topbar-brand{font-weight:700;font-size:15px;letter-spacing:.03em;margin-right:8px;white-space:nowrap}.topbar-search{flex:1;max-width:360px;height:32px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill);padding:0 12px;color:var(--muted);display:flex;align-items:center}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:12px}.icon-btn{width:32px;height:32px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill);cursor:default}.user-pill{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:1px dashed var(--line);border-radius:999px;background:var(--fill)}.avatar{width:26px;height:26px;border-radius:50%;background:var(--fill-dark);border:1px solid var(--line)}.shell{flex:1;display:grid;grid-template-columns:220px 1fr;min-height:0}.sidebar{background:var(--panel);border-right:2px solid var(--line);padding:12px 10px;overflow-y:auto}.nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:14px 8px 6px}.nav-btn{display:block;width:100%;text-align:left;padding:9px 10px;margin-bottom:2px;border:1px solid transparent;border-radius:var(--radius);background:none;font:inherit;color:var(--text);cursor:pointer}.nav-btn:hover{background:var(--fill);border-color:var(--line-light)}.nav-btn.active{background:var(--fill);border-color:var(--line);font-weight:600}.main{padding:16px 20px 24px;overflow:auto}.page{display:none}.page.active{display:block}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.page-header h2{margin:0;font-size:20px;font-weight:700}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.btn{padding:7px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);font:inherit;cursor:pointer;color:var(--text)}.btn.primary{background:var(--fill-dark);border-style:solid;font-weight:600}.btn.ghost{border-style:dashed;background:var(--fill)}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}.c3{grid-column:span 3}.c4{grid-column:span 4}.c5{grid-column:span 5}.c6{grid-column:span 6}.c7{grid-column:span 7}.c8{grid-column:span 8}.c12{grid-column:span 12}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px}.panel-title{margin:0 0 10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.kpi-num{font-size:28px;font-weight:700;margin:4px 0 0}.kpi-sub{font-size:11px;color:var(--muted);margin-top:4px}.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;align-items:center}.toolbar .toolbar-spacer{flex:1;min-width:8px}.filter{height:30px;min-width:120px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill);padding:0 10px;color:var(--muted);display:inline-flex;align-items:center;font-size:12px}.filter-select{height:30px;min-width:140px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill);padding:0 28px 0 10px;color:var(--text);font-size:12px;font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 16px) 12px,calc(100% - 11px) 12px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.toolbar-search{flex:1;min-width:200px;max-width:320px;height:30px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--panel);padding:0 10px;font-size:12px;font-family:inherit;color:var(--text)}.toolbar-search::placeholder{color:var(--muted)}.toolbar-search:focus{outline:none;border-color:var(--accent);border-style:solid}table{width:100%;border-collapse:collapse;font-size:12px}th,td{border:1px solid var(--line-light);padding:8px 10px;text-align:left}th{background:var(--fill);font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.03em}tr:nth-child(2n) td{background:#fafbfc}.badge{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;border:1px solid var(--line);background:var(--fill)}.badge.ok{border-color:#a8d4b8;background:#eef7f1;color:var(--ok)}.badge.warn{border-color:#e8d4a8;background:#faf6ee;color:var(--warn)}.badge.danger{border-color:#e8b8b8;background:#faf0f0;color:var(--danger)}.badge.info{border-color:#b8cce8;background:#eef3fa;color:var(--accent)}.kanban{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr));gap:10px;overflow-x:auto;padding-bottom:4px}.kanban-jobs{grid-template-columns:repeat(6,minmax(150px,1fr))}.col{background:var(--fill);border:1px dashed var(--line);border-radius:var(--radius);min-height:320px;padding:8px;display:flex;flex-direction:column}.col-add-job{width:100%;margin-top:auto}.col-head{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--line)}.card-w{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:10px;margin-bottom:8px;cursor:default}.card-w strong{display:block;font-size:12px;margin-bottom:4px}.card-w span{font-size:11px;color:var(--muted)}.card-w-job .card-w-job-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}.card-w-job .card-w-job-head strong{margin-bottom:0;flex:1;min-width:0}.card-w-job-foot{margin-top:8px}.job-payment-badge{display:inline-block;flex-shrink:0;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:var(--radius);line-height:1}.job-payment-badge.paid{background:#eef7f1;color:var(--ok);border:2px solid #a8d4b8}.job-payment-badge.unpaid{background:#faf6ee;color:#9a6b00;border:2px solid #e8c878}.job-payment-badge.unpaid.urgent{background:#faf0f0;color:var(--danger);border-color:#e8b8b8}.job-payment-badge.draft{background:#eef2fb;color:#3a5bbf;border:2px solid #b9c8ee}.job-payment-badge.none{background:var(--fill);color:var(--muted);border:2px solid var(--line)}.job-payment-badge.voided{background:var(--fill);color:var(--muted);border:2px dashed var(--line);text-decoration:line-through}.sla-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle;border:1px solid var(--line)}.sla-dot.green{background:#b8e0c4}.sla-dot.amber{background:#f0dfa0}.sla-dot.red{background:#e8b0b0}.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:12px}.tab{padding:8px 14px;border:1px solid transparent;border-bottom:none;margin-bottom:-1px;font:inherit;background:none;color:var(--muted);cursor:pointer}.tab.on{background:var(--panel);border-color:var(--line);border-bottom-color:var(--panel);color:var(--text);font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field label{display:block;font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:600}.field .input{height:34px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill);width:100%}.field .input.tall{height:72px}.split{display:grid;grid-template-columns:1fr 320px;gap:12px}.calendar{display:grid;gap:1px;background:var(--line-light);border:1px solid var(--line);border-radius:var(--radius);overflow-x:auto}.calendar.calendar-eng-y{grid-template-columns:96px repeat(11,minmax(52px,1fr))}.calendar.calendar-eng-y.cols-days{grid-template-columns:96px repeat(5,minmax(80px,1fr))}.cal-view,.jobs-view{display:none}.cal-view.active,.jobs-view.active{display:block}.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-right:4px}.view-toggle button{border:none;background:var(--panel);padding:6px 12px;font:inherit;font-size:12px;color:var(--muted);cursor:pointer;border-right:1px solid var(--line-light)}.view-toggle button:last-child{border-right:none}.view-toggle button.on{background:var(--fill-dark);color:var(--text);font-weight:600}.cal-cell{background:var(--panel);min-height:44px;padding:4px;font-size:10px;color:var(--muted)}.cal-cell.head{background:var(--fill);font-weight:700;min-height:32px;display:flex;align-items:center;justify-content:center;color:var(--text);font-size:11px}.cal-cell.row-head{background:var(--fill);font-weight:700;font-size:11px;color:var(--text);display:flex;align-items:center;padding:0 8px;border-right:1px solid var(--line-light);min-height:52px}.row-head-inner{display:flex;flex-direction:column;gap:4px;line-height:1.25}.row-head-name{font-weight:700}.row-head-workload{font-size:10px;font-weight:600;color:var(--accent)}.event-title{display:block;font-size:10px;font-weight:700;color:var(--text);line-height:1.3}.event-workload{font-weight:700;color:var(--accent)}.event-sub{display:block;margin-top:2px;font-size:9px;color:var(--muted);line-height:1.25}.cal-cell.row-head.unassigned{background:#faf6ee;color:var(--warn);border-bottom:1px solid #e8d4a8}.cal-cell.slot-unassigned{background:#fdfbf7}.cal-cell.slot{position:relative;min-height:52px}.cal-cell.slot-has-event{padding:3px}.event{background:var(--fill-dark);border:1px solid var(--line);border-radius:3px;padding:3px 5px;font-size:10px;color:var(--text);height:100%;min-height:44px;box-sizing:border-box}.event.event-spanning{border-color:var(--accent);border-left-width:3px;background:linear-gradient(90deg,#eef4fc 0%,var(--fill-dark) 12%)}.event.event-spanning .event-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.month-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line-light);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.month-cal-head{background:var(--fill);font-weight:700;font-size:11px;color:var(--text);text-align:center;padding:6px 4px}.month-cal-cell{background:var(--panel);min-height:92px;padding:4px 4px 6px;display:flex;flex-direction:column;gap:3px}.month-cal-cell.out{background:var(--fill)}.month-cal-cell.today{background:#eef4fc}.month-cal-date{font-size:11px;font-weight:700;color:var(--muted)}.month-cal-cell.today .month-cal-date{color:var(--accent)}.month-event{background:var(--fill-dark);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:3px;padding:2px 5px;line-height:1.25}.month-event strong{display:block;font-size:10px;font-weight:700;color:var(--text)}.month-event span{font-size:9px;color:var(--muted)}.week-list{list-style:none;margin:0;padding:0}.week-day{border-top:1px solid var(--line-light)}.week-day:first-child{border-top:none}.week-day-head{display:flex;align-items:baseline;justify-content:space-between;padding:10px 0 6px}.week-day-name{font-size:12px;font-weight:700;color:var(--text)}.week-day-count{font-size:11px;color:var(--muted)}.week-day-jobs{list-style:none;margin:0 0 8px;padding:0}.week-job{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:12px;padding:6px 8px;border-radius:var(--radius);font-size:12px}.week-job:hover{background:var(--fill)}.week-job-time{font-weight:700;color:var(--accent)}.week-job-main{color:var(--text)}.week-job-meta{font-size:11px;color:var(--muted);text-align:right}.stat-bar{height:8px;background:var(--fill);border-radius:4px;overflow:hidden;margin-top:8px}.stat-bar i{display:block;height:100%;background:var(--fill-dark);border-right:1px solid var(--line)}.login-wrap{max-width:380px;margin:40px auto}.login-wrap .panel{padding:24px}.login-logo{text-align:center;font-weight:700;font-size:18px;margin-bottom:20px;letter-spacing:.05em}.skeleton{height:12px;background:linear-gradient(90deg,var(--fill) 25%,var(--fill-dark) 50%,var(--fill) 75%);background-size:200% 100%;border-radius:3px;margin-top:6px}.timeline-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px dashed var(--line-light);font-size:12px}.timeline-item:last-child{border-bottom:none}.timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--fill-dark);border:1px solid var(--line);margin-top:3px;flex-shrink:0}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#2a2f3a80;align-items:center;justify-content:center;padding:20px}.modal-overlay.open{display:flex}body.modal-open{overflow:hidden}.modal{width:100%;max-width:520px;max-height:calc(100vh - 40px);overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 16px 48px #2a2f3a33}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line-light)}.modal-header h3{margin:0;font-size:16px;font-weight:700}.modal-close{width:32px;height:32px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill);font-size:20px;line-height:1;color:var(--muted);cursor:pointer;padding:0}.modal-body{padding:16px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--line-light);background:var(--fill)}.modal-lg{max-width:720px}.modal-xl{max-width:960px;max-height:calc(100vh - 32px)}.job-detail-body{display:flex;flex-direction:column;gap:16px}.job-detail-summary{display:grid;grid-template-columns:1fr 1fr minmax(220px,.9fr);gap:12px}.job-docs-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.job-activity-panel{border-top:1px solid var(--line-light);padding-top:4px}.job-activity-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.notes-compose-inline{margin-bottom:14px;padding-bottom:14px;border-bottom:1px dashed var(--line-light)}.job-activity-feed{display:flex;flex-direction:column;gap:10px;max-height:280px;overflow-y:auto;padding-right:4px}.job-activity-empty{margin:0;font-size:12px;color:var(--muted);text-align:center;padding:16px 0}.activity-item{display:flex;gap:10px;align-items:flex-start;font-size:12px}.activity-dot{width:10px;height:10px;border-radius:50%;background:var(--fill-dark);border:1px solid var(--line);margin-top:14px;flex-shrink:0}.activity-dot--note{background:#e8eef8;border-color:#9eb4d4}.activity-card{flex:1;min-width:0;background:var(--fill);border:1px solid var(--line-light);border-radius:var(--radius);padding:10px 12px}.activity-card--note{background:#eef3fa;border-color:#c5d4ea}.activity-meta{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:6px}.activity-meta span{color:var(--muted);font-size:11px;white-space:nowrap}.activity-body{margin:0 0 6px;line-height:1.5}.activity-footer{display:flex;justify-content:space-between;align-items:center;gap:8px}.activity-who{font-size:11px;color:var(--muted)}.activity-note-actions{display:flex;gap:4px;flex-shrink:0}.activity-icon-btn{width:28px;height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px dashed var(--line);border-radius:var(--radius);background:var(--panel);color:var(--muted);cursor:pointer}.activity-icon-btn svg{width:14px;height:14px}.activity-icon-btn:hover{border-color:var(--accent);color:var(--text)}.activity-icon-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.activity-icon-btn-primary:hover{color:#fff;opacity:.9}.activity-icon-btn-danger:hover{border-color:var(--danger);color:var(--danger)}.activity-edit-textarea{min-height:56px;margin-bottom:8px}.modal-subtitle{margin:4px 0 0;font-size:12px;color:var(--muted);display:flex;align-items:center;flex-wrap:wrap;gap:6px}.modal-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--line-light);background:var(--fill)}.modal-tabs{margin:0;padding:0 16px;background:var(--panel)}.card-w.clickable{cursor:pointer;transition:border-color .12s,box-shadow .12s}.card-w.clickable:hover{border-color:var(--accent);box-shadow:0 2px 8px #2a2f3a14}.card-w.card-selected{border-color:var(--accent);border-width:2px;background:#f5f8fc}.kanban-quotes{grid-template-columns:repeat(4,minmax(140px,1fr))}tr.row-selected td{background:#eef3fa!important}.esign-panel{max-width:480px}.job-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-rows{display:flex;flex-direction:column;gap:0}.detail-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px dashed var(--line-light);font-size:12px}.detail-row:last-child{border-bottom:none}.detail-row span{color:var(--muted)}.detail-section{margin:14px 0 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.detail-section:first-of-type{margin-top:4px}.job-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}.job-edit-full{grid-column:1 / -1}.job-edit-field{margin-bottom:10px}.job-edit-field label{display:block;margin-bottom:4px;font-size:11px;font-weight:600;color:var(--muted)}.job-edit-input{width:100%;height:32px;padding:0 8px;font:inherit;font-size:12px;color:var(--text);background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}.job-edit-input:focus{outline:none;border-color:var(--accent)}select.job-edit-input{cursor:pointer}.notes-textarea{width:100%;min-height:72px;padding:8px 10px;font:inherit;resize:vertical;border:1px dashed var(--line);border-radius:var(--radius);background:var(--fill)}.note-item{padding:10px 0;border-bottom:1px dashed var(--line-light);font-size:12px}.note-item:last-child{border-bottom:none}.note-meta{display:flex;justify-content:space-between;margin-bottom:4px}.note-meta span{color:var(--muted);font-size:11px}.note-item p{margin:0;line-height:1.5}.doc-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px dashed var(--line-light);font-size:12px}.doc-row:last-child{border-bottom:none}.doc-icon{font-size:18px;line-height:1}.doc-row>div{flex:1}@media (max-width: 960px){.shell{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:2px solid var(--line);display:flex;flex-wrap:wrap;gap:4px;padding:8px}.nav-label{display:none}.nav-btn{width:auto}.kanban{grid-template-columns:repeat(3,minmax(160px,1fr))}.split{grid-template-columns:1fr}.c3,.c4,.c5,.c6,.c7,.c8{grid-column:span 12}.job-detail-grid{grid-template-columns:1fr}}a{color:inherit;text-decoration:none}.field input,.field select,.field textarea{width:100%;height:34px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:0 10px;font:inherit;font-size:13px;color:var(--text)}.field textarea{height:auto;padding:8px 10px}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}.muted{color:var(--muted)}.center{text-align:center}.form-error{color:var(--danger);font-size:12px;margin:8px 0 0}.role-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:8px 0;border-bottom:1px dashed var(--line-light)}.role-row:last-child{border-bottom:none}.role-row .role-desc{font-size:11px;color:var(--muted);margin-top:2px}.role-row strong{font-size:12px}.role-desc{font-size:11px;color:var(--muted);margin-top:2px}.seg-chips{display:flex;flex-wrap:wrap;gap:4px}.seg-chip{display:inline-block;padding:2px 7px;font-size:11px;background:var(--fill);border:1px solid var(--line);border-radius:4px;color:var(--muted)}.worktype-seg-head{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.worktype-seg-table{margin-top:6px}.worktype-seg-table th{background:transparent;border:none;padding:4px 6px}.worktype-seg-table td{border:none;padding:4px 6px;vertical-align:middle}.worktype-seg-table tr:nth-child(2n) td{background:transparent}.worktype-preview{margin-top:14px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--fill)}.work-item-list{display:flex;flex-direction:column;gap:0}.work-item-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px dashed var(--line-light)}.work-item-row:last-child{border-bottom:none}.work-item-main{display:flex;flex-direction:column;gap:2px;min-width:0}.work-item-main strong{font-size:12px}.work-item-sub{font-size:11px;color:var(--muted)}.work-item-controls{display:flex;align-items:center;gap:6px;white-space:nowrap}.work-item-input{height:28px;font-size:12px;padding:0 6px}.work-item-hours-input{width:56px}.work-item-hours{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}
