@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg: #f4f5f7;--surface: #ffffff;--panel: #ffffff;--border: #e1e4e8;--text: #2f3437;--muted: #6b7280;--accent: #f9763e;--accent-strong: #e56a35;--report-work: #f9763e;--report-meetings: #5fa7d4;--report-break: #f0b246;--report-lunch: #f4b87a;--report-admin: #9aa5b1;--report-gaps: #cbd5e1;--report-other: #b3c0c4;--report-overtime: #94a3b8;--success: #2f9f76;--warning: #c08a2d;--sidebar-width: 240px;--sidebar-width-collapsed: 76px;--header-height: 56px;--content-max: 1200px;--sidebar-bg: #f9fafb;--radius: 14px;--shadow: 0 12px 28px rgba(15, 23, 42, .08);--time-panel-height: 680px}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#f6f7f9,#f1f3f5);font-family:Inter,Segoe UI,sans-serif;color:var(--text);min-height:100vh}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.page{max-width:var(--content-max);margin:0 auto;padding:20px 16px 28px}.page.full-width{max-width:none}.topbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.topbar h1{margin:6px 0;font-size:24px}.page-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.tabs{display:inline-flex;gap:6px;margin-top:8px;border:1px solid var(--border);border-radius:999px;padding:2px;background:var(--surface)}.tab{padding:6px 10px;border-radius:999px;font-size:12px;color:var(--muted)}.tab.active{background:#f9763e1f;color:var(--text)}.details p{margin:2px 0}.topbar-actions{display:flex;gap:10px}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}.empty-panel h2{margin-top:6px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.stack{flex-wrap:wrap}.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:12px;margin:0}.muted{color:var(--muted);margin:4px 0}.small{font-size:12px}.strong{font-weight:700}.mid{font-weight:500;font-size:14px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.filters{display:flex;gap:10px;flex-wrap:wrap}.input-with-icon{position:relative;display:inline-flex;align-items:center}.input-with-icon svg{position:absolute;left:10px;color:var(--muted)}.input-with-icon input{padding-left:32px}input,select,textarea{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:10px}input:focus,select:focus{outline:1px solid var(--accent)}button{background:var(--accent);color:#fff;border:none;padding:8px 12px;border-radius:12px;font-weight:700;cursor:pointer;transition:background .12s ease,box-shadow .12s ease}button:hover{background:var(--accent-strong);box-shadow:0 8px 20px #f9763e2e}button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}button.ghost:hover{background:#f3f4f6;color:var(--text);box-shadow:none}.link-button{border:none;background:transparent;color:var(--muted);padding:0;font-weight:600;text-decoration:underline;text-underline-offset:3px;cursor:pointer}.link-button:hover{color:var(--text);background:transparent;box-shadow:none}button.icon{width:42px;padding:10px 0}.table{border:1px solid var(--border);border-radius:12px;overflow:hidden}.table-head,.table-row{display:grid;grid-template-columns:1.2fr 1fr 1fr .6fr .8fr;gap:10px;padding:12px}.eligible-work-orders .table-head,.eligible-work-orders .table-row{grid-template-columns:2fr .7fr 1fr}.work-orders .table-head,.work-orders .table-row{grid-template-columns:1.6fr 1.1fr .7fr .6fr .45fr .55fr .6fr}.invoice-work-orders .table-head,.invoice-work-orders .table-row{grid-template-columns:40px 1.6fr 1.1fr .7fr .6fr .6fr}.table-head{background:#f8fafc;color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.05em;position:sticky;top:0;z-index:2;border-bottom:1px solid var(--border)}.table-row{border-top:1px solid var(--border);align-items:center;min-height:52px}.table-row:hover{background:#f5f6f8}.table-row.selected{background:#f9763e14}.invoice-select{display:flex;align-items:center;justify-content:center}.row-group{border-top:1px solid var(--border)}.row-group>.table-row{border-top:none}.row-expand{padding:0;background:#f7f8fa}.row-expand .expand-body{grid-column:1 / -1;padding:12px;display:grid;gap:10px}.expand-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.expand-header .topbar-actions{margin-left:auto;align-items:center}.stacked{display:grid;gap:12px}.totals{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:12px;margin-bottom:10px;background:#f7f8fa}.billing{font-weight:700;color:var(--text)}.time-entries .table-head,.time-entries .table-row{grid-template-columns:.55fr 1fr .6fr .7fr .9fr 1fr}.table-empty{padding:10px 12px}.notice{border:1px solid rgba(249,118,62,.3);background:#f9763e14;border-radius:12px;padding:8px 10px}.table-row[role=button]{cursor:pointer}.table-row[role=button]:hover{background:#1118270a}.table-row[role=button]:focus{outline:1px solid rgba(249,118,62,.4);outline-offset:-1px}@media(max-width:900px){.table-head,.table-row{grid-template-columns:1fr}}.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.action-button{background:transparent;border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:8px;font-weight:600;display:inline-flex;align-items:center;gap:6px;box-shadow:none}.action-button:hover{background:#f3f4f6;box-shadow:none}.action-button.danger{color:var(--muted);border-color:var(--border)}.action-button.danger:hover{color:#b42318;border-color:#b4231859;background:#b4231814}.action-button.icon-only{width:34px;height:34px;padding:0;justify-content:center}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:16px}.dashboard-card{display:grid;gap:12px}.dashboard-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.dashboard-card h3{margin:0;font-size:16px}.status-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.status-metrics.single{grid-template-columns:1fr}.stat-number{display:block;font-size:22px;font-weight:700;color:var(--text)}.stat-label{display:block;font-size:12px;color:var(--muted)}.card-actions{margin-top:4px}.team-card{margin-top:0}.dashboard-bottom-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;align-items:start}.team-list{display:grid;gap:12px}.team-list.compact{gap:8px}.team-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--border)}.team-row.compact{padding:6px 0}.team-row.compact[role=button]{cursor:pointer}.team-row:last-child{border-bottom:none}.team-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;text-align:right}.team-hours{font-weight:600}.team-status{font-size:12px;font-weight:600}.team-status.success{color:#2f9f76}.team-status.warning{color:#c55a2b}.team-status.danger{color:#c53b3b}.team-summary{font-weight:600;color:var(--text)}.workorder-chart{display:grid;gap:12px}.workorder-row{display:grid;grid-template-columns:minmax(0,1fr) 1.3fr auto;gap:12px;align-items:center}.workorder-label{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workorder-bar{position:relative;height:30px;background:#eef1f4;border-radius:0;overflow:hidden}.workorder-bar:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,rgba(148,163,184,.4) 0,rgba(148,163,184,.4) 1px,transparent 1px,transparent 18px);opacity:.5}.workorder-bar-fill{display:block;height:100%;position:relative;z-index:1;background:linear-gradient(90deg,#f9763e8c,#f9763e33);border-radius:0;box-shadow:none}.workorder-value{font-size:12px;font-weight:600;color:var(--muted)}.resource-chart-card{margin-top:0;margin-bottom:16px;gap:16px}.resource-chart-header{align-items:flex-start}.resource-chart-legend{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#f9763e1a;color:var(--muted);font-weight:600;font-size:12px}.resource-chart-dot{width:10px;height:10px;border-radius:999px;background:linear-gradient(180deg,#f9763e,#f6a76b);display:inline-block}.resource-area-chart{position:relative;border-radius:16px;border:1px solid var(--border);background:linear-gradient(180deg,#f8fafc,#fff);padding:12px 12px 16px;overflow:hidden}.resource-area-chart:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(to top,rgba(148,163,184,.45) 0,rgba(148,163,184,.45) 1px,transparent 1px,transparent 28px);opacity:.6;pointer-events:none}.resource-area-svg{width:100%;height:220px;display:block;position:relative;z-index:1}.resource-area-fill{fill:url(#resource-area-gradient)}.resource-area-line{fill:none;stroke:#f9763e;stroke-width:3.5}.resource-area-point{fill:#f9763e;stroke:#fff;stroke-width:2}.resource-axis-value{font-size:12px;font-weight:600;fill:var(--text)}.resource-axis-label{font-size:11px;fill:var(--muted)}.menu-wrapper{position:relative}.menu{position:absolute;right:0;top:calc(100% + 8px);min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;z-index:10}.menu-item{width:100%;text-align:left;border-radius:10px;padding:8px 10px;background:transparent;color:var(--text);border:1px solid transparent}.menu-item:hover{border-color:#2f343733;transform:none;box-shadow:none}.menu-item.danger{color:#ff8aa6}.menu-item.danger:hover{border-color:#ff8aa680}.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#f1f2f4;color:var(--text);font-weight:600;font-size:12px}.badge.success{background:#2f9f7629;color:#2f9f76}.badge.warning{background:#f9763e29;color:#c55a2b}.badge.danger{background:#eb575729;color:#c53b3b}.badge.muted-badge{background:#6b72801f;color:var(--muted)}.alert{background:#f9763e1f;border:1px solid rgba(249,118,62,.35);color:#9a4b1f;padding:10px 12px;border-radius:10px;margin:12px 0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-section{display:grid;gap:12px;padding:14px;border:1px solid var(--border);border-radius:12px;background:#fff;margin-bottom:14px}.form-section:last-of-type{margin-bottom:0}.form-section-header h3{margin:0;font-size:14px;font-weight:600}.form-section-collapsible{padding:0}.form-section-summary{list-style:none;padding:14px;cursor:pointer;font-weight:600}.form-section-summary::-webkit-details-marker{display:none}.form-section-collapsible[open] .form-section-summary{border-bottom:1px solid var(--border)}.form-section-collapsible .form-grid{padding:14px}.auth-page{min-height:70vh;display:flex;align-items:center;justify-content:center;max-width:none;width:100%;padding:48px 24px}.auth-card{width:min(460px,100%);display:grid;gap:24px;padding:32px;border-radius:10px;box-shadow:0 6px 16px #0f172a14;font-size:15px}.auth-card h1{font-size:inherit;margin:0;font-weight:600}.auth-logo{width:210px;height:auto;margin-bottom:0}.auth-logo-wrap{display:flex;justify-content:center;margin-bottom:16px}.auth-header{display:grid;gap:8px;align-items:start}.auth-form{display:grid;gap:18px}.auth-fields{display:grid;gap:16px}.auth-footer{display:flex;justify-content:flex-start;align-items:center;margin-top:10px}.auth-form label{display:grid;gap:6px}.auth-form input{width:100%;padding:10px 12px;border-radius:6px;border:1.5px solid #d6dbe1}.auth-form input:focus{outline:none;border-color:#f9763e;box-shadow:0 0 0 2px #f9763e26}.auth-actions{margin:6px 0 2px;display:grid;gap:10px}.auth-actions button{width:100%;padding:12px}.auth-label{font-weight:600;color:var(--text)}.auth-link{font-size:12px;color:var(--muted);text-decoration:underline;text-underline-offset:3px}.auth-card button{border-radius:6px;padding:10px 12px;font-weight:600;box-shadow:none}.auth-card button:hover{box-shadow:none}.admin-users-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:14px}.admin-users .table-head,.admin-users .table-row{grid-template-columns:1.2fr 1.4fr .7fr .6fr .7fr}@media(max-width:720px){.form-grid{grid-template-columns:1fr}}@media(max-width:960px){.admin-users-grid{grid-template-columns:1fr}}.span-2{grid-column:1 / -1}.field{display:flex;flex-direction:column;gap:6px;color:var(--muted)}.inline{display:grid;grid-template-columns:1fr 1fr;gap:8px}@media(max-width:720px){.inline{grid-template-columns:1fr}}.field textarea{resize:vertical;min-height:84px}.field.checkbox{flex-direction:row;align-items:center;gap:10px;color:var(--text)}.field.checkbox span{color:var(--text)}.divider{height:1px;background:var(--border);margin:6px 0}.combobox{position:relative}.combo-list{position:absolute;left:0;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;max-height:260px;overflow:auto;z-index:20}.combo-item{width:100%;display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:10px;background:transparent;color:var(--text);border:1px solid transparent;text-align:left}button.combo-item{cursor:pointer}.combo-item:hover{border-color:#2f343733;transform:none;box-shadow:none}.form-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;margin-top:6px}.form-actions .notice{flex:1;margin-right:auto}.form-actions.split{justify-content:space-between;gap:10px;align-items:center}.invoice-summary{display:grid;gap:12px}.invoice-summary-list{display:grid;gap:10px}.invoice-summary-row{display:grid;grid-template-columns:minmax(0,1.6fr) auto auto;gap:12px;align-items:center}.invoice-summary-row.total{font-weight:700}.table-body{max-height:calc(100vh - 220px);overflow:auto}.table-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-top:1px solid var(--border);background:#f7f8fa}.modal-overlay{position:fixed;inset:0;background:#0f172a14;display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.modal{width:min(1080px,96vw);max-height:min(86vh,860px);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border);background:#f8fafc}.modal-title{margin:0;font-size:16px;font-weight:600}.modal-subtitle{margin:4px 0 0;color:var(--muted);font-size:13px}.modal-body{padding:14px;overflow:auto}.form-shell{width:100%;display:grid;gap:14px}.time-page{max-width:1320px}.time-band{display:grid;gap:14px;margin-bottom:18px}.time-band-row{display:grid;grid-template-columns:1.4fr 1fr;gap:14px;align-items:start}.time-band-left{display:grid;gap:12px}.time-title h1{margin:0 0 6px}.day-card{display:grid;gap:12px}.day-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.day-card h2{margin:4px 0 0;font-size:20px;display:flex;align-items:center;gap:8px}.day-nav{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.day-nav button{display:inline-flex;align-items:center;gap:6px}.summary-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0}.summary-card{display:flex;align-items:center;gap:12px}.summary-icon{width:38px;height:38px;border-radius:10px;color:var(--text);display:inline-flex;align-items:center;justify-content:center}.time-helper{margin:0 0 16px}.time-layout{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch;margin-bottom:16px}.time-layout>section{height:var(--time-panel-height)}.work-orders-panel{display:flex;flex-direction:column;gap:12px}.work-orders-panel input{width:100%;margin-bottom:0}.wo-selected{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#f7f8fa;margin-bottom:10px}.wo-selected.active{border-color:#f9763e73;background:#f9763e1f}.wo-selected-actions{display:flex;gap:6px;flex-wrap:wrap}.timer-button{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;font-weight:700;min-height:44px}.timer-button.danger{background:#c0392b}.timer-button.danger:hover{background:#a93226}.work-orders-header h3{margin:4px 0 6px;font-size:14px;font-weight:600;color:var(--muted)}.wo-list-scroll{flex:1;overflow:auto;min-height:0;display:grid;gap:8px}.wo-list{display:grid;gap:8px;grid-auto-rows:minmax(72px,auto);align-content:start}.wo-item-row{display:grid;grid-template-columns:1fr;gap:8px;align-items:center;min-height:72px;padding:8px;border:1px solid var(--border);border-radius:12px;background:#fff;text-align:left;color:var(--text)}.wo-item-row.selected{border-color:#f9763e66;background:#f9763e14}.wo-item-row:hover{transform:none;box-shadow:none;color:#fff!important}.wo-item{display:grid;gap:4px;text-align:left;background:transparent;border:none;color:var(--text);padding:0}.wo-item.selected{border:1px solid rgba(249,118,62,.4)}.timeline-panel{display:flex;flex-direction:column;gap:12px;height:100%}.timeline-header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;align-items:flex-start}.timeline-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.selected-work-order{font-size:14px;font-weight:600;margin:6px 0 0}.confirm-button{width:100%;padding:10px 12px;border-radius:12px;font-weight:700}.timer-banner{display:grid;gap:4px;border:1px solid rgba(249,118,62,.2);background:#f9763e14;padding:8px 10px;border-radius:12px}.timeline-scroll{position:relative;border:1px solid var(--border);border-radius:12px;overflow:auto;max-height:none;background:#f8fafc;flex:1}.timeline-grid{position:relative}.timeline-hour{position:absolute;left:0;right:0;height:1px;background:#1118270f}.timeline-hour span{position:absolute;left:10px;top:-8px;font-size:11px;color:var(--muted)}.entry-block{position:absolute;left:80px;right:12px;border-radius:10px;padding:6px 8px;display:flex;justify-content:space-between;align-items:center;font-size:12px;background:#f9763e1f;border:1px solid rgba(249,118,62,.25);cursor:grab;transition:top .2s ease,height .2s ease}.entry-block.preview{border-style:dashed;pointer-events:none}.entry-block.locked{background:#2f9f761f;border-color:#2f9f764d;cursor:default}.entry-block.invalid{border-color:#f9763e99}.entry-title{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-time{color:var(--muted)}.resize-handle{position:absolute;left:0;right:0;height:6px;cursor:ns-resize}.resize-handle.top{top:-2px}.resize-handle.bottom{bottom:-2px}.gap-block{position:absolute;left:80px;right:12px;background:#6b728014;border:1px dashed rgba(107,114,128,.3);border-radius:10px;cursor:pointer;padding:0;box-shadow:none;transform:none;transition:top .2s ease,height .2s ease}.gap-block:hover{transform:none;box-shadow:none}.gap-block.active{border-color:#f9763e80;background:#f9763e14}.selection-block{position:absolute;left:80px;right:12px;background:#f9763e1f;border:1px dashed rgba(249,118,62,.5);border-radius:10px;pointer-events:none;transition:top .2s ease,height .2s ease}.selection-label{position:absolute;top:6px;right:8px;background:#fff;border:1px solid rgba(249,118,62,.35);border-radius:10px;padding:6px 12px;font-size:16px;font-weight:700;color:var(--text)}.timeline-popover{position:absolute;left:96px;right:18px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px;display:grid;gap:8px;z-index:6;box-shadow:var(--shadow)}.popover-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.popover-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.popover-controls{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.popover-actions{display:flex;justify-content:flex-end;gap:8px}.gap-popover-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;align-items:center}.gap-popover-actions .gap-select{grid-column:span 2}.gaps-panel{border:1px solid var(--border);border-radius:12px;padding:10px;background:#f7f8fa;display:grid;gap:10px;margin-bottom:16px}.gaps-summary summary{cursor:pointer;color:var(--muted);font-size:13px;margin-bottom:8px}.gaps-list{display:grid;gap:8px}.gap-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:8px;border:1px solid var(--border);border-radius:10px;background:#fff}.gap-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-end}.gap-select select{min-width:180px}.fine-tune{border:1px solid rgba(249,118,62,.2);border-radius:12px;padding:12px;display:grid;gap:10px;background:#f9fafb}.fine-tune-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.fine-row{display:grid;gap:6px}.fine-controls{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.fine-actions{display:flex;justify-content:flex-end;gap:8px}.month-panel{margin-top:16px}.month-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.month-calendar{display:grid;gap:8px}.month-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.month-cells{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.month-cell{min-height:56px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:8px;display:flex;align-items:flex-start;justify-content:flex-end;font-weight:600;cursor:pointer}.month-cell span{color:var(--text)}.month-cell.empty{background:transparent;border:1px dashed var(--border);cursor:default}.month-cell.disabled{opacity:.5;cursor:not-allowed}.month-cell.status-green{border-color:#2f9f76b3;background:#2f9f7629}.month-cell.status-orange{border-color:#f9763eb3;background:#f9763e29}.month-cell.status-red{border-color:#ff8aa699;background:#ff8aa61a}.month-cell.selected{outline:2px solid rgba(249,118,62,.45);outline-offset:-2px}.confirm-modal{display:grid;gap:16px}.confirm-section{display:grid;gap:8px}.confirm-list{margin:0;padding-left:18px;color:var(--muted)}.confirm-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.confirm-status{border:1px solid var(--border);border-radius:12px;padding:10px 12px;display:grid;gap:4px;background:#f8fafc}.confirm-status.success{border-color:#2f9f7666;background:#2f9f7614}.confirm-status.danger{border-color:#eb575766;background:#eb575714}.confirm-status-label{font-size:12px;color:var(--muted)}.confirm-status-value{font-weight:700;color:var(--text)}.inline-error{color:#c53b3b;font-weight:600}.lock-banner{display:flex;justify-content:space-between;align-items:center;gap:12px}@media(max-width:980px){.time-band-row,.time-layout{grid-template-columns:1fr}.time-layout>section{height:auto}.entry-block,.gap-block,.selection-block,.timeline-popover{left:12px}}.gap-block{z-index:1}.entry-block{z-index:2}.selection-block{z-index:3}.timeline-scroll{cursor:crosshair}.wo-item{border-radius:0;box-shadow:none}.wo-item:hover{transform:none;box-shadow:none}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;background:var(--bg)}.app-shell.collapsed{grid-template-columns:var(--sidebar-width-collapsed) 1fr}.app-sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:18px;position:relative;overflow:visible}.app-brand{display:flex;align-items:center;gap:10px;margin-bottom:8px}.app-brand img{width:160px;height:auto;max-width:100%}.app-brand-full{display:block}.app-brand-mark{display:none;width:28px;height:auto}.app-nav{display:grid;gap:4px;font-size:14px}.app-nav-link{position:relative;display:flex;align-items:center;gap:10px;padding:8px 10px 8px 14px;border-radius:8px;color:var(--text);width:100%;max-width:100%;overflow:visible}.app-nav-icon{width:20px;height:20px;color:inherit;opacity:.7;flex-shrink:0}.app-nav-text{white-space:normal}.app-nav-link:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:3px;background:transparent}.app-nav-link.active{background:#f9763e14;color:var(--text)}.app-nav-link.active:before{background:var(--accent)}.app-nav-link.active .app-nav-icon{opacity:1}.app-nav-link.disabled{color:var(--muted);cursor:default}.app-collapse{margin-top:auto;align-self:flex-end;background:var(--surface);border:1px solid var(--border);width:36px;height:36px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;color:var(--muted)}.app-collapse:hover{background:#f3f4f6;box-shadow:none}.app-collapse-icon{transition:transform .12s ease}.app-collapse-icon.flipped{transform:rotate(180deg)}.app-divider{height:1px;background:var(--border);margin:8px 0}.app-main{display:flex;flex-direction:column;min-width:0;background:var(--surface)}.app-header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px}.app-breadcrumb{font-size:15px;font-weight:600;color:var(--text)}.app-user{position:relative;display:flex;align-items:center;gap:8px}.app-user-avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--muted);padding:0;box-shadow:none}.app-user-avatar:hover{background:#f3f4f6;box-shadow:none}.app-user-meta{display:grid;gap:2px;line-height:1.1}.app-user-name{font-size:13px;font-weight:600}.app-user-email{font-size:12px;color:var(--muted)}.app-user-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:10px;min-width:200px;z-index:20}.app-user-menu button{width:100%;text-align:left;background:transparent;border:none;padding:8px 10px;border-radius:8px;color:var(--text);font-weight:500}.app-user-menu button:hover{background:#f3f4f6;box-shadow:none}.app-content{padding:24px}.app-content-inner{width:100%;margin:0 auto}.content--standard{max-width:var(--content-max)}.content--wide{max-width:1440px}.content--fluid{max-width:none}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.app-sidebar{position:sticky;top:0;z-index:10}}.app-shell.collapsed .app-brand-full{display:none}.app-shell.collapsed .app-brand-mark{display:block}.app-shell.collapsed .app-nav-text{display:none}.app-shell.collapsed .app-nav-link{justify-content:center;padding:8px 0}.app-shell.collapsed .app-divider{margin:8px 0}.app-shell.collapsed .app-collapse{align-self:center}.app-shell.collapsed .app-brand{justify-content:center}.app-shell.collapsed .app-brand-mark{width:42px}.app-shell.collapsed .app-nav,.app-shell.collapsed .app-nav-link{overflow:visible}.app-shell.collapsed .app-nav-link:after{content:attr(data-label);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);white-space:nowrap;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:12px;color:var(--text);box-shadow:var(--shadow);opacity:0;pointer-events:none;z-index:30}.app-shell.collapsed .app-nav-link:hover:after{opacity:1}.report-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:16px 0}.report-kpi-card{display:grid;gap:6px;padding:18px}.report-kpi-value{font-size:28px;font-weight:700;margin:0}.kpi-bar{width:100%;height:6px;border-radius:999px;background:#94a3b833;overflow:hidden}.kpi-bar-fill{display:block;height:100%;background:linear-gradient(90deg,#f9763ed9,#f9763e59)}.report-main-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:16px;align-items:stretch;margin-bottom:16px}.report-primary-card{display:grid;gap:12px;height:100%}.report-side-card{display:flex;flex-direction:column;gap:16px;height:100%}.report-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.report-toggle{display:inline-flex;gap:4px;padding:4px;border-radius:999px;border:1px solid var(--border);background:#f7f8fa}.report-toggle button{background:transparent;color:var(--muted);border:none;padding:6px 12px;border-radius:999px;font-weight:600;box-shadow:none}.report-toggle button:hover{background:#f9763e1f;color:var(--text);box-shadow:none}.report-toggle button.active{background:#f9763e2e;color:var(--text)}.chart-frame{width:100%;overflow:hidden;border-radius:14px}.chart-frame--timeline{height:220px}.chart-frame--donut{height:220px;display:flex;align-items:center;justify-content:center}.chart-frame--month,.chart-frame--trend{height:300px}.inline-check{display:inline-flex;align-items:center;gap:8px;font-size:12px}.timeline-panel{display:grid;gap:8px;height:100%;overflow:hidden}.timeline-track{position:relative;height:120px;border-radius:14px;border:1px solid var(--border);background:#f8fafc;overflow:hidden}.timeline-track:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(to right,rgba(148,163,184,.2) 0,rgba(148,163,184,.2) 1px,transparent 1px,transparent 64px);pointer-events:none}.timeline-segment{position:absolute;top:18px;height:64px;padding:6px 8px;border-radius:10px;font-size:12px;font-weight:600;color:#1f2937;display:inline-flex;align-items:center;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.timeline-segment.compact span{display:none}.timeline-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}.timeline-segment.work{background:#f9763e59}.timeline-segment.meetings{background:#5fa7d459}.timeline-segment.break{background:#f0b24652}.timeline-segment.lunch{background:#f4b87a52}.timeline-segment.admin{background:#9aa5b14d}.timeline-segment.gaps{background:#cbd5e180}.timeline-segment.other{background:#b3c0c44d}.timeline-segment.overtime{border:1px dashed rgba(100,116,139,.7)}.timeline-segment.overtime:after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,#fff6 0 6px,#fff0 6px 12px);opacity:.8;pointer-events:none}.month-chart{position:relative;min-height:260px;height:100%;overflow:hidden}.month-chart-bars{position:relative;display:grid;grid-template-columns:repeat(var(--month-days, 31),minmax(0,1fr));align-items:flex-end;gap:4px;padding:16px 12px 24px 36px;min-height:240px;border-radius:14px;border:1px solid var(--border);background:#f9fafb;overflow:hidden}.month-chart-bars:before{content:"";position:absolute;inset:12px 12px 32px;background-image:repeating-linear-gradient(to top,rgba(148,163,184,.1) 0,rgba(148,163,184,.1) 1px,transparent 1px,transparent 28px);pointer-events:none}.month-bar{display:flex;flex-direction:column;align-items:center;gap:4px;z-index:1}.month-bar-stack{width:100%;height:190px;display:flex;flex-direction:column-reverse;border-radius:10px;overflow:hidden;background:#94a3b80f;border:1px solid rgba(148,163,184,.12)}.month-bar-segment{width:100%}.month-bar-label{font-size:11px;color:var(--muted)}.month-chart-axis{position:absolute;left:10px;top:20px;bottom:48px;display:flex;flex-direction:column;justify-content:space-between;font-size:11px;color:var(--muted);pointer-events:none}.donut-wrap{display:grid;gap:14px}.donut{width:180px;height:180px;border-radius:999px;margin:0 auto;display:grid;place-items:center;position:relative;overflow:hidden}.donut-center{position:absolute;width:110px;height:110px;border-radius:999px;background:var(--panel);display:grid;place-items:center;text-align:center;border:1px solid var(--border)}.donut-legend{display:grid;gap:8px}.donut-item{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:8px;row-gap:6px;padding:6px 8px;border-radius:10px;border:1px solid transparent;background:#fff;color:var(--text);text-align:left;font-weight:600;box-shadow:none}.donut-item:hover{border-color:#94a3b866;box-shadow:none}.donut-item-bar{grid-column:1 / -1;height:4px;border-radius:999px;background:#94a3b833;overflow:hidden;position:relative}.donut-item-bar:after{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--pct, 0%);background:var(--bar-color, var(--report-work))}.donut-item--overtime{border-color:#94a3b859;background:#94a3b814;cursor:default}.legend-dot.overtime{background:transparent;border:2px solid var(--report-overtime)}.legend-dot{width:10px;height:10px;border-radius:999px}.legend-dot.work,.month-bar-segment.work,.trend-bar-segment.work{background:var(--report-work)}.legend-dot.meetings,.month-bar-segment.meetings,.trend-bar-segment.meetings{background:var(--report-meetings)}.legend-dot.break,.month-bar-segment.break,.trend-bar-segment.break{background:var(--report-break)}.legend-dot.lunch,.month-bar-segment.lunch,.trend-bar-segment.lunch{background:var(--report-lunch)}.legend-dot.admin,.month-bar-segment.admin,.trend-bar-segment.admin{background:var(--report-admin)}.legend-dot.gaps,.month-bar-segment.gaps,.trend-bar-segment.gaps{background:var(--report-gaps)}.legend-dot.other,.month-bar-segment.other,.trend-bar-segment.other{background:var(--report-other)}.top-work-orders h4{margin:0 0 8px}.top-work-list{display:grid;gap:8px}.top-work-row{display:flex;justify-content:space-between;gap:10px;font-size:13px}.top-work-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-work-meta{color:var(--muted);font-weight:600}.report-trend-card{display:grid;gap:12px}.trend-chart{position:relative;min-height:260px;height:100%;overflow:hidden}.trend-bars{position:relative;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));align-items:flex-end;gap:8px;padding:16px 12px 26px;min-height:220px;border-radius:14px;border:1px solid var(--border);background:#f8fafc;overflow:hidden}.trend-bars:before{content:"";position:absolute;inset:12px 12px 34px;background-image:repeating-linear-gradient(to top,rgba(148,163,184,.2) 0,rgba(148,163,184,.2) 1px,transparent 1px,transparent 28px);pointer-events:none}.trend-bar{display:flex;flex-direction:column;align-items:center;gap:6px;z-index:1}.report-workorders-card{margin-bottom:16px;display:grid;gap:10px}.report-scatter-card{display:grid;gap:12px;margin-bottom:16px}.scatter-chart{position:relative;height:580px;border-radius:16px;border:1px solid var(--border);background:#f9fafb;padding:16px;overflow:hidden}.scatter-grid{position:relative;width:100%;height:100%;border-radius:12px;background-image:linear-gradient(to right,rgba(148,163,184,.15) 1px,transparent 1px),linear-gradient(to top,rgba(148,163,184,.15) 1px,transparent 1px);background-size:20% 20%}.scatter-point{position:absolute;transform:translate(-50%);border-radius:999px;border:2px solid rgba(255,255,255,.9);box-shadow:0 6px 14px #0f172a1f;opacity:.92}.scatter-point.prod-high{background:#1f7a4d}.scatter-point.prod-good{background:#6bc17a}.scatter-point.prod-mid{background:#f0b246}.scatter-point.prod-low{background:#e06c5f}.scatter-axis{position:absolute;font-size:12px;color:var(--muted);font-weight:600;z-index:2}.scatter-axis--x{bottom:8px;right:16px}.scatter-axis--y{top:16px;left:8px;writing-mode:vertical-rl;transform:rotate(180deg)}.scatter-legend{position:absolute;right:16px;top:16px;display:grid;gap:6px;background:#ffffffd9;border:1px solid var(--border);border-radius:12px;padding:8px 10px;font-size:12px}.legend-item{display:flex;align-items:center;gap:6px;color:var(--text)}.legend-item:before{content:"";width:10px;height:10px;border-radius:999px;background:currentColor}.legend-item.prod-high{color:#1f7a4d}.legend-item.prod-good{color:#6bc17a}.legend-item.prod-mid{color:#f0b246}.legend-item.prod-low{color:#e06c5f}.report-table-card{display:grid;gap:12px}.report-table{display:grid;gap:8px}.report-table-head,.report-table-row{display:grid;grid-template-columns:minmax(180px,1.3fr) repeat(5,minmax(90px,.7fr));gap:10px;align-items:center;padding:10px 12px}.report-table-head{border-radius:12px;background:#f8fafc;border:1px solid var(--border);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.report-table-head button{background:transparent;border:none;color:var(--muted);text-align:left;font-weight:700;padding:0}.report-table-row{border-radius:12px;border:1px solid var(--border);background:#fff}.report-name{display:grid;gap:2px}.prod-pill{font-weight:700}.prod-pill.prod-high{color:#1f7a4d}.prod-pill.prod-good{color:#6bc17a}.prod-pill.prod-mid{color:#b45f1f}.prod-pill.prod-low{color:#b3392d}@media(max-width:960px){.report-table-head,.report-table-row{grid-template-columns:1fr;align-items:start}}.trend-bar-stack{width:100%;height:200px;display:flex;flex-direction:column-reverse;border-radius:10px;overflow:hidden;background:#94a3b81a;border:1px solid rgba(148,163,184,.2)}.trend-bar-segment{width:100%}.trend-bar-label{font-size:11px;color:var(--muted)}.trend-line{position:absolute;inset:12px 16px 34px;pointer-events:none}.trend-legend{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px 12px}.trend-legend-item{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;padding:0;cursor:pointer;color:var(--text);font-weight:600}@media(max-width:980px){.report-main-grid{grid-template-columns:1fr}}@media(max-width:720px){.report-kpi-grid{grid-template-columns:1fr}.report-toggle{width:100%;justify-content:space-between}.donut{width:160px;height:160px}.donut-center{width:96px;height:96px}}.report-list,.report-list-body{display:grid;gap:10px}.report-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:12px;border:1px solid var(--border);padding:12px 14px;background:#fff;color:var(--text);text-align:left;box-shadow:none}.report-list-item:hover{background:#f5f6f8;box-shadow:none}.report-filters{margin-bottom:16px}.report-filters .form-grid{grid-template-columns:minmax(220px,1.4fr) .6fr .6fr}.report-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:16px;align-items:start}.report-card{display:grid;gap:12px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.summary-card{border-radius:12px;border:1px solid var(--border);padding:10px 12px;background:#f8fafc}.report-stack{display:grid;gap:8px;margin-top:6px}.report-stack-bar{height:12px;border-radius:999px;background:#e7ecf1;overflow:hidden;display:flex}.report-stack-segment{display:block;height:100%}.report-stack-segment.work{background:linear-gradient(90deg,#f9763ed9,#f9763e73)}.report-stack-segment.gap{background:#cfd8e3}.report-stack-legend{display:flex;justify-content:space-between;gap:10px}.report-trend-chart{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));gap:12px;align-items:end;padding:12px;border-radius:12px;border:1px solid var(--border);background-color:#f8fafc;background-image:repeating-linear-gradient(to top,rgba(148,163,184,.35) 0,rgba(148,163,184,.35) 1px,transparent 1px,transparent 32px);min-height:220px}.report-trend-item{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:60px}.report-trend-bar{width:100%;height:180px;border-radius:10px;overflow:hidden;border:1px solid rgba(148,163,184,.35);background:#94a3b81f;display:flex;flex-direction:column-reverse}.report-trend-segment{display:block;width:100%}.report-month-label{font-size:11px;color:var(--muted);text-align:center}.report-legend{display:flex;flex-wrap:wrap;gap:10px 14px;margin-top:12px}.report-legend-item{display:inline-flex;align-items:center;gap:6px}.report-legend-dot{width:10px;height:10px;border-radius:999px;background:var(--text)}.report-trend-segment.work,.report-legend-dot.work{background:#f9763e}.report-trend-segment.break,.report-legend-dot.break{background:#f0b246}.report-trend-segment.meeting,.report-legend-dot.meeting{background:#5fa7d4}.report-trend-segment.admin,.report-legend-dot.admin{background:#9aa5b1}.report-trend-segment.idle,.report-legend-dot.idle{background:#c4c7cf}.report-trend-segment.internal,.report-legend-dot.internal{background:#7ec59f}.report-trend-segment.external,.report-legend-dot.external{background:#d17c70}.report-trend-segment.lunch,.report-legend-dot.lunch{background:#e5a66d}@media(max-width:960px){.report-grid{grid-template-columns:1fr}}@media(max-width:900px){.report-filters .form-grid{grid-template-columns:1fr}}.timeoff-header{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:16px;margin-bottom:16px}.timeoff-user-card,.timeoff-summary-card{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.timeoff-summary-card{text-align:right}.timeoff-upcoming-card{display:grid;gap:12px;margin-top:16px}.timeoff-upcoming-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.timeoff-upcoming-list{display:grid;gap:10px;max-height:400px;overflow:auto;grid-template-columns:1fr}.timeoff-upcoming-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid var(--border);background:#f8fafc}.timeoff-upcoming-date{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap}.timeoff-upcoming-chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.timeoff-chip{padding:4px 8px;border-radius:999px;background:#f9763e1f;color:var(--text);font-size:12px;font-weight:600}.timeoff-total{font-size:32px;font-weight:700;margin:6px 0 0}.timeoff-calendar-card{display:grid;gap:16px}.timeoff-calendar-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.timeoff-calendar-actions{display:inline-flex;gap:8px}.timeoff-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));text-align:center;font-size:12px;color:var(--muted)}.timeoff-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.timeoff-day{border-radius:12px;border:1px solid var(--border);background:#fff;padding:10px 0;text-align:center;font-weight:600;color:var(--text);box-shadow:none}.timeoff-day:hover:not(.disabled):not(.marked){background:#f9763e14;box-shadow:none}.timeoff-day.marked{background:#f9763e33;border-color:#f9763e80;color:var(--text)}.timeoff-day.today{border-color:#2f343766}.timeoff-day.disabled{background:#f3f4f6;color:#6b7280b3;cursor:not-allowed}.timeoff-day.empty{background:transparent;border:none;box-shadow:none}.timeoff-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.timeoff-status{display:inline-flex;gap:12px;align-items:center}.timeoff-unsaved{color:var(--warning);font-weight:600}.timeoff-actions{display:inline-flex;gap:8px}@media(max-width:900px){.timeoff-header{grid-template-columns:1fr}.timeoff-summary-card{text-align:left}}@media(min-width:720px){.timeoff-upcoming-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1100px){.timeoff-upcoming-list{grid-template-columns:repeat(3,minmax(0,1fr))}}
