.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#1e40af,#2563eb,#3b82f6)}.app-shell{max-width:1280px;margin:0 auto;padding:24px}.app-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px}.app-header h1{margin:0;font-size:1.75rem}button{border:none;background:#2563eb;color:#fff;padding:10px 16px;border-radius:10px;cursor:pointer;transition:background .2s ease}button.secondary{background:#6b7280}button:hover:not(:disabled){background:#1d4ed8}button.secondary:hover:not(:disabled){background:#4b5563}button:disabled{opacity:.55;cursor:not-allowed}input,textarea{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:10px;background:#fff;color:#111827;margin-bottom:0;font-family:inherit;font-size:.95rem;resize:none}label{display:block;margin-bottom:4px;font-weight:600}.card,.panel{background:#fff;border-radius:18px;box-shadow:0 12px 30px #0f172a14;padding:22px}.app-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:20px;align-items:start}.panel-right{height:calc(100vh - 160px);min-height:520px;overflow:hidden;display:flex;flex-direction:column;background:#fff;border-radius:18px;box-shadow:0 12px 30px #0f172a14}.demo-banner{margin:0 0 20px;padding:14px 18px;background:#fef3c7;border:1px solid #fde68a;color:#92400e;border-radius:12px;font-weight:600}.project-card{border:1px solid #e5e7eb;padding:14px;border-radius:14px;margin-bottom:12px}.project-card strong{display:block;margin-bottom:6px}.project-card .meta{color:#6b7280;font-size:.95rem}.section-title{margin-top:0}.error{color:#b91c1c;margin-top:8px}.chat-shell{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-shell--empty{justify-content:center;align-items:center;color:#6b7280;padding:24px}.project-loading{display:flex;flex-direction:column;align-items:center;gap:12px}.project-loading-car{font-size:2.5rem;animation:car-pulse 1s ease-in-out infinite}@keyframes car-pulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.15);opacity:1}}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid #e5e7eb;flex-shrink:0;background:#f9fafb;border-radius:18px 18px 0 0}.chat-header-info{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.chat-header-reg{font-weight:700;font-size:1rem;color:#111827}.chat-header-meta{font-size:.85rem;color:#6b7280}.chat-tabs{display:flex;border-bottom:1px solid #e5e7eb;flex-shrink:0;background:#fff}.chat-tab{flex:1;padding:10px 16px;font-size:.875rem;font-weight:500;background:transparent;color:#6b7280;border:none;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;transition:all .15s ease}.chat-tab:hover:not(.active){background:#f9fafb;color:#374151}.chat-tab.active{color:#2563eb;border-bottom-color:#2563eb;background:#fff}.tab-pane{flex:1;overflow-y:auto;min-height:0}.specs-grid{padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:12px;align-content:start}.spec-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px}.spec-card-title{margin:0 0 8px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.spec-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:3px 0;border-bottom:1px solid #f0f0f0;font-size:.875rem}.spec-row:last-child{border-bottom:none}.spec-label{color:#6b7280;flex-shrink:0}.spec-value{font-weight:600;color:#111827;text-align:right}.spec-notes{margin:0;padding-left:16px;font-size:.875rem;color:#374151}.spec-notes li{margin-bottom:4px}.specs-loading{padding:24px;text-align:center;color:#6b7280;font-style:italic}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px}.chat-empty{color:#9ca3af;font-size:.95rem;text-align:center;margin-top:40px}.chat-row{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}.chat-row--user{align-items:flex-end}.chat-row--ai{align-items:flex-start}.chat-bubble{padding:10px 14px;border-radius:16px;max-width:88%;line-height:1.5}.chat-bubble--user{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.chat-bubble--user p{margin:0}.chat-bubble--ai{background:#f3f4f6;color:#111827;border-bottom-left-radius:4px;max-width:100%;width:100%}.chat-bubble--thinking{display:flex;gap:5px;align-items:center;padding:12px 16px;width:auto}.dot{display:inline-block;width:7px;height:7px;background:#9ca3af;border-radius:50%;animation:dot-bounce 1.2s ease-in-out infinite}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:scale(.75);opacity:.4}40%{transform:scale(1.1);opacity:1}}.chat-time{font-size:.72rem;color:#9ca3af;padding:0 4px}.chat-pill-row{display:flex;justify-content:center;margin:4px 0 8px}.chat-pill{font-size:.78rem;color:#6b7280;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;padding:3px 14px}.chat-input-bar{border-top:1px solid #e5e7eb;padding:12px 16px;flex-shrink:0;background:#fff;border-radius:0 0 18px 18px}.chat-mode-prompt{padding:24px 20px 8px}.chat-mode-prompt-label{font-size:.85rem;color:#6b7280;margin:0 0 12px}.chat-mode-cards{display:flex;gap:10px}.chat-mode-card{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px;border-radius:10px;border:2px solid #e5e7eb;background:#fff;cursor:pointer;text-align:left;transition:border-color .15s}.chat-mode-card:hover{border-color:#93c5fd}.chat-mode-card.active{border-color:#2563eb;background:#eff6ff}.chat-mode-card-title{font-size:.9rem;font-weight:600;color:#1d2939}.chat-mode-card.active .chat-mode-card-title{color:#2563eb}.chat-mode-card-desc{font-size:.75rem;color:#6b7280;line-height:1.3}.chat-verbosity-bar{display:flex;align-items:center;gap:6px;margin-bottom:8px}.chat-verbosity-label{font-size:.72rem;color:#9ca3af;margin-right:2px}.chat-verbosity-btn{font-size:.72rem;padding:2px 10px;border-radius:12px;border:1px solid #d1d5db;background:#fff;color:#6b7280;cursor:pointer}.chat-verbosity-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.chat-input-bar textarea{border-radius:10px;border:1px solid #d1d5db;padding:10px 12px;line-height:1.4}.chat-input-bar textarea:focus{outline:none;border-color:#2563eb}.ai-response{line-height:1.6}.ai-response p{margin:0 0 8px}.ai-response ul,.ai-response ol{margin:0 0 8px;padding-left:20px}.ai-response li{margin-bottom:4px}.ai-response h1,.ai-response h2,.ai-response h3{margin:12px 0 6px;font-size:1rem}.ai-response strong{font-weight:700}.ai-response code{background:#e5e7eb;padding:1px 5px;border-radius:4px;font-family:monospace;font-size:.9em}.ai-response pre{background:#e5e7eb;padding:10px;border-radius:8px;overflow-x:auto;margin-bottom:8px}.ai-response table{width:100%;border-collapse:collapse;font-size:.85rem;margin:8px 0 12px}.ai-response th{background:#f1f5f9;text-align:left;padding:7px 10px;font-weight:600;border-bottom:2px solid #e2e8f0;white-space:nowrap}.ai-response td{padding:7px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.ai-response tr:last-child td{border-bottom:none}.ai-response td:nth-child(n+4),.ai-response th:nth-child(n+4){text-align:right}.ai-suggestion{display:flex;align-items:flex-start;gap:10px;margin-bottom:6px}.ai-suggestion>span{flex:1}.ai-suggestion--open{flex-wrap:wrap}.ai-suggestion--warning>span{padding-left:8px;border-left:3px solid #f59e0b;color:#92400e}.open-answer-input{width:100%;margin:4px 0 0;padding:6px 10px;font-size:.875rem;border:1.5px solid #d1d5db;border-radius:8px;background:#fff;color:#111827}.what-fixed-btn{margin-top:10px;font-size:.78rem;padding:5px 14px;background:#f0fdf4;color:#15803d;border:1px solid #86efac;border-radius:8px}.what-fixed-btn:hover:not(:disabled){background:#dcfce7}.fix-chooser{margin-top:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px}.fix-chooser-label{font-size:.82rem;font-weight:700;color:#374151;margin:0 0 10px}.fix-chooser-list{list-style:none;padding:0;margin:0 0 12px;display:flex;flex-direction:column;gap:8px}.fix-chooser-item label{display:flex;align-items:flex-start;gap:8px;font-size:.85rem;color:#111827;cursor:pointer;font-weight:400}.fix-chooser-item input[type=checkbox]{margin-top:2px;flex-shrink:0;width:auto}.fix-chooser-item--done label{color:#6b7280;cursor:default}.fix-chooser-actions{display:flex;gap:8px}.fix-chooser-actions button{font-size:.82rem;padding:5px 14px}.confirmed-fixes-bar{background:#f0fdf4;border-top:1px solid #bbf7d0;padding:10px 16px;font-size:.82rem;color:#15803d}.confirmed-fixes-bar ul{margin:4px 0 0;padding-left:18px}.confirmed-fixes-bar li{margin:2px 0}.chat-tab--alert{color:#d97706}.chat-tab--alert.active{color:#d97706;border-bottom-color:#d97706}.chat-tab-badge{display:inline-block;margin-left:5px;background:#2563eb;color:#fff;border-radius:10px;font-size:.7rem;padding:1px 6px;font-weight:600;vertical-align:middle}.chat-tab--alert .chat-tab-badge{background:#d97706}.vehicle-history-tab{padding:16px;display:flex;flex-direction:column;gap:20px}.vh-section{display:flex;flex-direction:column;gap:8px}.vh-heading{font-size:.9rem;font-weight:600;color:#1e293b;margin:0}.vh-sub{margin:0;font-size:.8rem;color:#6b7280}.vh-timeline{display:flex;flex-direction:column;gap:0}.vh-job{display:flex;align-items:flex-start;gap:10px;border-left:2px solid #e2e8f0;padding:8px 0 8px 14px;position:relative}.vh-job--current{border-left-color:#2563eb}.vh-job-dot{width:8px;height:8px;border-radius:50%;background:#94a3b8;position:absolute;left:-5px;top:12px;flex-shrink:0}.vh-job--current .vh-job-dot{background:#2563eb}.vh-job-body{display:flex;flex-direction:column;gap:2px}.vh-job-reg{font-weight:600;font-size:.875rem;color:#1e293b}.vh-job-date{font-size:.78rem;color:#94a3b8}.vh-job-meta{font-size:.8rem;color:#6b7280}.vh-fixes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.vh-fix{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.vh-fix--mine{background:#f0fdf4;border-color:#bbf7d0}.vh-fix-text{flex:1;font-size:.875rem;color:#1e293b}.vh-fix-date{font-size:.75rem;color:#94a3b8;white-space:nowrap;flex-shrink:0}.vh-fix-tag{font-size:.7rem;background:#dcfce7;color:#16a34a;border-radius:6px;padding:1px 7px;white-space:nowrap;flex-shrink:0;font-weight:500}.vh-regs{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.vh-reg{display:flex;gap:12px;align-items:center;font-size:.85rem;padding:4px 0;color:#374151}.suggestion-confirmed{color:#16a34a;font-weight:600;white-space:nowrap;flex-shrink:0;margin-top:3px;font-size:.8rem}.yn-buttons{display:flex;gap:5px;flex-shrink:0;margin-top:1px}.yn-btn{font-size:.75rem;padding:2px 12px;border-radius:8px;border:1.5px solid #d1d5db;background:#f3f4f6;color:#374151;cursor:pointer;transition:all .15s ease}.yn-btn:hover{background:#e5e7eb}.yn-btn.yn-yes.active{background:#dcfce7;border-color:#16a34a;color:#15803d;font-weight:600}.yn-btn.yn-no.active{background:#fee2e2;border-color:#dc2626;color:#b91c1c;font-weight:600}.continue-btn{margin-top:14px;background:#0f766e;font-weight:600;font-size:.9rem;padding:8px 18px}.continue-btn:hover:not(:disabled){background:#0d5e57}@media (max-width: 960px){.app-grid{grid-template-columns:1fr}.panel-right{height:70vh}}.admin-shell{display:flex;flex-direction:column;min-height:100vh;background:#f8fafc}.admin-header{display:flex;align-items:center;gap:24px;padding:0 32px;height:58px;background:#1e293b;color:#fff;flex-shrink:0}.admin-brand{font-weight:700;font-size:1rem;color:#fff}.admin-brand-sub{font-size:.72rem;background:#2563eb;color:#fff;padding:2px 8px;border-radius:6px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.admin-nav{display:flex;gap:2px;flex:1}.admin-nav-btn{background:transparent;color:#94a3b8;border:none;border-radius:8px;padding:6px 16px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.admin-nav-btn:hover,.admin-nav-btn.active{background:#334155;color:#fff}.admin-nav-btn:hover:not(:disabled){background:#334155}.admin-header-right{display:flex;align-items:center;gap:12px;margin-left:auto}.admin-user{font-size:.8rem;color:#94a3b8}.admin-content{flex:1;padding:32px;max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box}.admin-page-title{font-size:1.4rem;font-weight:700;color:#0f172a;margin:0 0 24px}.admin-section-title{font-size:1rem;font-weight:600;color:#374151;margin:24px 0 12px}.admin-loading{color:#9ca3af;padding:24px 0}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.stat-card{background:#fff;border-radius:14px;padding:20px 24px;box-shadow:0 2px 8px #0f172a0f;border:1px solid #e2e8f0}.stat-value{font-size:1.8rem;font-weight:700;color:#0f172a;line-height:1}.stat-label{font-size:.8rem;color:#64748b;margin-top:6px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-sub{font-size:.8rem;color:#94a3b8;margin-top:4px}.admin-table-wrap{background:#fff;border-radius:14px;border:1px solid #e2e8f0;overflow:auto;box-shadow:0 2px 8px #0f172a0a}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{text-align:left;padding:10px 16px;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}.admin-table td{padding:12px 16px;color:#1e293b;border-bottom:1px solid #f1f5f9;vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table-row{cursor:pointer;transition:background .1s}.admin-table-row:hover td{background:#f8fafc}.admin-table-row--active td{background:#eff6ff}.admin-cell-truncate{max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-toolbar{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.admin-filters{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.admin-search{padding:8px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;width:260px;background:#fff;color:#111827;margin-bottom:0}.admin-filters select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;background:#fff;color:#111827;width:auto;margin-bottom:0}.badge{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 10px;border-radius:20px;white-space:nowrap}.badge-green{background:#dcfce7;color:#15803d}.badge-grey{background:#f1f5f9;color:#64748b}.badge-blue{background:#dbeafe;color:#1d4ed8}.admin-split{display:flex;gap:20px;align-items:flex-start}.admin-split-main{flex:1;min-width:0;transition:flex .2s}.admin-split-main--narrow{flex:0 0 55%}.detail-panel{flex:0 0 42%;background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:24px;box-shadow:0 4px 16px #0f172a14;position:sticky;top:20px;max-height:calc(100vh - 120px);overflow-y:auto}.detail-close{float:right;background:transparent;color:#94a3b8;padding:0;width:28px;height:28px;border-radius:6px;font-size:.9rem;line-height:28px;text-align:center}.detail-close:hover{background:#f1f5f9;color:#374151}.detail-title{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 10px;word-break:break-all}.detail-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.detail-date{font-size:.78rem;color:#94a3b8}.detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.detail-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}.detail-stat{background:#f8fafc;border-radius:10px;padding:10px 8px;text-align:center}.detail-stat strong{display:block;font-size:1.1rem;color:#0f172a}.detail-stat span{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.detail-section{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:20px 0 10px}.kb-form-wrap{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px #0f172a0a}.kb-form{display:flex;flex-direction:column;gap:12px}.kb-form-row{display:flex;gap:12px;flex-wrap:wrap}.kb-form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}.kb-form-group label{font-size:.8rem;font-weight:600;color:#374151;margin-bottom:0}.kb-form-group input,.kb-form-group select,.kb-form-group textarea{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;background:#fff;color:#111827;width:100%;box-sizing:border-box;margin-bottom:0}.kb-form-group textarea{resize:vertical}.kb-form-actions{display:flex;gap:10px;margin-top:4px}.tab-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:3px;gap:2px}.tab-toggle button{background:transparent;color:#64748b;border:none;border-radius:6px;padding:5px 14px;font-size:.8rem;font-weight:500;cursor:pointer}.tab-toggle button.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001a}.tab-toggle button:hover:not(.active):not(:disabled){background:#e2e8f0}.convo-feed{display:flex;flex-direction:column;gap:10px;overflow-y:auto;max-height:calc(100vh - 260px);padding-right:4px}.convo-entry{display:flex;flex-direction:column;gap:2px}.convo-entry--user{align-items:flex-end}.convo-entry--ai,.convo-entry--assistant{align-items:flex-start}.convo-bubble{padding:8px 12px;border-radius:14px;max-width:90%;font-size:.85rem;line-height:1.5}.convo-bubble--user{background:#2563eb;color:#fff;border-bottom-right-radius:3px}.convo-bubble--ai,.convo-bubble--assistant{background:#f1f5f9;color:#1e293b;border-bottom-left-radius:3px;max-width:100%;width:100%}.convo-ai-prose p{margin:0 0 6px}.convo-ai-prose ul,.convo-ai-prose ol{margin:0 0 6px;padding-left:18px}.convo-ai-prose li{margin-bottom:2px}.convo-ai-prose h1,.convo-ai-prose h2,.convo-ai-prose h3{font-size:.9rem;margin:8px 0 4px}.convo-ai-prose strong{font-weight:700}.convo-pill-row{display:flex;justify-content:center;margin:2px 0}.user-active-pill{background:#dcfce7;color:#15803d;padding:2px 10px;border-radius:20px;font-weight:600;font-size:.85rem}.report-tab{padding:20px;display:flex;flex-direction:column;gap:20px}.report-status-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px}.report-badge{font-size:.75rem;font-weight:700;padding:3px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}.report-badge--draft{background:#fef3c7;color:#92400e}.report-badge--published{background:#dcfce7;color:#15803d}.report-status-bar-actions{display:flex;gap:8px;margin-left:auto}.report-form{display:flex;flex-direction:column;gap:16px}.report-section{display:flex;flex-direction:column;gap:6px}.report-label{font-size:.8rem;font-weight:600;color:#374151}.report-hint{font-size:.72rem;color:#9ca3af;margin-top:2px}.report-costs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.report-cost-group{display:flex;flex-direction:column;gap:4px}.report-cost-group label{font-size:.78rem;font-weight:600;color:#374151}.report-cost-group input{padding:8px 10px;font-size:.875rem}.report-cost-total{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;font-size:.875rem;font-weight:700;color:#0f172a}.report-images{display:flex;flex-direction:column;gap:12px}.report-image-upload{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px dashed #d1d5db;border-radius:10px;background:#fafafa;cursor:pointer}.report-upload-icon{font-size:1.4rem}.report-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.report-image-card{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;background:#fff}.report-image-card img{width:100%;height:100px;object-fit:cover;display:block}.report-image-card-body{padding:6px 8px}.report-image-caption{font-size:.75rem;padding:4px 6px;border:1px solid #e2e8f0;border-radius:6px;width:100%;box-sizing:border-box;margin-bottom:4px}.report-image-delete{font-size:.7rem;padding:2px 8px;background:#fee2e2;color:#b91c1c}.cp-shell{display:flex;flex-direction:column;min-height:100vh;background:#f8fafc}.cp-header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:58px;background:#1e293b;color:#fff;flex-shrink:0}.cp-brand{display:flex;align-items:center;gap:10px}.cp-brand-name{font-weight:700;font-size:1rem;color:#fff}.cp-brand-sub{font-size:.72rem;background:#2563eb;color:#fff;padding:2px 8px;border-radius:6px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.cp-header-right{display:flex;align-items:center;gap:12px}.cp-user-email{font-size:.8rem;color:#94a3b8}.cp-main{flex:1;max-width:820px;width:100%;margin:0 auto;padding:40px 24px;box-sizing:border-box}.cp-page-title{font-size:1.4rem;font-weight:700;color:#0f172a;margin:0 0 24px}.cp-vehicle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.cp-vehicle-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:20px;text-align:left;box-shadow:0 2px 8px #0f172a0d;cursor:pointer;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:6px;color:#111827}.cp-vehicle-card:hover{box-shadow:0 6px 20px #0f172a1f;border-color:#93c5fd;background:#fff}.cp-vehicle-reg{font-size:1.25rem;font-weight:800;color:#0f172a;letter-spacing:.03em}.cp-vehicle-info{font-size:.875rem;color:#6b7280}.cp-vehicle-jobs{font-size:.8rem;color:#2563eb;font-weight:600;margin-top:4px}.cp-vehicle-arrow{font-size:.8rem;color:#94a3b8;margin-top:auto;padding-top:8px}.cp-vehicle-header{margin-bottom:24px}.cp-vehicle-title{font-size:1.4rem;font-weight:800;color:#0f172a;margin:0 0 4px}.cp-vehicle-meta{font-size:.9rem;color:#6b7280;margin:0}.cp-job-list{display:flex;flex-direction:column;gap:12px}.cp-job-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px 20px;text-align:left;box-shadow:0 1px 4px #0f172a0a;cursor:pointer;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:8px;color:#111827;width:100%}.cp-job-card:hover{box-shadow:0 4px 16px #0f172a1a;border-color:#93c5fd;background:#fff}.cp-job-date{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.cp-job-summary{font-size:.9rem;color:#374151;margin:0;line-height:1.5}.cp-job-footer{display:flex;justify-content:space-between;align-items:center;padding-top:4px}.cp-job-cost{font-size:.9rem;font-weight:700;color:#0f172a}.cp-job-arrow{font-size:.8rem;color:#2563eb;font-weight:600}.cp-detail{display:flex;flex-direction:column;gap:0}.cp-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px}.cp-detail-title{font-size:1.3rem;font-weight:800;color:#0f172a;margin:0 0 6px}.cp-detail-meta{font-size:.875rem;color:#6b7280;margin:0}.cp-status-badge{font-size:.72rem;font-weight:700;padding:4px 14px;border-radius:20px;background:#dcfce7;color:#15803d;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.05em}.cp-back{background:transparent;color:#6b7280;padding:0;font-size:.875rem;font-weight:500;margin-bottom:24px;display:inline-block}.cp-back:hover{color:#111827;background:transparent}.cp-report-section{border-top:1px solid #f1f5f9;padding:20px 0}.cp-report-section--note{background:transparent}.cp-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin:0 0 10px}.cp-section-text{font-size:.9375rem;color:#1e293b;line-height:1.7;margin:0}.cp-fixes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.cp-fix{font-size:.9rem;color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:8px 12px;font-weight:500}.cp-costs{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.cp-cost-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-size:.9rem;color:#374151;border-bottom:1px solid #f1f5f9;background:#fff}.cp-cost-row:last-child{border-bottom:none}.cp-cost-row--total{background:#f8fafc;font-weight:700;color:#0f172a;font-size:1rem}.cp-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.cp-photo{border-radius:10px;overflow:hidden;border:1px solid #e2e8f0}.cp-photo img{width:100%;height:140px;object-fit:cover;display:block}.cp-photo-caption{padding:6px 10px;font-size:.78rem;color:#6b7280;margin:0;background:#fff}.cp-published-at{font-size:.78rem;color:#94a3b8;text-align:center;padding-top:20px;border-top:1px solid #f1f5f9;margin-top:8px}.cp-loading{text-align:center;padding:48px;color:#9ca3af;font-size:.9rem}.cp-error{color:#b91c1c;padding:24px;text-align:center}.cp-empty{color:#9ca3af;font-size:.9rem;padding:32px 0}.cp-job-badges{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap}.cp-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.72rem;font-weight:600;letter-spacing:.02em}.cp-badge--report{background:#dbeafe;color:#1d4ed8}.cp-badge--quote{background:#fef9c3;color:#92400e}.cp-badge--approved{background:#d1fae5;color:#065f46}.cp-status-badge--quote{background:#fef9c3;color:#92400e;font-size:.78rem;padding:4px 10px;border-radius:12px;font-weight:600}.cp-quote-section{margin-top:24px}.cp-quote-group{margin-bottom:12px}.cp-quote-group-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:4px}.cp-quote-line{display:flex;align-items:baseline;gap:8px;padding:5px 0;border-bottom:1px solid #f1f5f9;font-size:.88rem}.cp-quote-line-desc{flex:1;color:#1e293b}.cp-quote-line-qty{color:#94a3b8;font-size:.8rem;white-space:nowrap}.cp-quote-line-total{font-weight:600;white-space:nowrap}.cp-quote-totals{margin-top:12px;border-top:2px solid #e2e8f0;padding-top:10px}.cp-quote-notes{margin-top:12px;font-size:.85rem;color:#64748b;font-style:italic;padding:8px 12px;background:#f8fafc;border-radius:6px}.quote-tab{padding:20px 0}.quote-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px}.quote-selector{display:flex;gap:8px;flex-wrap:wrap}.quote-pill{padding:5px 14px;border-radius:20px;border:1px solid #e2e8f0;background:#fff;font-size:.84rem;cursor:pointer;color:#374151;display:flex;align-items:center;gap:6px}.quote-pill.active{background:#1e40af;color:#fff;border-color:#1e40af}.quote-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.quote-status-dot.draft{background:#94a3b8}.quote-status-dot.sent{background:#f59e0b}.quote-status-dot.approved{background:#10b981}.quote-status-dot.invoiced{background:#6366f1}.quote-empty-state{text-align:center;padding:40px 0;color:#6b7280}.quote-empty-state textarea{width:100%;max-width:560px;margin:12px 0}.quote-status-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f8fafc;border-radius:8px;margin-bottom:20px;border:1px solid #e2e8f0}.quote-status-actions{display:flex;gap:8px}.quote-status-badge{font-size:.8rem;font-weight:600;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.04em}.quote-status-badge.draft{background:#f1f5f9;color:#475569}.quote-status-badge.sent{background:#fef3c7;color:#92400e}.quote-status-badge.approved{background:#d1fae5;color:#065f46}.quote-status-badge.invoiced{background:#ede9fe;color:#4c1d95}.cp-status-badge--quote{background:#fef3c7;color:#92400e}.diag-summary-block{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:12px 16px;margin-bottom:20px}.diag-summary-block h4{margin:0 0 6px;font-size:.85rem;color:#0369a1}.diag-summary-block p{margin:0;font-size:.88rem;color:#374151;white-space:pre-wrap}.diag-summary-input{width:100%;resize:vertical}.quote-section{margin-bottom:24px}.quote-section h4{font-size:.9rem;font-weight:600;color:#374151;margin:0 0 12px}.parts-search-form{display:flex;gap:8px;margin-bottom:12px}.parts-search-input{flex:1}.parts-empty{font-size:.85rem;color:#9ca3af;padding:8px 0}.parts-results{display:flex;flex-direction:column;gap:6px}.part-result-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;gap:12px}.part-result-info{display:flex;gap:8px;align-items:baseline;flex-wrap:wrap;flex:1}.part-brand{font-weight:600;font-size:.85rem;color:#1e40af}.part-title{font-size:.88rem;color:#111827}.part-number{font-size:.78rem;color:#6b7280;font-family:monospace}.part-category{font-size:.73rem;color:#6366f1;background:#ede9fe;padding:1px 7px;border-radius:10px;white-space:nowrap}.part-result-price{display:flex;align-items:center;gap:10px;white-space:nowrap}.part-cost{font-size:.8rem;color:#6b7280}.part-sell{font-size:.88rem;font-weight:600;color:#111827}.part-add-btn{padding:4px 12px;font-size:.82rem}.quote-table{width:100%;border-collapse:collapse;font-size:.86rem}.quote-table th{text-align:left;padding:8px 10px;border-bottom:2px solid #e2e8f0;font-weight:600;color:#6b7280;font-size:.78rem;text-transform:uppercase}.quote-table td{padding:9px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.quote-table .num{text-align:right}.line-type-badge{font-size:.73rem;padding:2px 8px;border-radius:10px;background:#f1f5f9;color:#475569;white-space:nowrap}.line-edit-input{width:70px;padding:3px 6px;font-size:.84rem}.line-actions{display:flex;gap:6px;justify-content:flex-end}.line-actions .danger{color:#dc2626;border-color:#fca5a5}.labour-add-row{margin-top:12px}.add-labour-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:14px;margin-top:8px}.add-labour-form input[type=text],.add-labour-form input:not([type]){width:100%;margin-bottom:10px}.add-labour-row{display:flex;gap:12px;flex-wrap:wrap}.add-labour-row label{display:flex;flex-direction:column;gap:4px;font-size:.82rem;color:#374151}.add-labour-row input{width:90px}.add-labour-actions{display:flex;gap:8px;margin-top:12px}.quote-totals{margin-left:auto;width:280px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.quote-total-row{display:flex;justify-content:space-between;padding:9px 16px;font-size:.88rem;border-bottom:1px solid #f1f5f9}.quote-total-row.total{font-weight:700;font-size:1rem;background:#1e40af;color:#fff;border-bottom:none}.quote-pill-delete{background:none;border:none;padding:0 0 0 6px;font-size:.7rem;line-height:1;cursor:pointer;opacity:.5;color:inherit}.quote-pill-delete:hover{opacity:1}.quote-list{display:flex;flex-direction:column;gap:10px}.quote-accordion{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;background:#fff}.quote-accordion.open{border-color:#bfdbfe;box-shadow:0 2px 8px #2563eb12}.qa-header{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;background:#f8fafc;-webkit-user-select:none;user-select:none;flex-wrap:wrap}.quote-accordion.open .qa-header{background:#eff6ff;border-bottom:1px solid #bfdbfe}.qa-header:hover{background:#f0f9ff}.qa-chevron{font-size:.75rem;color:#94a3b8;flex-shrink:0}.qa-ref{font-family:monospace;font-weight:700;font-size:.85rem;background:#1e40af;color:#fff;padding:2px 8px;border-radius:5px;white-space:nowrap}.qa-title{font-weight:600;font-size:.9rem;color:#111827}.qa-customer{font-size:.82rem;color:#6b7280}.qa-spacer{flex:1}.qa-total{font-weight:700;font-size:.92rem;color:#1e40af;white-space:nowrap}.qa-status{font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.qa-status.draft{background:#f1f5f9;color:#475569}.qa-status.sent{background:#fef3c7;color:#92400e}.qa-status.approved{background:#d1fae5;color:#065f46}.qa-status.invoiced{background:#ede9fe;color:#4c1d95}.qa-body{padding:16px;display:flex;flex-direction:column;gap:12px}.qa-meta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.qa-sent-label{font-size:.78rem;color:#6b7280}.qa-fields{display:flex;flex-direction:column;gap:8px}.qa-fields textarea{width:100%;box-sizing:border-box;resize:vertical}.qa-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding-top:12px;border-top:1px solid #f1f5f9}.quote-selector-bar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid #e2e8f0}.quote-selector-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;cursor:pointer;font-size:.84rem;color:#374151;transition:border-color .15s,background .15s}.quote-selector-tab:hover{border-color:#2563eb}.quote-selector-tab.active{background:#1e40af;color:#fff;border-color:#1e40af}.quote-selector-tab .qst-ref{font-weight:700;font-size:.8rem;font-family:monospace}.quote-selector-tab .qst-title{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quote-selector-tab .qst-badge{font-size:.68rem;font-weight:700;padding:1px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em}.quote-selector-tab.active .qst-badge{background:#fff3;color:#fff}.quote-selector-tab:not(.active) .qst-badge.draft{background:#f1f5f9;color:#64748b}.quote-selector-tab:not(.active) .qst-badge.sent{background:#fef3c7;color:#92400e}.quote-selector-tab:not(.active) .qst-badge.approved{background:#d1fae5;color:#065f46}.quote-selector-tab:not(.active) .qst-badge.invoiced{background:#ede9fe;color:#4c1d95}.quote-selector-add{padding:6px 12px;border:1px dashed #cbd5e1;border-radius:20px;background:#f8fafc;color:#64748b;cursor:pointer;font-size:.82rem}.quote-selector-add:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.quote-meta-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.quote-meta-ref{display:flex;align-items:center;gap:8px}.quote-ref-badge{font-family:monospace;font-size:.9rem;font-weight:700;background:#1e40af;color:#fff;padding:3px 10px;border-radius:6px}.quote-title-display{font-size:.92rem;color:#374151;font-weight:600}.quote-customer-row{display:flex;align-items:center;gap:10px;position:relative}.quote-customer-label{font-size:.8rem;color:#6b7280;white-space:nowrap}.quote-customer-value{display:flex;align-items:center;gap:8px}.quote-customer-name{font-size:.88rem;font-weight:600;color:#111827}.quote-customer-email{font-size:.8rem;color:#6b7280}.customer-picker-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:100;min-width:240px;overflow:hidden}.customer-picker-option{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:10px 14px;border:none;background:none;cursor:pointer;font-size:.88rem;color:#111827;border-bottom:1px solid #f1f5f9;text-align:left}.customer-picker-option:hover{background:#f0f9ff}.customer-picker-option .cpo-name{font-weight:600}.customer-picker-option .cpo-email{font-size:.78rem;color:#6b7280}.customer-picker-remove{color:#dc2626}.customer-picker-remove:hover{background:#fef2f2}.customer-picker-cancel{width:100%;padding:8px 14px;border:none;background:#f8fafc;cursor:pointer;font-size:.82rem;color:#6b7280;text-align:center}.customer-picker-cancel:hover{background:#f1f5f9}.quote-items-section{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.quote-item-card{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;background:#fff}.quote-item-card.expanded{border-color:#bfdbfe}.quote-item-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f8fafc;cursor:pointer;-webkit-user-select:none;user-select:none}.quote-item-card.expanded .quote-item-header{background:#eff6ff}.quote-item-chevron{font-size:.75rem;color:#94a3b8;flex-shrink:0}.quote-item-title-text{font-weight:600;font-size:.92rem;flex:1;color:#111827}.quote-item-subtotal{font-size:.88rem;font-weight:700;color:#1e40af;white-space:nowrap}.quote-item-header-actions{display:flex;gap:6px;margin-left:8px}.quote-item-body{padding:16px;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:12px}.quote-item-desc-display{font-size:.88rem;color:#374151;background:#f0f9ff;border-radius:6px;padding:8px 12px;margin:0}.quote-item-notes-display{font-size:.82rem;color:#6b7280;font-style:italic;margin:0}.quote-item-meta-form{display:flex;flex-direction:column;gap:8px}.quote-item-title-input{font-weight:600;font-size:.95rem}.quote-item-desc-input,.quote-item-notes-input{font-size:.88rem;resize:vertical}.quote-item-add-row{display:flex;flex-direction:column;gap:0}.quote-item-subtotal-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-top:1px dashed #e2e8f0;font-size:.88rem;font-weight:600;color:#374151;margin-top:4px}.quote-add-item-btn{background:#f8fafc;border:2px dashed #cbd5e1;color:#64748b;border-radius:8px;padding:10px 20px;font-size:.88rem;cursor:pointer;width:100%;text-align:center;transition:border-color .15s,color .15s}.quote-add-item-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.add-item-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:14px}.add-item-form input{width:100%;margin-bottom:10px}.add-item-form-actions{display:flex;gap:8px}.cp-quote-item-group{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.cp-quote-item-group:last-of-type{border-bottom:none}.cp-quote-item-title{font-size:.88rem;font-weight:700;color:#1e40af;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.cp-quote-item-desc{font-size:.85rem;color:#6b7280;margin:0 0 8px}.cp-quote-item-subtotal{text-align:right;font-size:.82rem;font-weight:600;color:#374151;margin-top:6px}.mot-tab{padding:4px 0 16px}.mot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.mot-test-card{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px;overflow:hidden}.mot-test-card.mot-pass{border-left:4px solid #16a34a}.mot-test-card.mot-fail{border-left:4px solid #dc2626}.mot-test-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#f9fafb;flex-wrap:wrap}.mot-badge{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.mot-badge--pass{background:#dcfce7;color:#15803d}.mot-badge--fail{background:#fee2e2;color:#b91c1c}.mot-test-date{font-weight:600;font-size:.88rem}.mot-mileage{font-size:.82rem;color:#6b7280}.mot-defects{padding:8px 14px 10px;border-top:1px solid #f3f4f6}.mot-defect-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:4px}.mot-defect{font-size:.82rem;padding:3px 0;line-height:1.4}.mot-defect--fail{color:#b91c1c}.mot-defect--advisory{color:#92400e}.mot-defect--dangerous{font-weight:600}.mot-recall-banner{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;font-weight:600;padding:10px 14px;border-radius:6px;margin-bottom:12px;font-size:.88rem}.mot-meta-block{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px 14px;margin-bottom:14px}.mot-section-heading{font-size:.72rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.mot-meta-row{display:flex;justify-content:space-between;padding:3px 0;font-size:.82rem;border-bottom:1px solid #f3f4f6}.mot-meta-row:last-child{border-bottom:none}.mot-meta-label{color:#6b7280}.mot-meta-value{font-weight:500;text-align:right}.mot-defect--minor{color:#92400e}.mot-defect--prs{color:#1d4ed8}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:24px 16px;overflow-y:auto}.preview-modal{background:#fff;border-radius:12px;width:100%;max-width:640px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:calc(100vh - 48px)}.preview-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.preview-modal-header h3{margin:0;font-size:.95rem;font-weight:600;color:#374151}.preview-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:#6b7280;padding:4px 8px;border-radius:4px;line-height:1}.preview-close:hover{background:#f3f4f6;color:#111827}.preview-modal-body{overflow-y:auto;padding:0;flex:1}.workshop-examples{margin-top:12px;padding:0 4px}.workshop-examples-label{font-size:.78rem;color:#94a3b8;margin:0 0 8px}.workshop-example-chips{display:flex;flex-wrap:wrap;gap:6px}.workshop-chip{background:#f0f9ff;color:#0369a1;border:1px solid #bae6fd;border-radius:16px;padding:4px 12px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s}.workshop-chip:hover:not(:disabled){background:#e0f2fe;color:#0284c7}.ws-shell{display:flex;flex-direction:column;height:100%}.ws-tabs{display:flex;gap:2px;padding:12px 20px 0;border-bottom:1px solid #e5e7eb;background:#fff}.ws-tab{background:none;border:none;padding:8px 16px;font-size:.88rem;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.ws-tab.active{color:#1d4ed8;border-bottom-color:#1d4ed8;font-weight:600}.ws-tab:hover:not(.active){color:#374151}.ws-body{flex:1;overflow-y:auto;padding:24px 24px 40px}.ws-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px;margin-bottom:20px}.ws-section-title{font-size:.95rem;font-weight:700;color:#111827;margin:0 0 16px}.ws-field{margin-bottom:12px}.ws-label{display:block;font-size:.8rem;font-weight:600;color:#374151;margin-bottom:4px}.ws-hint{font-weight:400;color:#9ca3af}.ws-field input,.ws-field select,.ws-field textarea{width:100%}.ws-save-bar{display:flex;align-items:center;gap:12px;justify-content:flex-end;padding-top:4px}.ws-add-form{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-top:12px}.training-layout{display:flex;gap:24px;align-items:flex-start;min-height:0}.training-chat-panel{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:12px}.training-chat-feed{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;min-height:360px;max-height:520px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.training-chat-bar{display:flex;gap:8px;align-items:center}.training-empty{color:#9ca3af;font-size:.9rem;text-align:center;margin:auto;padding:32px 0}.training-thinking{color:#9ca3af;font-style:italic}.training-feed-panel{flex:0 0 360px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:18px}.training-feed-input{width:100%;box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:.85rem;font-family:inherit;resize:vertical}.training-entry-card{border:1px solid #bfdbfe;border-radius:6px;padding:12px;background:#fff;margin-bottom:10px}.training-entry-title{font-weight:600;font-size:.85rem;margin-bottom:4px}.training-entry-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:.78rem;color:#6b7280;margin-bottom:6px}.training-entry-preview{font-size:.82rem;color:#374151;margin:0 0 8px;line-height:1.45}.training-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:center;justify-content:center}.training-modal{background:#fff;border-radius:12px;padding:24px;width:700px;max-width:95vw;max-height:90vh;overflow-y:auto}.app-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a;display:flex;align-items:center;justify-content:center;z-index:9999}.app-loading-inner{display:flex;flex-direction:column;align-items:center;gap:20px}.app-loading-logo{font-size:2rem;font-weight:700;color:#f8fafc;letter-spacing:-.5px}.app-loading-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-loading-text{font-size:.85rem;color:#64748b;margin:0}.admin-agent-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000040;display:flex;align-items:flex-end;justify-content:flex-end;padding:20px}.admin-agent-panel{width:420px;max-width:calc(100vw - 40px);height:560px;max-height:calc(100vh - 100px);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000002e;display:flex;flex-direction:column;overflow:hidden}.admin-agent-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.admin-agent-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;color:#111827}.admin-agent-dot{width:8px;height:8px;border-radius:50%;background:#10b981;flex-shrink:0}.admin-agent-close{background:none;border:none;color:#9ca3af;font-size:1rem;padding:4px 8px;cursor:pointer;border-radius:6px;line-height:1}.admin-agent-close:hover{background:#f3f4f6;color:#374151}.admin-agent-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.admin-agent-welcome p{font-size:.88rem;color:#374151;margin:0 0 12px}.admin-agent-suggestions{display:flex;flex-wrap:wrap;gap:6px}.admin-agent-suggestion{background:#f3f4f6;color:#374151;font-size:.8rem;padding:6px 12px;border-radius:999px;border:1px solid #e5e7eb;cursor:pointer;transition:background .15s}.admin-agent-suggestion:hover{background:#e5e7eb}.admin-agent-msg{display:flex}.admin-agent-msg.user{justify-content:flex-end}.admin-agent-msg.ai{justify-content:flex-start}.admin-agent-bubble{max-width:82%;padding:9px 13px;border-radius:14px;font-size:.875rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.admin-agent-msg.user .admin-agent-bubble{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.admin-agent-msg.ai .admin-agent-bubble{background:#f3f4f6;color:#111827;border-bottom-left-radius:4px}.admin-agent-thinking{display:flex;align-items:center;gap:4px;padding:12px 16px}.admin-agent-thinking span{width:6px;height:6px;border-radius:50%;background:#9ca3af;animation:agent-bounce 1.2s infinite}.admin-agent-thinking span:nth-child(2){animation-delay:.2s}.admin-agent-thinking span:nth-child(3){animation-delay:.4s}@keyframes agent-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.admin-agent-error{font-size:.8rem;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:8px 12px}.admin-agent-input-row{display:flex;gap:8px;padding:12px 14px;border-top:1px solid #f3f4f6;flex-shrink:0}.admin-agent-input{flex:1;resize:none;border:1px solid #e5e7eb;border-radius:10px;padding:9px 12px;font-size:.875rem;font-family:inherit;line-height:1.4;max-height:120px;overflow-y:auto;margin:0}.admin-agent-input:focus{outline:none;border-color:#2563eb}.admin-agent-send{padding:9px 16px;font-size:.85rem;border-radius:10px;flex-shrink:0;align-self:flex-end}.quote-toolbar{display:flex;align-items:center;gap:8px;padding:10px 0 12px;border-bottom:1px solid #e5e7eb;margin-bottom:12px;flex-wrap:wrap}.quote-toolbar button{padding:7px 14px;font-size:.82rem}.quote-toolbar-sep{flex:1}.quote-toolbar-count{font-size:.82rem;font-weight:600;color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:4px 10px;white-space:nowrap}.quote-list-panel{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.quote-empty-hint{color:#9ca3af;font-size:.88rem;margin:8px 0 0}.quote-select-all-row{display:flex;align-items:center;gap:8px;padding:4px 14px 6px}.quote-select-all-row label{font-size:.8rem;color:#6b7280;cursor:pointer;-webkit-user-select:none;user-select:none}.quote-list-row{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 10px;border:1px solid #e5e7eb;border-left:4px solid #e5e7eb;border-radius:10px;background:#fff;transition:border-color .15s,background .15s}.quote-list-row.checked{background:#eff6ff;border-color:#93c5fd;border-left-color:#2563eb}.quote-list-row.selected{border-color:#2563eb}.qlr-body{display:flex;align-items:center;gap:10px;flex:1;min-width:0;padding:6px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.qlr-body:focus-visible{outline:2px solid #2563eb;outline-offset:2px;border-radius:4px}.qlr-body:hover .qlr-ref{border-color:#93c5fd}.quote-list-row.status-draft{border-left-color:#d1d5db}.quote-list-row.status-sent{border-left-color:#3b82f6}.quote-list-row.status-approved{border-left-color:#10b981;background:#f0fdf4}.quote-list-row.status-approved.checked{background:#dcfce7}.quote-list-row.status-invoiced{border-left-color:#8b5cf6}.qlr-checkbox{width:16px;height:16px;flex-shrink:0;cursor:pointer;accent-color:#2563eb}.qlr-ref{font-size:.78rem;font-weight:600;color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe;border-radius:5px;padding:2px 7px;white-space:nowrap}.qlr-title{font-size:.88rem;font-weight:500;color:#111827}.qlr-customer{font-size:.82rem;color:#6b7280}.qlr-spacer{flex:1}.qlr-total{font-size:.88rem;font-weight:600;color:#111827}.qlr-status{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:999px;white-space:nowrap}.qlr-status.draft{background:#f3f4f6;color:#6b7280}.qlr-status.sent{background:#dbeafe;color:#1d4ed8}.qlr-status.approved{background:#d1fae5;color:#065f46}.qlr-status.invoiced{background:#ede9fe;color:#5b21b6}.quote-detail{border:1px solid #e5e7eb;border-radius:12px;padding:18px 20px 20px;background:#fff}.qd-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid #f3f4f6}.qd-header-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1}.qd-title{font-size:.92rem;font-weight:600;color:#111827}.qd-overview{margin-bottom:14px;padding:10px 12px;background:#f9fafb;border-radius:8px;border:1px solid #f3f4f6}.qd-summary{margin:0 0 4px;font-size:.88rem;color:#374151}.qd-notes{margin:0;font-size:.82rem;color:#6b7280}.qd-status-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid #f3f4f6}.qd-status-actions button{padding:8px 16px;font-size:.82rem}.inv-shell{padding:24px;max-width:1200px}.inv-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.inv-title{margin:0;font-size:1.3rem;font-weight:700;color:#111827;flex:1}.inv-summary{display:flex;gap:8px;flex-wrap:wrap}.inv-filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.inv-search{flex:1;min-width:200px;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.88rem}.inv-category{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.88rem;background:#fff;cursor:pointer}.inv-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.76rem;font-weight:600;letter-spacing:.01em}.inv-badge--ok{background:#dcfce7;color:#15803d}.inv-badge--low{background:#fef9c3;color:#a16207}.inv-badge--out{background:#fee2e2;color:#dc2626}.inv-badge--total{background:#f3f4f6;color:#374151}.inv-table-wrap{overflow-x:auto;border:1px solid #e5e7eb;border-radius:10px}.inv-table{width:100%;border-collapse:collapse;font-size:.85rem}.inv-table thead{background:#f9fafb;border-bottom:1px solid #e5e7eb}.inv-table th{padding:10px 12px;text-align:left;font-weight:600;color:#6b7280;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.inv-table td{padding:10px 12px;border-bottom:1px solid #f3f4f6;color:#111827;vertical-align:middle}.inv-table tbody tr:last-child td{border-bottom:none}.inv-table tbody tr:hover{background:#f9fafb}.inv-row--out{background:#fff5f5}.inv-row--out:hover{background:#fee2e2}.inv-row--low{background:#fffbeb}.inv-row--low:hover{background:#fef9c3}.inv-num{text-align:right}.inv-mono{font-family:monospace;font-size:.8rem;color:#6b7280}.inv-cat{display:inline-block;padding:2px 8px;background:#f3f4f6;border-radius:12px;font-size:.76rem;color:#374151;text-transform:capitalize}.inv-stock{font-weight:600;color:#111827}.inv-reserved{color:#6b7280}.inv-actions{display:flex;gap:6px;justify-content:flex-end;white-space:nowrap}:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f4f7fb;color:#1d2939}button,input,textarea{font:inherit}button{cursor:pointer}
