.layout{background:#f8fafc;min-height:100vh;display:flex}.sidebar{color:#fff;background:#0f172a;flex-direction:column;width:260px;height:100vh;display:flex;position:fixed}.sidebar-header{border-bottom:1px solid #1e293b;align-items:center;gap:10px;padding:20px;display:flex}.sidebar-header h1{color:#f8fafc;font-size:1.5rem;font-weight:700}.sidebar-header .badge{color:#000;background:#f59e0b;border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:600}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-item{color:#94a3b8;border-radius:8px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 16px;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#fff;background:#1e293b}.nav-item.active{color:#fff;background:#1e293b;border-left:3px solid #f59e0b}.nav-icon{font-size:1.1rem}.nav-label{font-size:.95rem}.sidebar-footer{border-top:1px solid #1e293b;padding:16px}.user-info{margin-bottom:12px}.user-name{color:#fff;font-weight:600;display:block}.user-role{color:#64748b;text-transform:capitalize;font-size:.8rem}.logout-btn{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;width:100%;padding:10px;font-weight:500;transition:background .2s}.logout-btn:hover{background:#b91c1c}.main-content{flex:1;margin-left:260px;padding:24px}.page-header{margin-bottom:24px}.page-header h2{color:#0f172a;font-size:1.75rem}.page-header p{color:#64748b;margin-top:4px}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:12px;width:100%;max-width:400px;padding:40px;box-shadow:0 20px 40px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:#0f172a;font-size:2rem}.login-header p{color:#64748b;margin-top:4px}.form-group input{border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:12px;font-size:1rem}.form-group input:focus{border-color:#f59e0b;outline:none;box-shadow:0 0 0 3px #f59e0b1a}.login-btn{color:#000;cursor:pointer;background:#f59e0b;border:none;border-radius:8px;width:100%;padding:14px;font-size:1rem;font-weight:600;transition:background .2s}.login-btn:hover{background:#d97706}.error-message{color:#dc2626;text-align:center;background:#fef2f2;border-radius:8px;margin-bottom:20px;padding:12px}.login-footer{text-align:center;color:#64748b;margin-top:20px;font-size:.85rem}.table-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:#374151;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:14px 16px;font-weight:600}.data-table td{border-bottom:1px solid #f1f5f9;padding:14px 16px}.status{border-radius:12px;padding:4px 10px;font-size:.8rem}.status.active{color:#065f46;background:#d1fae5}.status.inactive{color:#64748b;background:#f1f5f9}.empty{text-align:center;color:#64748b;padding:40px!important}.form-section{background:#fff;border-radius:8px;margin-bottom:24px;padding:24px;box-shadow:0 1px 3px #0000001a}.form-section h3{color:#0f172a;margin-bottom:16px}.create-form{max-width:600px}.form-group{margin-bottom:16px}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#f59e0b;outline:none}.form-group textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.btn-primary{color:#fff;cursor:pointer;background:#f59e0b;border:none;border-radius:6px;padding:12px 24px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#d97706}.btn-primary:disabled{cursor:not-allowed;background:#d1d5db}.btn-secondary{color:#fff;cursor:pointer;background:#6b7280;border:none;border-radius:6px;margin-left:12px;padding:8px 16px;font-weight:500}.btn-secondary:hover{background:#4b5563}.success-message{color:#065f46;background:#d1fae5;border-radius:6px;margin-bottom:16px;padding:12px}.customer-cards{flex-direction:column;gap:12px;display:flex}.customer-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.customer-card-header{cursor:pointer;background:#f9fafb;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.customer-card-header:hover{background:#f3f4f6}.customer-info h3{color:#0f172a;margin:0 0 4px;font-size:16px}.customer-actions{align-items:center;gap:12px;display:flex}.expand-icon{color:#6b7280;font-size:12px}.customer-meta{color:#6b7280;gap:16px;padding:0 20px 12px;font-size:13px;display:flex}.customer-sites{background:#fff;border-top:1px solid #e5e7eb;padding:16px 20px}.sites-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.sites-header h4{color:#374151;margin:0;font-size:14px}.sites-list{flex-direction:column;gap:8px;display:flex}.site-item{background:#f9fafb;border-radius:6px;justify-content:space-between;align-items:center;padding:12px;display:flex}.site-info{flex-direction:column;gap:2px;display:flex}.site-info strong{color:#0f172a;font-size:14px}.site-info span{color:#6b7280;font-size:12px}.site-actions{gap:8px;display:flex}.btn-small{color:#fff;cursor:pointer;background:#6b7280;border:none;border-radius:4px;padding:6px 12px;font-size:12px}.btn-small:hover{background:#4b5563}.add-site-form{background:#f9fafb;border-radius:6px;margin-bottom:12px;padding:16px}.add-site-form .form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.no-sites{color:#9ca3af;text-align:center;padding:20px;font-style:italic}.modal{background:#fff;border-radius:12px;width:400px;max-width:90%;padding:24px}.modal h3{margin:0 0 20px}.modal-actions{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h2{margin:0}.btn-danger{color:#fff;background:#dc2626}.dashboard{padding:24px}.dashboard h2{color:#0f172a;margin:0 0 24px;font-size:24px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;text-decoration:none;transition:all .2s;display:block}.stat-card:hover{border-color:#f59e0b;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.highlight{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border-color:#f59e0b}.stat-value{color:#0f172a;margin-bottom:8px;font-size:36px;font-weight:700}.stat-label{color:#6b7280;font-size:14px;font-weight:500}.filter-badge{color:#92400e;background:#fef3c7;border-radius:12px;margin-left:12px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.monthly-badge{color:#1e40af;background:#dbeafe;border-radius:8px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.site-bookings{color:#065f46;background:#d1fae5;border-radius:8px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.header-actions{align-items:center;gap:12px;display:flex}.config-badge{border-radius:8px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.config-badge.configured{color:#065f46;background:#d1fae5}.config-badge.partial{color:#92400e;background:#fef3c7}.config-badge.not-configured{color:#991b1b;background:#fee2e2}.config-status-grid{background:#f9fafb;border-radius:8px;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0;padding:16px;display:grid}.config-item{align-items:center;gap:8px;font-size:13px;display:flex}.config-item.done{color:#065f46}.config-item.missing{color:#991b1b}.config-icon{font-weight:700}.field-hint{color:#6b7280;margin-top:4px;font-size:11px;display:block}.quote-preview{background:#f9fafb;border-radius:8px;margin-top:12px;padding:16px}.preview-row{border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:8px 0;display:flex}.preview-row:last-child{border-bottom:none;font-weight:600}.invoices-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.invoices-table{border-collapse:collapse;width:100%}.invoices-table th{text-align:left;color:#374151;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:14px 16px;font-weight:600}.invoices-table td{color:#0f172a;border-bottom:1px solid #f1f5f9;padding:14px 16px}.invoices-table tr:hover{cursor:pointer;background:#f8fafc}.invoice-number{color:#0f172a;font-weight:600}.amount{font-family:monospace;font-weight:600}.status-badge{color:#fff;text-transform:capitalize;border-radius:20px;padding:4px 12px;font-size:.8rem;font-weight:500;display:inline-block}.mark-paid-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:6px;padding:6px 12px;font-size:.85rem;transition:background .2s}.mark-paid-btn:hover{background:#059669}.mark-paid-btn.large{padding:12px 24px;font-size:1rem}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow:auto}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h3{color:#0f172a}.close-btn{cursor:pointer;color:#64748b;background:0 0;border:none;font-size:1.5rem}.modal-body{padding:20px}.detail-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;padding:10px 0;display:flex}.detail-row .label{color:#64748b}.detail-row.total{border-bottom:none;padding-top:16px;font-size:1.1rem;font-weight:700}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;padding:20px;display:flex}.loading{color:#64748b;justify-content:center;align-items:center;min-height:400px;display:flex}.action-buttons{gap:8px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:background .2s;display:flex}.action-btn.pdf{color:#fff;background:#3b82f6}.action-btn.pdf:hover{background:#2563eb}.action-btn.send{color:#fff;background:#8b5cf6}.action-btn.send:hover{background:#7c3aed}.action-btn:disabled{opacity:.5;cursor:not-allowed}.sent-badge{color:#10b981;font-weight:500}.not-sent{color:#94a3b8}.modal-footer{flex-wrap:wrap;gap:12px;display:flex}.action-btn-modal{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 16px;font-weight:500;display:flex}.action-btn-modal.pdf{color:#fff;background:#3b82f6}.action-btn-modal.pdf:hover{background:#2563eb}.action-btn-modal.send{color:#fff;background:#8b5cf6}.action-btn-modal.send:hover{background:#7c3aed}.finance-cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.finance-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.finance-card .card-label{color:#64748b;margin-bottom:8px;font-size:.9rem}.finance-card .card-value{color:#0f172a;font-size:1.5rem;font-weight:700}.finance-card.warning{background:#fffbeb;border-color:#f59e0b}.finance-card.success{background:#f0fdf4;border-color:#10b981}.filter-bar{gap:10px;margin-bottom:20px;display:flex}.filter-bar button{cursor:pointer;background:#f1f5f9;border:none;border-radius:6px;padding:8px 16px}.filter-bar button.active{color:#000;background:#f59e0b}.jobs-table{background:#fff;border-radius:12px;overflow:hidden}.jobs-table table{border-collapse:collapse;width:100%}.jobs-table th,.jobs-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:12px}.jobs-table th{background:#f8fafc;font-weight:600}.jobs-table .margin{color:#10b981;font-weight:600}.status-badge{background:#e2e8f0;border-radius:12px;padding:4px 10px;font-size:.75rem}.status-badge.uninvoiced{color:#92400e;background:#fef3c7}.status-badge.invoiced{color:#1e40af;background:#dbeafe}.status-badge.paid{color:#065f46;background:#d1fae5}.status-badge.pending{color:#92400e;background:#fef3c7}.status-badge.approved{color:#1e40af;background:#dbeafe}.action-btns{gap:6px;display:flex}.action-btns button{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:4px;padding:4px 10px;font-size:.75rem}.action-btns button.paid{background:#10b981}.action-btns button.settle{background:#8b5cf6}.quote-form-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:24px}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px;display:grid}.form-group label{color:#374151;margin-bottom:6px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:10px;font-size:1rem}.calculate-btn{color:#000;cursor:pointer;background:#f59e0b;border:none;border-radius:8px;margin-top:8px;padding:12px 24px;font-weight:600}.calculate-btn:hover{background:#d97706}.calculate-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#dc2626;background:#fef2f2;border-radius:8px;margin-bottom:24px;padding:12px}.request-id{color:#64748b;background:#f8fafc;border-radius:8px;margin-bottom:24px;padding:12px;font-family:monospace}.results-section h3{margin-bottom:16px}.results-table{border-collapse:collapse;background:#fff;border-radius:12px;width:100%;overflow:hidden}.results-table th,.results-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:12px}.results-table th{background:#f8fafc;font-weight:600}.results-table .total{color:#10b981;font-weight:700}.results-table .eligible{background:#f0fdf4}.results-table .ineligible{background:#fef2f2}.status-badge{border-radius:12px;padding:4px 10px;font-size:.8rem;font-weight:500}.status-badge.eligible{color:#065f46;background:#d1fae5}.status-badge.ineligible{color:#991b1b;background:#fee2e2}*{box-sizing:border-box;margin:0;padding:0}body{color:#0f172a;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}a{text-decoration:none}button{font-family:inherit}
