:root{--bg: #f8f9fb;--card-bg: #ffffff;--border: #e5e7eb;--border-subtle: #f3f4f6;--text: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--primary: #CD2A2B;--primary-hover: #b02424;--primary-light: rgba(205, 42, 43, .06);--danger: #dc2626;--danger-hover: #b91c1c;--row-hover: #f9fafb;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-lg: 0 4px 12px rgba(0,0,0,.08);--radius: 10px;--radius-sm: 6px;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--mobile-nav-h: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}.layout{display:flex;min-height:100vh}.main-content{flex:1;overflow:auto;min-width:0}.loading-text{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted);font-size:14px}.loading-fullscreen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.sidebar{width:240px;flex-shrink:0;background:var(--card-bg);height:100vh;position:sticky;top:0;display:flex;flex-direction:column;overflow-y:auto;border-right:1px solid var(--border)}.sidebar-brand{padding:20px 16px;font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-brand-logo{height:32px;width:auto;object-fit:contain}.login-brand-logo{height:40px;width:auto;object-fit:contain}.sidebar-brand-icon{width:26px;height:26px;border-radius:6px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-nav{padding:8px;flex:1}.sidebar-section-title{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);padding:12px 8px 4px;letter-spacing:.05em}.sidebar-item{display:flex;align-items:center;gap:8px;padding:6px 8px;font-size:13px;font-weight:500;color:var(--text-secondary);border:none;background:none;width:100%;text-align:left;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s,color .15s;font-family:var(--font)}.sidebar-item:hover{background:var(--primary-light);color:var(--text)}.sidebar-item.active{background:var(--primary-light);color:var(--primary)}.sidebar-badge{margin-left:auto;font-size:11px;font-weight:600;color:var(--text-muted);background:var(--border-subtle);padding:1px 6px;border-radius:10px}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:16px;flex-shrink:0}.sidebar-stat{text-align:center;flex:1}.sidebar-stat-value{display:block;font-size:18px;font-weight:700;color:var(--text)}.sidebar-stat-label{font-size:11px;color:var(--text-muted)}.sidebar-user{padding:.5rem 1rem;margin-bottom:.25rem;flex-shrink:0}.sidebar-user-name{display:block;font-size:13px;font-weight:600;color:var(--text)}.sidebar-user-role{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.sidebar-logout{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;border:none;background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;text-align:left;border-top:1px solid var(--border-subtle);transition:color .15s;font-family:var(--font);flex-shrink:0}.sidebar-logout:hover{color:var(--danger)}.mobile-bottom-nav{display:none}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border:none;background:none;color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:10px;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-item:active{background:var(--border-subtle)}.page{padding:24px 32px;max-width:1200px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.page-header h1{font-size:22px;font-weight:700}.page-header-right{display:flex;gap:8px;align-items:center}.page-title{font-size:22px;font-weight:700;color:var(--text)}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.page-header-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filters-row{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex:1;max-width:320px}.search-box input{border:none;outline:none;font-size:13px;font-family:var(--font);flex:1;background:transparent}.search-box input:focus{border-color:var(--primary)}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{border:none;outline:none;font-size:13px;font-family:var(--font);flex:1;background:transparent}.filter-group{display:flex;gap:2px;background:var(--border-subtle);border-radius:var(--radius-sm);padding:2px}.filter-btn{padding:5px 10px;font-size:12px;font-weight:500;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .15s;font-family:var(--font)}.filter-btn:hover{color:var(--text)}.filter-btn.active{background:var(--card-bg);color:var(--text);box-shadow:var(--shadow)}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-header{padding:12px 16px;font-weight:600;font-size:13px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg)}.card-body{padding:16px}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;padding:10px 12px;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg)}.table td{padding:10px 12px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.table-row:last-child td{border-bottom:none}.table-row.clickable{cursor:pointer}.table-row.clickable:hover td{background:var(--row-hover)}.table tfoot td{padding:8px 12px;border-top:1px solid var(--border);font-size:13px}.table-container{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-row-link,.table-row-clickable{cursor:pointer}.table-row-link:hover td,.table-row-clickable:hover td{background:var(--row-hover)}.empty-cell{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:14px}code{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:var(--primary);font-weight:600}.text-bold{font-weight:600}.text-muted{color:var(--text-muted)!important}.text-right{text-align:right}.text-danger{color:var(--danger)!important}.text-success{color:#16a34a!important}.text-warning{color:#d97706!important}.font-medium{font-weight:500}.identifier{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:var(--primary);font-weight:600}.identifier-lg{font-family:SF Mono,Fira Code,monospace;font-size:16px;color:var(--primary);font-weight:700}.identifier-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:var(--primary);font-weight:600}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#15803d}.badge-gray{background:#f3f4f6;color:#6b7280}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:3px 9px;border-radius:20px;border:1px solid;white-space:nowrap}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;font-size:13px}.status-badge-sm{font-size:12px;font-weight:500;text-transform:capitalize}.status-badge-sm.active{color:#16a34a}.status-badge-sm.inactive{color:var(--text-muted)}.status-badge-sm.clickable{cursor:pointer}.priority-badge{font-size:12px;font-weight:600;text-transform:capitalize}.tech-pill,.service-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:2px 9px;border-radius:12px;border:1px solid;white-space:nowrap}.tech-dot,.service-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.color-swatch{display:inline-block;width:18px;height:18px;border-radius:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;font-family:var(--font);text-align:left;transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-lg)}.stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-value{font-size:20px;font-weight:700}.stat-label{font-size:12px;color:var(--text-muted)}.stat-card-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-body{flex:1}.stat-card-value{font-size:22px;font-weight:700;color:var(--text)}.stat-card-label{font-size:12px;color:var(--text-muted);margin-top:2px}.section{margin-bottom:24px}.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:.75rem}.detail-layout{display:flex;gap:24px}.detail-main{flex:1;min-width:0}.detail-sidebar{width:260px;flex-shrink:0}.detail-sidebar-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.detail-sidebar-section h4{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;letter-spacing:.05em}.detail-sidebar-section select{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);outline:none}.detail-title-row{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.detail-customer-name{font-size:22px;font-weight:700;margin-bottom:16px}.detail-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;padding:16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius)}.detail-meta-item{display:flex;flex-direction:column;gap:2px;font-size:13px}.detail-meta-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.03em}.detail-section{margin-top:24px}.detail-section h3{font-size:15px;font-weight:600;margin-bottom:12px}.detail-notes{font-size:13px;color:var(--text-secondary);white-space:pre-wrap;line-height:1.6}.detail-container{padding:1.5rem;max-width:900px}.detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.detail-title{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}.detail-col{display:flex;flex-direction:column;gap:0}.detail-fields{display:flex;flex-direction:column;gap:.5rem}.detail-field{display:flex;align-items:baseline;gap:.75rem;font-size:14px}.detail-label{font-size:12px;color:var(--text-muted);min-width:80px}.detail-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.info-row{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--border-subtle);font-size:13px;align-items:flex-start}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:var(--text-secondary);min-width:110px;display:flex;align-items:center;gap:4px;flex-shrink:0}.link{color:var(--primary);text-decoration:none;display:inline-flex;align-items:center;gap:4px;font-size:13px}.link:hover{text-decoration:underline}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}.status-buttons{display:flex;flex-direction:column;gap:4px}.status-btn{padding:7px 10px;font-size:12px;font-weight:500;text-transform:capitalize;border:1px solid var(--border);background:none;border-radius:var(--radius-sm);cursor:pointer;text-align:left;font-family:var(--font);transition:all .15s}.status-btn:hover{background:var(--row-hover)}.status-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary);font-weight:600}.note-input-row{display:flex;gap:8px;margin-bottom:12px}.note-input-row input{flex:1;padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);outline:none}.note-input-row input:focus{border-color:var(--primary)}.notes-list{display:flex;flex-direction:column;gap:8px}.note-item{padding:10px 14px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.note-content{font-size:13px;margin-bottom:4px}.note-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;font-family:var(--font);transition:background .15s,box-shadow .15s,color .15s;white-space:nowrap;min-height:36px}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-secondary{background:var(--card-bg);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--row-hover)}.btn-danger{background:#fef2f2;color:var(--danger);border-color:#fecaca}.btn-danger:hover{background:#fee2e2}.btn-success{background:#dcfce7;color:#16a34a;border-color:#bbf7d0}.btn-success:hover{background:#bbf7d0}.btn-ghost{background:none;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--row-hover);color:var(--text)}.btn-back{border:none;padding:6px 8px;color:var(--text-secondary);background:none}.btn-back:hover{color:var(--text);background:var(--row-hover)}.btn-sm{padding:4px 10px;font-size:12px;min-height:28px}.btn-block{width:100%;justify-content:center;margin-top:8px}.btn-group{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all .15s}.btn-icon:hover{background:var(--row-hover);color:var(--text)}.btn-icon.danger:hover{background:#fef2f2;color:var(--danger)}.action-btns{display:flex;gap:4px;align-items:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:85vh;overflow-y:auto}.modal-sm{max-width:440px}.modal-lg{max-width:680px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card-bg);z-index:1}.modal-header h2,.modal-title{font-size:16px;font-weight:600}.modal-close{border:none;background:none;font-size:22px;cursor:pointer;color:var(--text-muted);padding:0 4px;line-height:1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--card-bg)}.modal-body{padding:20px;display:flex;flex-direction:column;gap:12px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group.full-width{grid-column:1 / -1}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;display:block}.form-group label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.form-checkboxes{display:flex;flex-direction:column;gap:6px}.form-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.form-checkbox input{width:16px;height:16px;accent-color:var(--primary)}.form-hint{font-size:12px;margin-top:4px;color:var(--text-muted)}.form-input,.form-control,.form-group input:not([type=checkbox]):not([type=radio]),.form-group select,.form-group textarea{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font);outline:none;transition:border-color .15s,box-shadow .15s;background:var(--card-bg);color:var(--text);width:100%}.form-input:focus,.form-control:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #cd2a2b1a}.form-select{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font);outline:none;background:var(--card-bg);transition:border-color .15s;width:100%;color:var(--text)}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #cd2a2b1a}.form-textarea{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font);outline:none;background:var(--card-bg);resize:vertical;width:100%;transition:border-color .15s;color:var(--text)}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #cd2a2b1a}.form-group textarea{resize:vertical}.inline-input{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);outline:none;width:100%}.inline-input:focus{border-color:var(--primary)}.tags-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--border-subtle);border:1px solid var(--border);border-radius:12px;font-size:12px;font-weight:500;color:var(--text-secondary)}.tag button{border:none;background:none;cursor:pointer;color:var(--text-muted);font-size:14px;line-height:1;padding:0}.tag-sm{font-size:11px;padding:1px 6px}.tag-input-row{display:flex;gap:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:12px;color:var(--text-muted);font-size:14px}.empty-state-icon{opacity:.4}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0}.pagination-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);cursor:pointer;color:var(--text-secondary);transition:all .15s}.pagination-btn:hover:not(:disabled){background:var(--row-hover)}.pagination-btn:disabled{opacity:.4;cursor:default}.pagination-info{font-size:12px;color:var(--text-muted)}.error-banner{position:fixed;bottom:20px;right:20px;background:#fef2f2;border:1px solid #fecaca;color:var(--danger);padding:10px 16px;border-radius:var(--radius);font-size:13px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);z-index:200;max-width:400px}.error-close{border:none;background:none;color:var(--danger);cursor:pointer;padding:2px;flex-shrink:0}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px}.task-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.task-row:last-child{border-bottom:none}.task-done .task-label{text-decoration:line-through;color:var(--text-muted)}.task-check{border:none;background:none;cursor:pointer;padding:2px;flex-shrink:0}.task-content{flex:1;display:flex;flex-direction:column;gap:4px}.task-label{font-size:14px}.task-note-btn{border:none;background:none;cursor:pointer;text-align:left;padding:0}.task-note-text{font-size:12px;color:var(--text-secondary);font-style:italic}.task-note-edit{display:flex;flex-direction:column;gap:6px}.task-edit-list{display:flex;flex-direction:column;gap:4px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.task-edit-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--card-bg);border-bottom:1px solid var(--border-subtle);font-size:13px}.task-edit-row:last-child{border-bottom:none}.task-edit-label{flex:1}.task-edit-index{width:20px;height:20px;border-radius:50%;background:var(--border-subtle);color:var(--text-muted);font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checklist-list{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.checklist-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px}.checklist-toggle{border:none;background:none;cursor:pointer;padding:0;display:flex;color:var(--text-secondary)}.checklist-done{text-decoration:line-through;color:var(--text-muted)}.evv-section{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.evv-row{display:flex;align-items:flex-start;gap:12px}.evv-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.04em}.evv-time{font-size:14px;font-weight:500;margin-top:2px}.cert-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-subtle)}.cert-row:last-child{border-bottom:none}.cert-info{flex:1;display:flex;flex-direction:column;gap:1px}.cert-name{font-size:13px;font-weight:500}.cert-expiry{font-size:12px}.cert-thumb{width:40px;height:40px;object-fit:cover;border-radius:6px;border:1px solid var(--border);flex-shrink:0}.cert-upload-area{border:2px dashed var(--border);border-radius:8px;padding:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:90px;transition:border-color .15s}.cert-upload-area:hover{border-color:var(--primary)}.cert-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:#94a3b8;font-size:13px}.cert-upload-preview{max-width:100%;max-height:160px;border-radius:6px;object-fit:contain}.template-layout{display:grid;grid-template-columns:280px 1fr;gap:16px}.template-list{display:flex;flex-direction:column;gap:8px}.template-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;cursor:pointer;transition:border-color .15s}.template-card:hover{border-color:var(--primary)}.template-card-active{border-color:var(--primary);background:var(--primary-light)}.template-card-name{font-size:13px;font-weight:600}.template-card-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.template-detail{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.template-panel{display:flex;flex-direction:column;gap:16px}.template-panel-header{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px solid var(--border)}.template-panel-title-row{display:flex;align-items:center;gap:8px}.template-panel-title{font-size:16px;font-weight:600;flex:1}.field-type-grid{display:flex;flex-wrap:wrap;gap:8px}.field-type-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);cursor:pointer;font-size:13px;color:var(--text);transition:border-color .15s,background .15s}.field-type-btn:hover{border-color:var(--primary)}.field-type-btn-active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:600}.options-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.option-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-subtle);border-radius:var(--radius-sm);font-size:13px}.option-bullet{color:var(--text-muted);font-size:15px}.option-label{flex:1}.form-fields-list{display:flex;flex-direction:column;gap:2px}.field-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-subtle);border:1px solid var(--border-subtle)}.field-type-icon{color:var(--text-muted);flex-shrink:0;margin-top:2px}.field-row-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.field-row-label{font-size:13px;font-weight:500;color:var(--text)}.field-row-options{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-type-badge{font-size:11px;color:var(--primary);font-weight:500}.field-row-actions{display:flex;gap:4px;flex-shrink:0}.field-editor{display:flex;flex-direction:column;gap:12px}.field-editor-inline{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px}.task-row-field{align-items:flex-start}.task-field-value{font-size:13px;color:var(--text);margin:6px 0 0;background:var(--bg-subtle);border-radius:var(--radius-sm);padding:6px 10px;min-height:32px}.choice-group{display:flex;flex-direction:column;gap:6px;margin-top:8px}.choice-option{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-size:13px;-webkit-user-select:none;user-select:none;background:var(--card-bg);transition:border-color .15s,background .15s}.choice-option:hover{border-color:var(--primary)}.choice-selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:500}.choice-dot{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;flex-shrink:0}.choice-selected .choice-dot{background:var(--primary)}.choice-check{flex-shrink:0;display:flex;align-items:center}.hide-mobile{display:block}.show-mobile,.mobile-signout-btn{display:none}.card-list{display:flex;flex-direction:column;gap:8px}.person-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:border-color .15s;display:flex;flex-direction:column;gap:6px}.person-card:hover{border-color:var(--primary)}.person-card:active{background:var(--bg-subtle)}.person-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}.person-card-name{font-size:15px;font-weight:600}.person-card-meta{display:flex;align-items:center;gap:6px;margin-top:4px}.person-card-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.person-card-label{color:var(--text-muted);font-size:12px}.schedule-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.schedule-day{background:var(--card-bg);min-height:160px;display:flex;flex-direction:column}.schedule-day.today{background:#cd2a2b0a}.schedule-day-header{padding:8px 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle)}.schedule-day-name{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.schedule-day-num{font-size:13px;font-weight:600;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%}.schedule-day-num.today{background:var(--primary);color:#fff}.schedule-day-jobs{padding:4px;flex:1;display:flex;flex-direction:column;gap:3px;overflow-y:auto}.schedule-job{display:block;width:100%;text-align:left;padding:4px 8px;border:none;background:var(--bg);border-left:3px solid var(--primary);border-radius:3px;cursor:pointer;font-family:var(--font);transition:background .15s}.schedule-job:hover{background:var(--border-subtle)}.schedule-job-time{font-size:10px;font-weight:600;color:var(--text-muted)}.schedule-job-title{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schedule-job-service{font-size:10px;color:var(--text-secondary)}.schedule-job-tech{font-size:10px;color:var(--text-muted)}.schedule-empty{font-size:11px;color:var(--text-muted);padding:8px;text-align:center}.tab-row{display:flex;gap:.25rem}.tab-btn{padding:8px 18px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--font)}.tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:16px}.login-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}.login-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.login-brand{display:flex;align-items:center;gap:.75rem;font-size:1.35rem;font-weight:700;color:var(--text)}.login-admin-link{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:500;font-family:var(--font);border:1px solid transparent;border-radius:var(--radius-sm);background:none;color:var(--danger);cursor:pointer;transition:all .15s;opacity:.7}.login-admin-link:hover,.login-admin-link.active{opacity:1;background:#fef2f2;border-color:#fecaca}.login-tabs{display:flex;gap:.25rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;margin-bottom:1.25rem}.login-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 12px;font-size:13px;font-weight:500;border:none;background:transparent;border-radius:calc(var(--radius-sm) - 1px);cursor:pointer;color:var(--text-secondary);transition:all .15s;font-family:var(--font)}.login-tab.active{background:var(--card-bg);color:var(--text);box-shadow:var(--shadow)}.login-form{display:flex;flex-direction:column;gap:1rem}.list-container{padding:1.5rem;max-width:1200px}.list-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:12px}.list-title{font-size:1.25rem;font-weight:700}.list-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.progress-bar-wrapper{display:flex;flex-direction:column;gap:.4rem}.progress-bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .3s}.progress-label{font-size:13px;color:var(--text-secondary)}.day-picker{display:flex;gap:6px;flex-wrap:wrap}.day-btn{padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.day-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.shifts-list{display:flex;flex-direction:column;gap:.5rem}.shift-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.shift-label{flex:1;min-width:120px}.shift-time{width:110px}.shift-sep{color:var(--text-muted);font-size:14px;flex-shrink:0}.shift-caregiver{flex:1.5;min-width:160px}.shift-display-row{display:flex;align-items:center;gap:1rem;padding:8px 0;border-bottom:1px solid var(--border-subtle);font-size:14px}.shift-display-row:last-child{border-bottom:none}.shift-label-text{font-weight:600;min-width:80px}.shift-time-text{color:var(--text-secondary);font-family:SF Mono,monospace;font-size:13px}.shift-caregiver-text{display:flex;align-items:center;gap:4px;color:var(--text-secondary);font-size:13px}.package-preview{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;color:#15803d;margin:.75rem 0}[data-agent] .btn-icon{opacity:1!important}[data-agent] .table-row .action-btns{visibility:visible!important}@media(max-width:1024px)and (min-width:768px){.sidebar{width:200px}.page{padding:20px 24px}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.sidebar{display:none}.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-h);background:var(--card-bg);border-top:1px solid var(--border);z-index:50;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -2px 8px #0000000f}.main-content{padding-bottom:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0px))}.page,.list-container,.detail-container{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:14px}.page-header>div:last-child{display:flex;flex-wrap:wrap;gap:6px;width:100%}.page-title{font-size:20px}.page-header-left{gap:8px}.detail-grid{grid-template-columns:1fr!important;gap:12px!important}.form-grid,.form-row{grid-template-columns:1fr!important}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.template-layout{grid-template-columns:1fr!important}.detail-layout{flex-direction:column}.detail-sidebar{width:100%}.hide-mobile{display:none!important}.show-mobile{display:block!important}.mobile-signout-btn{display:flex!important}.table-container,.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.table td{padding:12px 10px}.table th{padding:8px 10px}.btn{min-height:44px;padding:10px 16px;font-size:14px}.btn-sm{min-height:36px;padding:6px 12px;font-size:13px}.btn-block{min-height:52px;font-size:16px;font-weight:600}.btn-icon{width:40px;height:40px}.modal-overlay{align-items:flex-end;padding:0}.modal{max-height:93vh;border-radius:18px 18px 0 0;max-width:100%}.modal-sm,.modal-lg{max-width:100%}.filters-row{gap:8px}.search-box{max-width:100%;flex:1 1 100%}.info-row{flex-direction:column;gap:3px;padding:10px 0}.info-label{min-width:unset}.task-row{padding:12px 0;gap:12px}.task-label{font-size:15px}.task-check{padding:4px}.tab-row{width:100%}.tab-btn{flex:1;text-align:center;padding:11px 8px}.evv-section{gap:16px}.evv-time{font-size:16px}.error-banner{bottom:calc(var(--mobile-nav-h) + 12px);right:12px;left:12px;max-width:none}.login-screen{align-items:flex-start;padding-top:2rem;padding-bottom:2rem}.login-card{padding:1.75rem 1.5rem}.login-tab{padding:10px}.stat-card{padding:12px;gap:10px}.stat-card-value,.stat-value{font-size:20px}}
