*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--bg: #f8fafc;--card: #ffffff;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--error: #ef4444;--success: #22c55e;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{background:var(--card);border-radius:12px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 4px 24px #00000014}.auth-card h1{font-size:1.75rem;text-align:center;margin-bottom:.25rem}.auth-card h2{text-align:center;color:var(--text-muted);font-weight:400;font-size:1rem;margin-bottom:1.5rem}.auth-card form{display:flex;flex-direction:column;gap:.75rem}.auth-card input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;transition:border-color .15s}.auth-card input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.auth-card p{text-align:center;margin-top:1rem;color:var(--text-muted);font-size:.9rem}.auth-card a{color:var(--primary);text-decoration:none;font-weight:500}.form-row{display:flex;gap:.75rem}.form-row input{flex:1}.error{background:#fef2f2;color:var(--error);padding:.75rem;border-radius:var(--radius);font-size:.9rem;text-align:center}.btn-primary{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--radius);font-size:1rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--primary-hover)}.btn-logout{background:none;border:1px solid var(--border);padding:.4rem .75rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;color:var(--text-muted)}.btn-logout:hover{background:#f1f5f9}.navbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.nav-brand a{font-size:1.25rem;font-weight:700;color:var(--text);text-decoration:none}.company-name{margin-left:.75rem;color:var(--text-muted);font-size:.85rem}.nav-links{display:flex;gap:1.5rem}.nav-links a{color:var(--text-muted);text-decoration:none;font-weight:500;font-size:.9rem;transition:color .15s}.nav-links a:hover{color:var(--text)}.nav-user{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:var(--text-muted)}.main-content{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.dashboard h1{font-size:1.5rem;margin-bottom:.25rem}.subtitle{color:var(--text-muted);margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.stat-card h3{color:var(--text-muted);font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-label{color:var(--text-muted);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.stat-number{font-size:2rem;font-weight:700;margin-top:.4rem}.stat-card--green{border-left:4px solid #22c55e}.stat-card--amber{border-left:4px solid #f59e0b}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.dashboard-columns{display:grid;grid-template-columns:1fr 380px;gap:1.25rem;margin-top:1.5rem}.dashboard-right{display:flex;flex-direction:column;gap:1.25rem}.dashboard-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;border-bottom:1px solid var(--border)}.panel-header h2{font-size:.95rem;font-weight:600}.panel-empty{padding:1.5rem 1.25rem;color:var(--text-muted);font-size:.9rem}.btn-link{background:none;border:none;color:var(--primary);font-size:.8rem;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.dashboard-list{list-style:none;padding:0;margin:0}.dashboard-list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;gap:.5rem}.dashboard-list-item:last-child{border-bottom:none}.dashboard-list-item:hover{background:var(--bg)}.dli-left{display:flex;align-items:center;gap:.75rem;min-width:0}.dli-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dli-title{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.dli-sub{font-size:.75rem;color:var(--text-muted);margin-top:.1rem}.dli-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.dli-date{font-size:.75rem;color:var(--text-muted)}.dli-amount{font-size:.875rem;font-weight:600}.status-pill{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .5rem;border-radius:999px;background:#e2e8f0;color:#475569}.status-pill--scheduled{background:#dbeafe;color:#1d4ed8}.status-pill--in_progress{background:#fef3c7;color:#92400e}.status-pill--sent{background:#dbeafe;color:#1d4ed8}.status-pill--draft{background:#f1f5f9;color:#64748b}.stat-hint.positive{color:#16a34a}.stat-hint.negative{color:#dc2626}.overdue-badge{color:#dc2626;font-weight:600}.overdue-tag{color:#dc2626;font-weight:700;font-size:.7rem;margin-left:.25rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem}.data-table{width:100%;background:var(--card);border:1px solid var(--border);border-radius:12px;border-spacing:0;overflow:hidden}.data-table th{text-align:left;padding:.75rem 1rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#f8fafc;border-bottom:1px solid var(--border)}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8fafc}.name-cell{font-weight:500}.actions-cell{text-align:right;white-space:nowrap}.btn-sm{padding:.3rem .6rem;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:.8rem;cursor:pointer;margin-left:.25rem}.btn-sm:hover{background:#f1f5f9}.btn-danger{color:var(--error);border-color:#fecaca}.btn-danger:hover{background:#fef2f2}.btn-success{color:#16a34a;border-color:#bbf7d0}.btn-success:hover{background:#f0fdf4}.modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal{background:var(--card);border-radius:12px;padding:2rem;width:100%;max-width:560px;box-shadow:0 8px 32px #00000026}.modal h2{margin-bottom:1rem;font-size:1.25rem}.modal form{display:flex;flex-direction:column;gap:.75rem}.modal input,.modal textarea,.modal select{padding:.65rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:inherit}.modal input:focus,.modal textarea:focus,.modal select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-row-3{display:flex;gap:.75rem}.form-row-3 input{flex:1}.form-row-3 input:last-child{max-width:100px}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.btn-secondary{padding:.65rem 1.25rem;border:1px solid var(--border);border-radius:var(--radius);background:#fff;font-size:.9rem;cursor:pointer}.btn-secondary:hover{background:#f1f5f9}.empty-state{text-align:center;padding:3rem;color:var(--text-muted);background:var(--card);border:1px solid var(--border);border-radius:12px}.line-items-editor{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.li-header,.li-row{display:grid;grid-template-columns:120px 1fr 60px 80px 80px 36px;gap:.5rem;padding:.5rem .75rem;align-items:center}.li-header{background:#f8fafc;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border)}.li-row{border-bottom:1px solid var(--border)}.li-row:last-of-type{border-bottom:none}.li-row input,.li-row select{padding:.4rem .5rem;border:1px solid var(--border);border-radius:4px;font-size:.85rem;font-family:inherit}.li-row input:focus,.li-row select:focus{outline:none;border-color:var(--primary)}.li-total{font-weight:500;font-size:.85rem;text-align:right}.li-footer{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-top:1px solid var(--border);background:#f8fafc}.li-grand-total{font-weight:600;font-size:.95rem}.modal-wide{max-width:720px}.row-overdue td{background:#fef2f2!important}.filter-select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;background:#fff}.job-cards{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.job-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.job-card:hover{box-shadow:0 2px 8px #0000000f}.job-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.job-card-header>div:first-child{display:flex;gap:.4rem;flex-wrap:wrap}.job-card-actions{display:flex;gap:.25rem;flex-shrink:0}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.03em}.priority-tag{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase}.priority-high{background:#fef3c7;color:#92400e}.priority-urgent{background:#fee2e2;color:#991b1b}.priority-low{background:#f1f5f9;color:#64748b}.job-title{font-size:1.05rem;font-weight:600;margin:0}.job-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:var(--text-muted)}.job-desc{font-size:.85rem;color:var(--text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.job-transitions{display:flex;gap:.5rem;margin-top:.25rem;padding-top:.5rem;border-top:1px solid var(--border)}.btn-transition{padding:.35rem .75rem;border:none;border-radius:6px;background:var(--primary);color:#fff;font-size:.8rem;font-weight:500;cursor:pointer}.btn-transition:hover{opacity:.9}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted)}.payment-banner{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-radius:10px;margin-bottom:1rem;font-size:.9rem;font-weight:500;animation:slideDown .2s ease}.payment-banner--success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.payment-banner--cancelled{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.banner-close{background:none;border:none;cursor:pointer;font-size:1.1rem;opacity:.6;padding:0 .25rem}.banner-close:hover{opacity:1}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.services-stats{display:flex;gap:1.5rem;margin-bottom:1.25rem;padding:.75rem 1.25rem;background:var(--card);border:1px solid var(--border);border-radius:10px}.services-stat{display:flex;align-items:baseline;gap:.4rem}.services-stat-num{font-size:1.25rem;font-weight:700}.services-stat-label{font-size:.8rem;color:var(--text-muted)}.search-input{width:100%;max-width:320px;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;background:var(--card);color:var(--text)}.search-input:focus{outline:none;border-color:var(--primary)}.input-prefix-wrap{position:relative}.input-prefix{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.9rem;pointer-events:none}.checkbox-row{display:flex;gap:1.5rem;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.field-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.25rem}.usage-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.15rem .45rem;background:#e0f2fe;color:#0369a1;border-radius:999px}.service-table{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden}.service-table-header{display:grid;grid-template-columns:1fr 140px 80px 60px 100px 200px;padding:.6rem 1rem;background:var(--bg-secondary);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.service-row{display:grid;grid-template-columns:1fr 140px 80px 60px 100px 200px;padding:.75rem 1rem;align-items:center;border-bottom:1px solid var(--border);background:#fff;transition:background .15s}.service-row:last-child{border-bottom:none}.service-row:hover{background:#f8fafc}.service-row--inactive{opacity:.6}.service-name{font-weight:500;color:var(--text)}.service-desc{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.service-price{font-weight:600;color:var(--text)}.service-row-actions{display:flex;gap:.4rem;justify-content:flex-end}.service-section-divider{padding:.4rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.stat-card--link{cursor:pointer;transition:transform .15s,box-shadow .15s}.stat-card--link:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.stat-hint{font-size:.75rem;color:var(--primary);margin-top:.5rem;opacity:.8}@media(max-width:768px){.navbar{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.nav-brand{flex:1}.company-name{display:none}.nav-links{order:3;width:100%;display:flex;gap:.5rem;overflow-x:auto;padding-bottom:4px}.nav-links a{white-space:nowrap;font-size:.85rem}.nav-user span{display:none}.main-content{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.page-header>div{width:100%;display:flex;gap:.5rem}.page-header .filter-select{flex:1}.page-header .btn-primary{white-space:nowrap}.stats-grid{grid-template-columns:1fr 1fr}.dashboard-columns,.job-cards{grid-template-columns:1fr}.invoice-table-wrapper,.quote-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:600px}.service-table-header{grid-template-columns:1fr 100px 60px 40px 80px 120px;font-size:.65rem}.service-row{grid-template-columns:1fr 100px 60px 40px 80px 120px}.service-row-actions{gap:.25rem}.service-row-actions .btn-sm{font-size:.7rem;padding:.2rem .4rem}.modal{width:95vw;max-width:95vw;padding:1.25rem;max-height:90vh;overflow-y:auto}.form-row,.form-row-3{flex-direction:column}.btn-primary{padding:.6rem 1rem;font-size:.9rem}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.nav-links a{font-size:.8rem}.stat-number{font-size:2rem}}.cal-layout{display:flex;gap:1rem;align-items:flex-start}.cal-grid-wrap{flex:1;overflow-x:auto;border:1px solid var(--border);border-radius:10px;background:#fff}.cal-grid{display:grid;grid-template-columns:52px repeat(7,1fr);position:relative;min-width:600px}.cal-time-col{grid-column:1;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.cal-day-header{padding:10px 6px 8px;text-align:center;border-left:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-secondary)}.cal-today-header{background:#eff6ff}.cal-day-name{font-size:.7rem;color:var(--text-muted);font-weight:600;text-transform:uppercase}.cal-day-num{font-size:1.1rem;font-weight:700;color:var(--text);margin-top:2px}.cal-today-num{color:#fff;background:var(--primary);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin:2px auto 0}.cal-time-label{grid-column:1;height:60px;padding:4px 6px 0;font-size:.7rem;color:var(--text-muted);text-align:right;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.cal-cell{height:60px;border-left:1px solid var(--border);border-bottom:1px solid var(--border)}.cal-today-col{background:#fafcff}.cal-now-dot{position:absolute;width:10px;height:10px;background:#ef4444;border-radius:50%;left:-5px;transform:translateY(-50%);z-index:10;pointer-events:none}.cal-now-line{position:absolute;left:0;right:0;height:2px;background:#ef4444;opacity:.7;z-index:10;pointer-events:none;transform:translateY(-50%)}.cal-cell--droppable:hover{background:#eff6ff!important;cursor:copy}.cal-event{position:absolute;left:2px;right:2px;min-height:50px;border-radius:6px;padding:4px 6px;color:#fff;font-size:.75rem;z-index:2;box-shadow:0 1px 4px #00000026;cursor:pointer;transition:filter .1s}.cal-event:hover{filter:brightness(1.1)}.cal-event-time{font-size:.65rem;opacity:.85}.cal-event-title{font-weight:600;line-height:1.2;margin-top:2px}.cal-event-customer{opacity:.85;font-size:.7rem;margin-top:2px}.cal-event-btn{margin-top:4px;padding:2px 8px;background:#ffffff40;border:1px solid rgba(255,255,255,.5);border-radius:4px;color:#fff;font-size:.7rem;cursor:pointer}.cal-event-btn:hover{background:#fff6}.cal-sidebar{width:220px;flex-shrink:0;background:#fff;border:1px solid var(--border);border-radius:10px;padding:1rem}.cal-sidebar-title{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.cal-unscheduled-count{background:var(--primary);color:#fff;border-radius:999px;font-size:.7rem;padding:.1rem .45rem;font-weight:700}.cal-sidebar-hint{font-size:.75rem;color:var(--text-muted);margin-bottom:.75rem}.cal-sidebar-empty{font-size:.85rem;color:var(--text-muted);text-align:center;padding:1rem 0}.cal-unscheduled-card{padding:.65rem .75rem;background:var(--bg-secondary);border-radius:8px;margin-bottom:.5rem;border:1px solid var(--border);cursor:grab;transition:box-shadow .15s,transform .15s}.cal-unscheduled-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.cal-unscheduled-card:active{cursor:grabbing}.cal-us-title{font-size:.82rem;font-weight:600;color:var(--text)}.cal-us-customer{font-size:.75rem;color:var(--text-muted);margin-top:2px}.cal-unscheduled-card .priority-tag{margin-top:4px}@media(max-width:768px){.cal-layout{flex-direction:column}.cal-sidebar{width:100%}}.portal-wrap{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem}.portal-card{width:100%;max-width:640px;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #00000014}.portal-header{background:#1e293b;padding:28px 32px}.portal-company{color:#fff;font-size:1.25rem;font-weight:700}.portal-subtitle{color:#94a3b8;font-size:.875rem;margin-top:4px}.portal-body{padding:2rem}.portal-banner{padding:.875rem 1.25rem;border-radius:10px;margin-bottom:1.5rem;font-size:.9rem;font-weight:500}.portal-banner--success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.portal-banner--muted{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.portal-banner--error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.portal-banner--info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.portal-detail-grid{display:flex;gap:2rem;margin-bottom:1.5rem;flex-wrap:wrap}.portal-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}.portal-value{font-size:.95rem;font-weight:600;color:#1e293b}.portal-table{width:100%;border-collapse:collapse;margin-bottom:.5rem;font-size:.9rem}.portal-table th{text-align:left;padding:8px 10px;background:#f8fafc;color:#64748b;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.portal-table td{padding:10px;border-bottom:1px solid #f1f5f9;color:#1e293b}.portal-table tr:last-child td{border-bottom:none}.portal-tax-tag{display:inline-block;font-size:.65rem;background:#fef3c7;color:#92400e;border-radius:4px;padding:1px 5px;margin-left:6px;font-weight:600;text-transform:uppercase}.portal-total-row{display:flex;justify-content:space-between;padding:12px 10px;border-top:2px solid #e2e8f0;font-weight:700;font-size:1.1rem;margin-bottom:1.5rem}.portal-notes{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:1.5rem;font-size:.9rem;color:#475569}.portal-actions{border-top:1px solid #e2e8f0;padding-top:1.5rem;margin-top:.5rem}.portal-cta-text{color:#475569;font-size:.9rem;margin-bottom:1rem}.portal-btn-row{display:flex;gap:.75rem;flex-wrap:wrap}.portal-btn{padding:.75rem 1.75rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.portal-btn:disabled{opacity:.6;cursor:not-allowed}.portal-btn--accept{background:#22c55e;color:#fff}.portal-btn--accept:hover:not(:disabled){background:#16a34a}.portal-btn--decline{background:#f1f5f9;color:#475569}.portal-btn--decline:hover:not(:disabled){background:#e2e8f0}.portal-contact{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #f1f5f9;font-size:.85rem;color:#64748b}.portal-contact a{color:#3b82f6;text-decoration:none}.portal-footer{margin-top:1.5rem;font-size:.75rem;color:#94a3b8}.portal-loading{color:#64748b}.report-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.report-stat-card{background:var(--card);border:1px solid var(--border);border-left:4px solid #3b82f6;border-radius:10px;padding:1.1rem 1.25rem}.report-stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.35rem}.report-stat-value{font-size:1.5rem;font-weight:700;color:var(--text)}.report-stat-sub{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.report-section{margin-bottom:1.5rem}.report-section-title{font-size:1rem;font-weight:600;margin-bottom:.75rem}.report-chart-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.report-chart-card--sm{flex:1;min-width:0}.report-chart-title{font-size:.85rem;font-weight:600;color:var(--text-muted);margin-bottom:.75rem;text-align:center}.report-pie-row{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.report-pie-row .report-chart-card--sm{min-width:220px}@media(max-width:768px){.report-kpi-grid{grid-template-columns:1fr 1fr}.report-pie-row{flex-direction:column}}@media(max-width:480px){.report-kpi-grid{grid-template-columns:1fr}}.mobile-bottom-nav{display:none}@media(max-width:768px){.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e2e8f0;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;text-decoration:none;color:#64748b;min-height:56px;font-size:.65rem;gap:2px}.mobile-nav-item:hover,.mobile-nav-item.active{color:#1e293b}.mobile-nav-icon{font-size:1.3rem;line-height:1}.mobile-nav-label{font-weight:500}.nav-links{display:none!important}.main-content{padding-bottom:calc(70px + env(safe-area-inset-bottom))!important}input,select,textarea{min-height:44px;font-size:16px!important}.btn-primary,.btn-secondary{min-height:44px}.modal{width:100vw!important;max-width:100vw!important;margin:0!important;border-radius:16px 16px 0 0!important;position:fixed!important;bottom:0!important;max-height:90vh!important;overflow-y:auto!important}.modal-backdrop{align-items:flex-end!important}}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.team-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.25rem;display:flex;align-items:flex-start;gap:1rem}.team-card--inactive{opacity:.6}.team-avatar{width:44px;height:44px;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}.team-avatar--inactive{background:#94a3b8}.team-info{flex:1;min-width:0}.team-name{font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:.4rem}.team-email{font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.team-meta{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.team-you-tag{font-size:.65rem;font-weight:600;text-transform:uppercase;background:#f1f5f9;color:#64748b;border-radius:999px;padding:.1rem .45rem}.role-badge{display:inline-block;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .55rem;border-radius:999px;color:#fff}.team-jobs-count{font-size:.75rem;color:var(--text-muted)}.team-actions{display:flex;flex-direction:column;gap:.35rem;flex-shrink:0;align-items:flex-end}.team-role-hints{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;font-size:.8rem;color:var(--text-muted);line-height:1.8;margin-bottom:.5rem}@media(max-width:480px){.team-grid{grid-template-columns:1fr}}.dispatch-layout{display:grid;grid-template-columns:1fr 320px;gap:1rem;height:calc(100vh - 140px)}.dispatch-map-wrap{border:1px solid var(--border);border-radius:12px;overflow:hidden}.dispatch-map{width:100%;height:100%}.dispatch-map-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary)}.dispatch-sidebar{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow-y:auto}.dispatch-job-list{list-style:none;padding:0;margin:0}.dispatch-job-item{display:flex;gap:.75rem;padding:.875rem 1rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;align-items:flex-start}.dispatch-job-item:last-child{border-bottom:none}.dispatch-job-item:hover,.dispatch-job-item--active{background:#f8fafc}.dispatch-job-num{width:28px;height:28px;border-radius:50%;color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dispatch-job-info{flex:1;min-width:0}.dispatch-job-title{font-weight:600;font-size:.875rem}.dispatch-job-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.dispatch-job-addr{font-size:.72rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-navigate-link{font-size:.8rem;color:var(--primary);text-decoration:none;font-weight:500}.job-navigate-link:hover{text-decoration:underline}@media(max-width:768px){.dispatch-layout{grid-template-columns:1fr;height:auto}.dispatch-map-wrap{height:300px}}.settings-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;max-width:680px}.settings-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.settings-card-header h2{font-size:1.1rem;margin:0 0 .25rem}.settings-card-header p{font-size:.875rem;color:var(--text-muted);margin:0}.qb-connected-banner,.qb-disconnected-banner{display:flex;align-items:center;gap:.6rem;padding:.6rem .9rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.qb-connected-banner{background:#f0fdf4;border:1px solid #bbf7d0}.qb-disconnected-banner{background:#fafafa;border:1px solid var(--border);color:var(--text-muted)}.qb-connected-dot,.qb-disconnected-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.qb-connected-dot{background:#22c55e}.qb-disconnected-dot{background:#94a3b8}.qb-sync-info{font-size:.875rem;color:var(--text-muted);line-height:1.6}.qb-sync-info-text{font-size:.875rem;color:var(--text-muted)}.qb-sync-result{border-radius:8px;padding:.75rem 1rem;font-size:.875rem;margin-top:.75rem}.qb-sync-result--ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.qb-sync-result--warn{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.btn-secondary{padding:.5rem 1rem;border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500}.btn-secondary:hover{background:var(--bg-secondary)}.ai-estimate-bar{display:flex;align-items:center;gap:.75rem;margin:.75rem 0;padding:.625rem .875rem;background:linear-gradient(135deg,#f0f4ff,#faf0ff);border:1px dashed #a78bfa;border-radius:10px}.ai-estimate-hint{font-size:.8rem;color:#7c3aed;opacity:.8}.btn-ai-estimate{padding:.45rem 1rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;white-space:nowrap;transition:opacity .15s}.btn-ai-estimate:hover{opacity:.88}.btn-ai{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;border:none!important}.btn-ai:hover{opacity:.88}.btn-ai:disabled{opacity:.45;cursor:not-allowed}.ai-estimate-modal{max-width:600px;padding:1.5rem}.ai-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.ai-modal-title{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ai-modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-muted);line-height:1;padding:0}.ai-modal-close:hover{color:var(--text)}.ai-dropzone{border:2px dashed #c4b5fd;border-radius:12px;padding:2rem 1rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:#faf5ff;margin-bottom:1rem}.ai-dropzone:hover,.ai-dropzone--over{border-color:#7c3aed;background:#f3e8ff}.ai-dropzone-icon{font-size:2.5rem;margin-bottom:.5rem}.ai-dropzone-text{font-weight:600;color:var(--text);margin-bottom:.25rem}.ai-dropzone-sub{font-size:.8rem;color:var(--text-muted)}.ai-file-selected{display:flex;align-items:center;gap:.5rem;justify-content:center;flex-wrap:wrap}.ai-file-icon{font-size:1.75rem}.ai-file-name{font-weight:600;word-break:break-all}.ai-file-size{font-size:.8rem;color:var(--text-muted)}.ai-notes{width:100%;border:1px solid var(--border);border-radius:8px;padding:.625rem .75rem;font-size:.9rem;resize:vertical;margin-bottom:1rem;background:var(--card);color:var(--text);box-sizing:border-box}.ai-notes:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 2px #7c3aed26}.ai-analyzing{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 1rem;color:var(--text-muted)}.ai-spinner{width:40px;height:40px;border:4px solid #e9d5ff;border-top-color:#7c3aed;border-radius:50%;animation:ai-spin .8s linear infinite}@keyframes ai-spin{to{transform:rotate(360deg)}}.ai-summary{background:linear-gradient(135deg,#f0f4ff,#faf0ff);border:1px solid #c4b5fd;border-radius:10px;padding:.875rem 1rem;font-size:.9rem;color:#4c1d95;margin-bottom:1rem;font-style:italic}.ai-results-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem}.ai-items{display:flex;flex-direction:column;gap:.5rem;max-height:320px;overflow-y:auto;margin-bottom:1rem}.ai-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s;background:var(--card)}.ai-item--checked{border-color:#a78bfa;background:#faf5ff}.ai-item input[type=checkbox]{margin-top:.2rem;accent-color:#7c3aed;flex-shrink:0;width:16px;height:16px}.ai-item-body{flex:1;min-width:0}.ai-item-desc{font-weight:600;font-size:.9rem;color:var(--text)}.ai-item-notes{font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.ai-item-meta{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.ai-item-meta strong{color:var(--text)}.ai-pricing-bar{margin:1rem 0}.btn-ai-pricing{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;margin-right:.5rem}.btn-ai-pricing:hover{opacity:.9}.btn-ai-pricing:disabled{opacity:.6;cursor:wait}.ai-pricing-result{background:linear-gradient(135deg,#faf5ff,#ede9fe);border:1px solid #c4b5fd;border-radius:10px;padding:1rem 1.25rem;margin-top:.75rem}.ai-pricing-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.6rem}.ai-pricing-amount{font-size:1.4rem;font-weight:700;color:#4c1d95}.ai-confidence{font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:99px}.ai-confidence--high{background:#dcfce7;color:#166534}.ai-confidence--medium{background:#fef9c3;color:#854d0e}.ai-confidence--low{background:#fee2e2;color:#991b1b}.ai-margin{font-size:.8rem;color:#6d28d9;font-weight:500}.ai-pricing-rationale{font-size:.875rem;color:#3b0764;margin:0 0 .5rem;line-height:1.5}.ai-pricing-notes{font-size:.8rem;color:#5b21b6;padding-left:1.25rem;margin:.5rem 0}.ai-pricing-notes li{margin-bottom:3px}.ai-similar-jobs{font-size:.78rem;color:#7c3aed;margin-top:.5rem}.ai-similar-chip{display:inline-block;background:#ede9fe;border-radius:6px;padding:2px 8px;margin:2px 4px 2px 0;font-size:.75rem}.ai-pricing-error{margin-top:.5rem;padding:.5rem .75rem;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;font-size:.85rem;color:#991b1b}.lead-page{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#f0fdf4);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.lead-card{background:#fff;border-radius:16px;box-shadow:0 4px 32px #00000014;padding:2rem;width:100%;max-width:560px}.lead-header{margin-bottom:1.5rem}.lead-header h1{font-size:1.5rem;margin:0 0 .25rem}.lead-header p{color:#64748b;margin:0;font-size:.9rem}.lead-form{display:flex;flex-direction:column;gap:1rem}.lead-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.lead-field{display:flex;flex-direction:column;gap:.35rem}.lead-field label{font-size:.85rem;font-weight:600;color:#374151}.lead-field input,.lead-field textarea{border:1.5px solid #e2e8f0;border-radius:8px;padding:.6rem .75rem;font-size:.9rem}.lead-field input:focus,.lead-field textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.lead-dropzone{border:2px dashed #cbd5e1;border-radius:10px;padding:1.25rem;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.875rem;color:#64748b;transition:all .15s}.lead-dropzone:hover,.lead-dropzone--active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.lead-dropzone-icon{font-size:1.5rem}.lead-photo-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.lead-photo-chip{background:#eff6ff;color:#1d4ed8;border-radius:6px;padding:4px 10px;font-size:.78rem;display:flex;align-items:center;gap:.35rem}.lead-photo-chip button{background:none;border:none;cursor:pointer;color:#64748b;font-size:1rem;line-height:1}.lead-submit{background:#2563eb;color:#fff;border:none;border-radius:10px;padding:.875rem;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:background .15s}.lead-submit:hover{background:#1d4ed8}.lead-submit:disabled{opacity:.6;cursor:wait}.lead-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;border-radius:8px;padding:.75rem 1rem;font-size:.875rem}.lead-success{background:#fff;border-radius:16px;box-shadow:0 4px 32px #00000014;padding:3rem 2rem;text-align:center;max-width:420px}.lead-success-icon{width:56px;height:56px;background:#dcfce7;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#16a34a;margin:0 auto 1rem}.leads-list{display:flex;flex-direction:column;gap:.5rem}.lead-item{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.lead-item-header{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;cursor:pointer;transition:background .1s}.lead-item-header:hover{background:#f8fafc}.lead-score-circle{width:36px;height:36px;border-radius:50%;color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lead-item-info{flex:1;min-width:0}.lead-item-name{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.lead-item-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.lead-hot-badge{font-size:.7rem;background:#fee2e2;color:#dc2626;padding:2px 8px;border-radius:99px;font-weight:700}.lead-status-badge{font-size:.7rem;color:#fff;padding:3px 10px;border-radius:99px;font-weight:600;white-space:nowrap}.lead-item-body{padding:.75rem 1rem 1rem;border-top:1px solid var(--border)}.lead-ai-summary{background:#faf5ff;border:1px solid #e9d5ff;border-radius:8px;padding:.6rem .75rem;font-size:.85rem;color:#5b21b6;margin:.5rem 0}.lead-item-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem;align-items:center}.lead-status-select{font-size:.8rem;padding:.35rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--card);cursor:pointer}@media(max-width:768px){.lead-row{grid-template-columns:1fr}}.btn-ms-sso{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:.65rem 1rem;background:#fff;color:#1a1a1a;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.btn-ms-sso:hover{background:#f9fafb;border-color:#9ca3af}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:#9ca3af;font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.portal-page{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#f0fdf4);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.portal-login-card{background:#fff;border-radius:16px;box-shadow:0 4px 32px #00000014;padding:2.5rem;width:100%;max-width:420px}.portal-login-card h1{margin:0 0 .5rem;font-size:1.5rem}.portal-input{border:1.5px solid #e2e8f0;border-radius:8px;padding:.65rem .75rem;font-size:.95rem;box-sizing:border-box}.portal-input:focus{outline:none;border-color:#3b82f6}.portal-submit{width:100%;background:#2563eb;color:#fff;border:none;border-radius:10px;padding:.875rem;font-size:1rem;font-weight:600;cursor:pointer}.portal-submit:hover{background:#1d4ed8}.portal-submit:disabled{opacity:.6;cursor:wait}.portal-link-btn{background:none;border:none;color:#2563eb;cursor:pointer;font-size:.875rem;text-decoration:underline}.portal-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;border-radius:8px;padding:.65rem 1rem;font-size:.875rem;margin-bottom:1rem}.portal-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite;margin:1rem auto}@keyframes spin{to{transform:rotate(360deg)}}.portal-shell{min-height:100vh;background:#f8fafc}.portal-header{background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:100}.portal-header-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;height:56px;display:flex;align-items:center;gap:1.5rem}.portal-brand{font-weight:700;font-size:1rem;color:#1e293b;flex-shrink:0}.portal-nav{display:flex;gap:.25rem;flex:1}.portal-nav-link{padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;color:#64748b;text-decoration:none;white-space:nowrap}.portal-nav-link:hover{background:#f1f5f9;color:#1e293b}.portal-nav-link--active{background:#eff6ff;color:#2563eb}.portal-avatar{width:34px;height:34px;background:#2563eb;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;cursor:pointer;flex-shrink:0}.portal-user-menu{position:relative}.portal-dropdown{position:absolute;right:0;top:44px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 4px 20px #0000001a;min-width:180px;padding:.5rem;z-index:200}.portal-dropdown-name{font-weight:600;font-size:.85rem;padding:.25rem .5rem}.portal-dropdown-email{font-size:.75rem;color:#64748b;padding:0 .5rem .25rem}.portal-dropdown-item{width:100%;background:none;border:none;text-align:left;padding:.45rem .5rem;border-radius:6px;font-size:.85rem;cursor:pointer;color:#ef4444}.portal-dropdown-item:hover{background:#fee2e2}.portal-main{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.portal-page-title{font-size:1.5rem;font-weight:700;margin:0 0 1.5rem}.portal-loading{padding:3rem;text-align:center;color:#64748b}.portal-empty-state{text-align:center;padding:3rem;color:#94a3b8}.portal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.portal-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1rem}.portal-stat-card--warn{border-color:#fca5a5;background:#fff7f7}.portal-stat-value{font-size:1.5rem;font-weight:700;color:#1e293b}.portal-stat-label{font-size:.8rem;color:#64748b;margin-top:.25rem}.portal-stat-sub{font-size:.75rem;color:#94a3b8;margin-top:2px}.portal-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.portal-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.portal-card-title{font-size:1rem;font-weight:600;margin:0 0 1rem}.portal-empty{color:#94a3b8;font-size:.875rem}.portal-job-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.portal-job-row:last-child{border-bottom:none}.portal-job-title{font-size:.875rem;font-weight:500}.portal-job-meta{font-size:.75rem;color:#94a3b8}.portal-activity-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.portal-activity-row:last-child{border-bottom:none}.portal-activity-icon{font-size:1.1rem;flex-shrink:0}.portal-activity-info{flex:1;min-width:0}.portal-activity-label{font-size:.85rem;font-weight:500}.portal-activity-date{font-size:.75rem;color:#94a3b8}.portal-activity-amount{font-size:.85rem;font-weight:600;color:#166534;white-space:nowrap}.portal-list{display:flex;flex-direction:column;gap:.5rem}.portal-list-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.portal-list-item--flat .portal-list-row{cursor:default}.portal-list-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer}.portal-list-row:hover{background:#f8fafc}.portal-list-info{flex:1;min-width:0}.portal-list-title{font-weight:600;font-size:.9rem}.portal-list-meta{font-size:.75rem;color:#94a3b8;margin-top:2px}.portal-list-desc{font-size:.8rem;color:#64748b;margin-top:4px}.portal-list-body{padding:.75rem 1.25rem 1rem;border-top:1px solid #f1f5f9}.portal-list-actions{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.portal-amount{font-weight:600;font-size:.9rem}.portal-status-chip{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:99px}.portal-li-table{width:100%;border-collapse:collapse;font-size:.82rem}.portal-li-table th{text-align:left;color:#64748b;font-weight:600;padding:4px 8px;border-bottom:1px solid #e2e8f0}.portal-li-table td{padding:4px 8px}.portal-li-table tr:not(:last-child) td{border-bottom:1px solid #f1f5f9}.portal-btn-outline{border:1.5px solid #e2e8f0;background:#fff;color:#374151;padding:.45rem .9rem;border-radius:8px;font-size:.82rem;cursor:pointer;text-decoration:none}.portal-btn-pay{background:#2563eb;color:#fff;border:none;padding:.45rem 1rem;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;text-decoration:none}.portal-btn-accept{background:#22c55e;color:#fff;border:none;padding:.45rem 1rem;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer}.portal-btn-decline{background:#fff;color:#ef4444;border:1.5px solid #fca5a5;padding:.45rem .9rem;border-radius:8px;font-size:.82rem;cursor:pointer}.portal-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;max-width:560px}.portal-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.portal-field label{font-size:.85rem;font-weight:600;color:#374151}.portal-field input,.portal-field textarea{border:1.5px solid #e2e8f0;border-radius:8px;padding:.6rem .75rem;font-size:.9rem}.portal-success-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:3rem 2rem;max-width:420px}.portal-success-card h2{margin:.75rem 0 .5rem}@media(max-width:768px){.portal-nav{display:none}.portal-stats,.portal-two-col{grid-template-columns:1fr}}.clock-widget{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:2rem;text-align:center;margin-bottom:1.5rem;transition:border-color .2s,box-shadow .2s}.clock-widget--active{border-color:#22c55e;box-shadow:0 0 0 4px #22c55e1a}.clock-status{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.clock-status--idle{color:#94a3b8}.clock-elapsed{font-size:3rem;font-weight:700;color:#22c55e;font-variant-numeric:tabular-nums;line-height:1.1;margin:.5rem 0}.clock-time{font-size:2.5rem;font-weight:300;color:#1e293b;margin:.5rem 0}.clock-since{font-size:.85rem;color:#94a3b8;margin-bottom:.75rem}.clock-job{font-size:.85rem;color:#64748b;margin-bottom:.75rem}.clock-out-form{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem;align-items:center}.btn-clock-in{background:#22c55e;color:#fff;border:none;border-radius:99px;padding:.875rem 2.5rem;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.03em;margin-top:.5rem;box-shadow:0 4px 12px #22c55e4d}.btn-clock-in:hover{background:#16a34a}.btn-clock-out{background:#ef4444;color:#fff;border:none;border-radius:99px;padding:.75rem 2rem;font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #ef44444d}.btn-clock-out:hover{background:#dc2626}.tc-live{color:#22c55e;font-weight:700;font-size:.8rem;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.tc-stats-row{display:flex;gap:1rem;margin-bottom:1.5rem}.tc-stat{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.875rem 1.25rem;min-width:100px}.tc-stat-val{font-size:1.4rem;font-weight:700;color:#1e293b}.tc-stat-label{font-size:.75rem;color:#64748b;margin-top:2px}.tc-row--active td{background:#f0fdf4}.tc-reimb-preview{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:.6rem .75rem;font-size:.875rem;color:#166534}.btn-danger{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5;padding:.3rem .6rem;border-radius:6px;font-size:.75rem;cursor:pointer}.btn-danger:hover{background:#fecaca}.reorder-prompt{display:flex;align-items:flex-start;gap:1rem;background:#fffbeb;border:2px solid #fcd34d;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.reorder-prompt-icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.reorder-prompt-body{flex:1}.reorder-prompt-title{font-weight:700;font-size:.95rem;color:#92400e}.reorder-prompt-question{font-size:.875rem;color:#78350f;margin-top:.4rem;font-weight:600}.reorder-prompt-items{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}.reorder-chip{background:#fef3c7;color:#92400e;font-size:.78rem;padding:2px 8px;border-radius:99px;border:1px solid #fcd34d}.reorder-chip-qty{color:#b45309}.reorder-prompt-actions{display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.btn-reorder-yes{background:#2563eb;color:#fff;border:none;padding:.5rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:700;cursor:pointer;white-space:nowrap}.btn-reorder-yes:hover{background:#1d4ed8}.btn-reorder-no{background:#fff;color:#64748b;border:1px solid #e2e8f0;padding:.45rem 1rem;border-radius:8px;font-size:.875rem;cursor:pointer}.reorder-sent-banner{background:#dcfce7;border:1px solid #86efac;border-radius:10px;padding:.75rem 1.25rem;font-size:.875rem;color:#166534;font-weight:500;margin-bottom:1rem}.import-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;margin-bottom:1rem}.import-section{margin-bottom:1.5rem}.import-section:last-child{margin-bottom:0}.import-section-title{font-size:1rem;font-weight:700;margin:0 0 .875rem;color:#1e293b}.import-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.import-type-card{border:2px solid var(--border);border-radius:10px;padding:1rem;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;transition:all .15s;color:#374151}.import-type-card:hover{border-color:#93c5fd;background:#eff6ff}.import-type-card--active{border-color:#2563eb;background:#eff6ff;color:#1d4ed8}.import-type-icon{font-size:1.5rem}.import-source-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.import-tab,.import-tab--active{padding:.45rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:#64748b}.import-tab--active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.import-dropzone{border:2px dashed #cbd5e1;border-radius:12px;padding:2.5rem 1.5rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.import-dropzone:hover,.import-dropzone--active{border-color:#3b82f6;background:#eff6ff}.import-dropzone--filled{border-color:#22c55e;background:#f0fdf4;border-style:solid}.import-format-badges{display:flex;gap:.5rem;align-items:center;margin-top:.75rem;flex-wrap:wrap}.import-badge{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:3px 10px;font-size:.78rem;font-weight:500}.import-badge--excel{color:#1d6f42;border-color:#bbf7d0;background:#f0fdf4}.import-template-hint{font-size:.82rem;color:#64748b;margin-top:1rem}.import-template-link{color:#2563eb;font-weight:500}.import-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;border-radius:8px;padding:.65rem 1rem;font-size:.875rem;margin-top:.75rem}.import-map-table{width:100%;border-collapse:collapse;font-size:.875rem;margin-top:.5rem}.import-map-table th{text-align:left;padding:8px 12px;background:#f8fafc;color:#64748b;font-size:.78rem;font-weight:600;border-bottom:1px solid var(--border)}.import-map-table td{padding:6px 12px;border-bottom:1px solid #f1f5f9}.import-row--unmapped td{background:#fafafa}.import-col-header{font-weight:600;color:#374151;white-space:nowrap}.import-col-sample{color:#94a3b8;font-size:.78rem;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-field-select{width:100%;padding:.35rem .5rem;border-radius:6px;font-size:.82rem;border:1.5px solid #e2e8f0;background:#fff;color:#64748b}.import-field-select--mapped{border-color:#86efac;background:#f0fdf4;color:#166534}.import-result-stats{display:flex;gap:1rem;justify-content:center;margin:1.5rem 0;flex-wrap:wrap}.import-result-stat{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:1rem 1.5rem;text-align:center;min-width:100px}.import-result-stat--success{background:#f0fdf4;border-color:#86efac}.import-result-stat--error{background:#fff7f7;border-color:#fca5a5}.import-result-num{font-size:2rem;font-weight:700;color:#1e293b}.import-result-label{font-size:.75rem;color:#64748b;margin-top:2px}.import-errors-list{background:#fff7f7;border:1px solid #fca5a5;border-radius:8px;padding:.75rem 1rem;font-size:.82rem;text-align:left;margin-top:1rem}.import-errors-list ul{margin:.5rem 0 0;padding-left:1.25rem}.import-errors-list li{margin-bottom:3px;color:#991b1b}@media(max-width:640px){.import-type-grid{grid-template-columns:1fr}}.consent-list{display:flex;flex-direction:column;gap:1.25rem}.consent-category-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:.5rem}.consent-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.875rem 1rem;border:1.5px solid #e2e8f0;border-radius:10px;background:#fafafa;margin-bottom:.5rem;transition:border-color .15s,background .15s}.consent-row--enabled{border-color:#86efac;background:#f0fdf4}.consent-info{flex:1}.consent-name{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.consent-desc{font-size:.82rem;color:#374151;margin-top:.25rem;line-height:1.4}.consent-detail{font-size:.75rem;color:#94a3b8;margin-top:.2rem}.consent-approved-by{font-size:.75rem;color:#16a34a;margin-top:.3rem}.consent-risk{font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.consent-risk--low{background:#dcfce7;color:#166534}.consent-risk--medium{background:#fef9c3;color:#854d0e}.consent-risk--high{background:#fee2e2;color:#dc2626}.consent-badge{font-size:.7rem;padding:2px 8px;border-radius:99px;font-weight:500}.consent-badge--pending{background:#f1f5f9;color:#64748b}.consent-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;margin-top:2px}.consent-toggle input{opacity:0;width:0;height:0}.consent-toggle-slider{position:absolute;cursor:pointer;inset:0;background:#e2e8f0;border-radius:99px;transition:.2s}.consent-toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px #0003}.consent-toggle input:checked+.consent-toggle-slider{background:#22c55e}.consent-toggle input:checked+.consent-toggle-slider:before{transform:translate(20px)}.consent-toggle input:disabled+.consent-toggle-slider{opacity:.5;cursor:wait}.consent-modal{max-width:460px;text-align:center}.consent-modal-icon{font-size:2.5rem;margin-bottom:.75rem}.consent-modal h2{margin:0 0 .25rem;font-size:1.1rem}.consent-modal h3{margin:0 0 .75rem;font-size:1rem;color:#1e293b}.consent-modal-desc{font-size:.875rem;color:#374151;line-height:1.5;margin-bottom:.5rem}.consent-modal-detail{font-size:.8rem;color:#64748b;margin-bottom:.75rem}.consent-modal-risk{border-radius:8px;padding:.5rem .75rem;font-size:.82rem;margin-bottom:.5rem}.consent-modal-risk--low{background:#f0fdf4;color:#166534}.consent-modal-risk--medium{background:#fefce8;color:#854d0e}.consent-modal-risk--high{background:#fff7f7;color:#dc2626}.consent-modal-fine{font-size:.75rem;color:#94a3b8;line-height:1.5}.inventory-page{max-width:1200px;margin:0 auto;padding:1.5rem}.inventory-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.inventory-header h1{margin:0 0 .25rem}.inventory-header p{margin:0;font-size:.82rem;color:#64748b}.inventory-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.inv-stat{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:.875rem 1rem;text-align:center}.inv-stat--warning{border-color:#fca5a5;background:#fff7f7}.inv-stat--info{border-color:#93c5fd;background:#eff6ff}.inv-stat-val{display:block;font-size:1.75rem;font-weight:700;line-height:1.1}.inv-stat-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin-top:.2rem}.inv-tabs{display:flex;gap:0;border-bottom:2px solid #e2e8f0;margin-bottom:1rem}.inv-tab{background:none;border:none;padding:.6rem 1.25rem;cursor:pointer;font-size:.875rem;color:#64748b;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.inv-tab--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.inv-filters{display:flex;gap:.75rem;margin-bottom:1rem}.inv-search{flex:1;padding:.5rem .75rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem}.inv-filter-select{padding:.5rem .75rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff}.inv-empty{text-align:center;padding:3rem;color:#94a3b8}.inv-table-wrap{overflow-x:auto;border:1.5px solid #e2e8f0;border-radius:10px}.inv-table{width:100%;border-collapse:collapse;font-size:.875rem}.inv-table th{background:#f8fafc;padding:.625rem .875rem;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;border-bottom:1.5px solid #e2e8f0}.inv-table td{padding:.75rem .875rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.inv-table tbody tr:last-child td{border-bottom:none}.inv-table tbody tr:hover{background:#fafafa}.inv-row--low{background:#fff7f7!important}.inv-item-name{font-weight:600}.inv-item-sku{font-size:.75rem;color:#94a3b8}.inv-qty{font-weight:600;font-size:1rem}.text-center{text-align:center!important}.text-right{text-align:right!important}.text-muted{color:#94a3b8}.inv-status-pill{font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:99px;white-space:nowrap}.inv-actions{display:flex;gap:.25rem;justify-content:flex-end}.suppliers-list{display:flex;flex-direction:column;gap:.75rem}.supplier-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:1rem 1.25rem;gap:1rem}.supplier-name{font-weight:600;font-size:.95rem;margin-bottom:.3rem}.supplier-details{display:flex;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:#64748b}.supplier-details a{color:#2563eb;text-decoration:none}.supplier-notes{font-size:.8rem;color:#94a3b8;margin-top:.25rem}.supplier-card-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.supplier-item-count{font-size:.75rem;background:#f1f5f9;color:#64748b;border-radius:99px;padding:2px 10px}.modal-hint{font-size:.75rem;color:#94a3b8;margin-top:.75rem;padding:.5rem .75rem;background:#f8fafc;border-radius:6px}
