:root{--bg:#f7faf7;--panel:#fff;--panel-soft:#f2f6f0;--border:#dfe7df;--text:#16211b;--muted:#65736b;--brand:#064525;--brand-2:#0d6b3a;--brand-soft:#dff0e3;--amber:#bc6d1d;--amber-soft:#fff1de;--red:#bd2f2f;--red-soft:#ffe7e4;--blue:#276b8f;--blue-soft:#e3f1f7;--shadow:0 12px 28px #192a1f14}*{box-sizing:border-box;letter-spacing:0}html{background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{min-height:100vh;margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh}.sidebar{background:var(--brand);color:#f6fff8;flex-direction:column;gap:26px;width:254px;height:100vh;padding:30px 18px 22px;display:flex;position:fixed;top:0;left:0}.brand{align-items:center;min-height:48px;padding:0 8px;font-size:2rem;font-weight:800;display:flex}.sidebar-nav{gap:8px;display:grid}.nav-link,.mobile-nav-link{align-items:center;gap:11px;display:flex}.nav-link{color:#ffffffe0;border-radius:8px;min-height:46px;padding:0 12px}.nav-link.active,.nav-link:hover{color:#fff;background:#ffffff1f}.sidebar-footer{border-top:1px solid #ffffff2e;align-items:center;gap:12px;margin-top:auto;padding-top:20px;display:flex}.session-meta{flex:1;min-width:0}.sidebar-footer strong,.sidebar-footer span{display:block}.sidebar-footer span{color:#ffffffb8;margin-top:2px;font-size:.86rem}.avatar{background:#ffffff24;border:1px solid #ffffff52;border-radius:50%;justify-content:center;align-items:center;width:42px;min-width:42px;height:42px;font-weight:800;display:inline-flex}.logout-button{color:#fff;background:#ffffff1a;border:1px solid #ffffff3d;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}.logout-button:hover{background:#ffffff2e}.main-area{min-height:100vh;margin-left:254px;padding:28px 34px 44px}.mobile-header,.mobile-bottom-nav{display:none}.page-header{justify-content:space-between;align-items:flex-start;gap:18px;max-width:1380px;margin:0 auto 24px;display:flex}.page-header h1{color:var(--brand);margin:4px 0 6px;font-size:2rem;line-height:1.15}.page-header p{color:var(--muted);margin:0;font-size:1.02rem}.section-kicker{color:var(--brand-2);align-items:center;gap:7px;font-size:.9rem;font-weight:700;display:flex}.user-switcher{background:var(--panel);border:1px solid var(--border);border-radius:8px;align-items:flex-start;gap:4px;min-width:260px;padding:9px 12px;display:grid}.user-switcher span{color:var(--muted);font-size:.76rem}.user-switcher select{color:var(--text);background:0 0;border:0;outline:0;width:100%;font-weight:700}.space-chip{background:var(--panel);border:1px solid var(--border);border-radius:8px;align-items:flex-start;gap:4px;min-width:220px;padding:11px 13px;display:grid}.space-chip strong{color:var(--brand)}.space-chip span{color:var(--muted);font-size:.86rem}.content{max-width:1380px;margin:0 auto}.grid{gap:16px;display:grid}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.two-column{grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);align-items:start;gap:16px;display:grid}.panel,.stat-card,.list-card,.form-panel{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:8px}.panel,.form-panel{padding:18px}.panel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.panel-header h2,.form-panel h2{color:var(--brand);margin:0;font-size:1.05rem}.panel-header p,.form-panel p{color:var(--muted);margin:4px 0 0}.stat-card{align-items:center;gap:14px;min-height:112px;padding:18px;display:flex}.stat-card span,.stat-card small{color:var(--muted);display:block}.stat-card strong{margin:6px 0;font-size:1.55rem;line-height:1.15;display:block}.stat-icon{border-radius:8px;justify-content:center;align-items:center;width:48px;min-width:48px;height:48px;display:inline-flex}.tone-green{background:var(--brand-soft);color:var(--brand)}.tone-amber{background:var(--amber-soft);color:var(--amber)}.tone-red,.tone-bad{background:var(--red-soft);color:var(--red)}.tone-blue{background:var(--blue-soft);color:var(--blue)}.tone-neutral{background:var(--panel-soft);color:var(--muted)}.tone-good{background:var(--brand-soft);color:var(--brand)}.tone-warn{background:var(--amber-soft);color:var(--amber)}.table-wrap{width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:740px}th,td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:13px 12px}th{color:var(--muted);font-size:.82rem;font-weight:800}td strong{display:block}td small{color:var(--muted)}.badge{white-space:nowrap;border-radius:8px;align-items:center;min-height:28px;padding:0 10px;font-size:.78rem;font-weight:800;line-height:1;display:inline-flex}.status-open,.status-in_progress,.severity-info{background:var(--brand-soft);color:var(--brand)}.status-waiting,.status-draft,.severity-warning{background:var(--amber-soft);color:var(--amber)}.status-closed,.status-archived{background:var(--panel-soft);color:var(--muted)}.status-select-form{margin:0}.status-select{appearance:none;cursor:pointer;font:inherit;white-space:nowrap;background-image:linear-gradient(45deg,#0000 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,#0000 50%);background-position:calc(100% - 14px),calc(100% - 9px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;border:0;border-radius:8px;min-height:28px;padding:0 28px 0 10px;font-size:.78rem;font-weight:800;line-height:1}.status-select:focus{outline:2px solid var(--brand);outline-offset:2px}.status-select option{color:var(--text)}.severity-critical{background:var(--red-soft);color:var(--red)}.pagination-bar{color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:14px;display:flex}.pagination-nav{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pagination-current,.pagination-disabled,.pagination-link{border-radius:8px;align-items:center;min-height:36px;padding:0 12px;font-size:.9rem;font-weight:800;display:inline-flex}.pagination-link{border:1px solid var(--border);color:var(--brand);background:#fff;text-decoration:none}.pagination-link:hover{background:var(--brand-soft)}.pagination-current{background:var(--brand);color:#fff}.pagination-disabled{background:var(--panel-soft);color:var(--muted)}.progress-wrap{gap:7px;min-width:150px;display:grid}.progress-meta{color:var(--muted);justify-content:space-between;align-items:center;font-size:.82rem;display:flex}.progress-meta strong{color:var(--text)}.progress-track{background:#e8ece8;border-radius:999px;height:8px;overflow:hidden}.progress-fill{background:var(--brand);border-radius:inherit;height:100%}.progress-fill.tone-warn{background:var(--amber)}.progress-fill.tone-bad{background:var(--red)}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.form-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr))}.field{gap:6px;display:grid}.field.full{grid-column:1/-1}.field label,.checkbox-field{color:var(--muted);font-size:.84rem;font-weight:800}.field input,.field select,.field textarea{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:8px;width:100%;min-height:44px;padding:10px 12px}.field textarea{resize:vertical;min-height:94px}.checkbox-field{align-items:center;gap:9px;display:flex}.checkbox-field input{width:18px;height:18px}.button-row{flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px;display:flex}.button{border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-weight:800;display:inline-flex}.button.compact-button{min-height:34px;padding:0 10px}.button.primary{background:var(--brand);color:#fff}.button.secondary{border-color:var(--border);color:var(--brand);background:#fff}.button.danger{background:var(--red-soft);color:var(--red)}.link-subtle{color:var(--brand);font-weight:800}.table-primary-link{color:var(--brand);font-weight:900;text-decoration:none}.table-primary-link:hover,.link-subtle:hover{text-decoration:underline}.inline-details summary{color:var(--brand);cursor:pointer;font-weight:900}.details-stack{gap:12px;min-width:240px;margin-top:12px;display:grid}.assignment-grid{background:var(--panel-soft);border:1px solid var(--border);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;display:grid}.assignment-grid.compact-list{grid-template-columns:1fr}.quick-actions{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.quick-actions .button{min-width:150px}.period-picker,.technician-filter{align-items:end;gap:8px;display:flex}.period-picker{align-items:end}.technician-filter{margin-left:auto}.period-picker label,.technician-filter label{color:var(--muted);gap:4px;font-size:.78rem;font-weight:800;display:grid}.period-picker input,.technician-filter select{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:8px;min-width:210px;min-height:42px;padding:0 11px}.timesheet-board{overflow:hidden}.timesheet-toolbar{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px;display:flex}.timesheet-toolbar h2{color:var(--brand);margin:0;font-size:1.18rem}.timesheet-toolbar p{color:var(--muted);margin:4px 0 0}.timesheet-toolbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.timesheet-table{border:2px solid #2d3830;min-width:1180px}.timesheet-table th,.timesheet-table td{border:1px solid #2d3830;padding:8px 9px}.timesheet-table td.timesheet-slot-cell{vertical-align:top;padding:0}.timesheet-table th{color:var(--text);text-align:center;text-transform:uppercase;background:#f3f6f2;font-size:.78rem}.timesheet-date-cell{background:#f7faf7;width:112px}.timesheet-cell-trigger{color:inherit;cursor:pointer;text-align:left;background:0 0;border:0;width:100%;height:100%;min-height:52px;padding:8px 9px;transition:background .15s,box-shadow .15s;display:block}.timesheet-cell-trigger:hover{background:#edf7ef}.timesheet-cell-trigger:focus-visible{box-shadow:inset 0 0 0 2px var(--brand);background:#edf7ef;outline:none}.timesheet-date-cell strong,.timesheet-date-cell small{display:block}.timesheet-cell-stack{gap:6px;min-width:0;display:grid}.timesheet-entry{gap:2px;min-width:0;display:grid}.timesheet-entry strong{color:var(--brand);overflow-wrap:anywhere;line-height:1.2}.timesheet-client-action{color:var(--brand);cursor:pointer;font:inherit;overflow-wrap:anywhere;text-align:left;background:0 0;border:0;justify-content:flex-start;align-items:center;min-height:0;padding:0;font-weight:900;line-height:1.2;display:inline-flex}.timesheet-client-action:hover,.timesheet-time-action:hover,.timesheet-task-action:hover,.timesheet-order-link:hover{text-decoration:underline}.timesheet-time-action,.timesheet-task-action{color:inherit;cursor:pointer;font:inherit;text-align:left;background:0 0;border:0;padding:0}.timesheet-time-action{color:var(--brand);white-space:nowrap;font-weight:900}.timesheet-task-action{overflow-wrap:anywhere}.timesheet-order-row{align-items:center;gap:5px;min-width:0;display:inline-flex}.timesheet-order-link{color:var(--muted);font-weight:500;text-decoration:none}.timesheet-icon-edit{color:var(--brand);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;width:18px;height:18px;padding:0;display:inline-flex}.timesheet-icon-edit:hover{background:var(--brand-soft)}.timesheet-entry span,.timesheet-entry p,.timesheet-task small{color:var(--muted)}.timesheet-entry p{margin:3px 0 0}.timesheet-time{color:var(--brand);white-space:nowrap;font-weight:900}.timesheet-task{color:var(--text);overflow-wrap:anywhere;gap:2px;min-width:220px;display:grid}.timesheet-status{color:var(--brand);text-align:center;min-height:20px;font-weight:900;display:block}.timesheet-empty{color:#98a39c;font-size:.86rem}.timesheet-mobile-slots{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.timesheet-mobile-slots section{background:var(--panel-soft);border:1px solid var(--border);border-radius:8px;gap:8px;padding:0;display:grid;overflow:hidden}.timesheet-mobile-slots .timesheet-cell-trigger{gap:8px;min-height:92px;padding:10px;display:grid}.timesheet-mobile-slots h4{color:var(--brand);margin:0;font-size:.9rem}.icon-button{border:1px solid var(--border);color:var(--brand);background:#fff;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}.icon-button:hover{background:var(--brand-soft)}.wizard-backdrop{z-index:100;background:#16211b6b;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.wizard-dialog{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;max-width:680px;max-height:calc(100vh - 36px);overflow:auto;box-shadow:0 24px 64px #0c19123d}.wizard-form{gap:16px;padding:20px;display:grid}.wizard-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.wizard-header strong{color:var(--brand-2);text-transform:uppercase;font-size:.86rem}.wizard-header h2{color:var(--brand);margin:4px 0 0;font-size:1.4rem}.wizard-stepper{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.wizard-step{background:var(--panel-soft);border:1px solid var(--border);color:var(--muted);border-radius:8px;justify-content:flex-start;align-items:center;gap:8px;min-height:42px;padding:0 10px;font-weight:900;display:flex}.wizard-step span{border:1px solid var(--border);background:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;min-width:24px;height:24px;display:inline-flex}.wizard-step.active,.wizard-step.done{background:var(--brand-soft);color:var(--brand);border-color:#bad9c2}.wizard-body,.wizard-panel{gap:14px;display:grid}.search-field{border:1px solid var(--border);background:#fff;border-radius:8px;align-items:center;gap:8px;min-height:44px;padding:0 11px;display:flex}.search-field svg{color:var(--muted);flex:none}.search-field input,.search-field select{background:0 0;border:0;outline:0;flex:1;width:100%;min-height:42px;padding:0}.or-results{gap:8px;max-height:260px;display:grid;overflow:auto}.or-result{border:1px solid var(--border);text-align:left;background:#fff;border-radius:8px;gap:3px;padding:10px 12px;display:grid}.or-result strong{color:var(--brand)}.or-result span{color:var(--muted)}.or-result.active,.or-result:hover{background:var(--brand-soft);border-color:#b8d8c0}.wizard-hint{background:var(--amber-soft);color:var(--amber);border-radius:8px;margin:0;padding:10px 12px;font-weight:800}.segment-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.segment-option{border:1px solid var(--border);text-align:left;background:#fff;border-radius:8px;gap:4px;min-height:78px;padding:12px;display:grid}.segment-option strong{color:var(--text)}.segment-option span{color:var(--muted);font-size:.84rem}.segment-option.active{background:var(--brand-soft);border-color:#b8d8c0}.segment-option.active strong{color:var(--brand)}.wizard-actions{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding-top:14px;display:flex}.wizard-actions button:disabled{cursor:not-allowed;opacity:.55}.list{gap:10px;display:grid}.list-card{gap:10px;padding:14px;display:grid}.list-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.list-card h3{margin:0 0 3px;font-size:1rem}.list-card p{color:var(--muted);margin:0}.meta-row{color:var(--muted);flex-wrap:wrap;gap:10px;font-size:.86rem;display:flex}.mobile-card-list{display:none}.client-layout{grid-template-columns:330px minmax(0,1fr);align-items:start;gap:16px;display:grid}.detail-layout{grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:16px;margin-bottom:16px;display:grid}.definition-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.definition-grid div,.client-summary{background:var(--panel-soft);border:1px solid var(--border);border-radius:8px;gap:5px;padding:12px;display:grid}.definition-grid span,.client-summary span{color:var(--muted);font-size:.84rem}.definition-grid strong{color:var(--text)}.client-list{gap:8px;margin-top:14px;display:grid}.client-link{border:1px solid var(--border);border-radius:8px;gap:4px;padding:12px;display:grid}.client-link.active,.client-link:hover{background:var(--brand-soft);border-color:#b8d8c0}.client-link span{color:var(--muted);font-size:.86rem}.entry-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.entry-panel{gap:22px;width:100%;max-width:920px;display:grid}.entry-panel strong,.entry-panel h1{color:var(--brand)}.entry-panel h1{margin:6px 0;font-size:2.2rem;line-height:1.1}.entry-panel p{color:var(--muted);margin:0}.entry-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.entry-card{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:8px;gap:10px;min-height:150px;padding:18px;display:grid}.entry-card svg{color:var(--brand)}.entry-card span{color:var(--muted)}.entry-card:hover{border-color:#b8d8c0}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-panel{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:8px;gap:18px;width:100%;max-width:420px;padding:28px;display:grid}.login-mark{background:var(--brand-soft);color:var(--brand);border-radius:8px;justify-content:center;align-items:center;width:54px;height:54px;display:inline-flex}.login-panel strong,.login-panel h1{color:var(--brand)}.login-panel h1{margin:6px 0 0;font-size:1.75rem;line-height:1.15}.login-form{gap:14px;display:grid}.notice{border-radius:8px;margin:0 0 16px;padding:12px 14px;font-weight:800}.notice.success{background:var(--brand-soft);color:var(--brand)}.notice.error{background:var(--red-soft);color:var(--red)}.empty{color:var(--muted);text-align:center;padding:22px 0}.donut{background:radial-gradient(circle at center, #fff 0 53%, transparent 54%), conic-gradient(var(--brand) var(--value), #edf1ed 0);border-radius:50%;place-content:center;place-items:center;width:132px;height:132px;margin:8px auto 16px;display:grid}.donut strong{font-size:1.65rem;display:block}.donut span{color:var(--muted);font-size:.78rem}.split-actions{grid-template-columns:1fr auto;align-items:end;gap:10px;display:grid}.offline-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.offline-panel{border:1px solid var(--border);background:#fff;border-radius:8px;max-width:440px;padding:28px}.offline-panel strong,.offline-panel h1,.offline-panel a{color:var(--brand)}@media (max-width:1320px){.two-column{grid-template-columns:1fr}}@media (max-width:1180px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:820px){.sidebar{display:none}.main-area{margin-left:0;padding:74px 14px 92px}.mobile-header{border-bottom:1px solid var(--border);z-index:20;background:#f7faf7f5;justify-content:space-between;align-items:center;height:58px;padding:0 14px;display:flex;position:fixed;top:0;left:0;right:0}.mobile-brand{color:var(--brand);font-size:1.25rem;font-weight:900}.mobile-header span{color:var(--muted);font-size:.86rem;font-weight:800}.page-header{gap:13px;margin-bottom:16px;display:grid}.page-header h1{font-size:1.55rem}.page-header p{font-size:.96rem}.user-switcher,.space-chip{width:100%;min-width:0}.stats-grid{grid-template-columns:1fr}.stat-card{min-height:92px}.form-grid,.form-grid.compact,.split-actions{grid-template-columns:1fr}.desktop-table{display:none}.mobile-card-list{gap:10px;display:grid}.panel,.form-panel{padding:14px}.quick-actions .button,.button-row .button,.button-row form,.button-row form button{width:100%}.period-picker,.technician-filter,.timesheet-toolbar,.timesheet-toolbar-actions,.wizard-actions{align-items:stretch;width:100%;display:grid}.technician-filter{margin-left:0}.period-picker input,.technician-filter select{width:100%;min-width:0}.timesheet-toolbar-actions .button,.wizard-actions .button{width:100%}.timesheet-mobile-slots,.segment-grid,.wizard-stepper{grid-template-columns:1fr}.wizard-backdrop{align-items:flex-end;padding:10px}.wizard-dialog{max-height:calc(100vh - 20px)}.mobile-bottom-nav{border-top:1px solid var(--border);grid-template-columns:repeat(var(--nav-count,4), minmax(0, 1fr));min-height:66px;padding:7px 6px calc(7px + env(safe-area-inset-bottom));z-index:30;background:#fff;display:grid;position:fixed;bottom:0;left:0;right:0}.mobile-nav-link{color:var(--muted);border-radius:8px;flex-direction:column;justify-content:center;gap:3px;min-width:0;font-size:.72rem}.mobile-nav-link.active{background:var(--brand-soft);color:var(--brand);font-weight:900}.client-layout,.detail-layout,.entry-grid,.definition-grid,.assignment-grid{grid-template-columns:1fr}}
