:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#747bff}body{margin:0;min-width:320px;min-height:100vh;width:100%;height:100vh;overflow:hidden}#root{width:100%;height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.technician-selector{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.technician-selector h3{margin-bottom:.75rem;color:#1e293b;font-size:1.125rem;font-weight:600}.technician-description{color:#64748b;font-size:.875rem;margin-bottom:1rem}.no-technicians{color:#94a3b8;font-style:italic;text-align:center;padding:2rem}.technicians-list{display:flex;flex-direction:column;gap:1rem}.technician-item{border:2px solid #e2e8f0;border-radius:.5rem;padding:1rem;transition:all .2s}.technician-item:has(.checkbox-root[data-state=checked]){border-color:#3b82f6;background:#eff6ff}.technician-checkbox{display:flex;align-items:flex-start;gap:.75rem}.checkbox-root{width:1.25rem;height:1.25rem;border-radius:.25rem;border:2px solid #cbd5e1;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin-top:.125rem}.checkbox-root:hover{border-color:#3b82f6}.checkbox-root[data-state=checked]{background:#3b82f6;border-color:#3b82f6}.checkbox-indicator{color:#fff;font-size:1rem;font-weight:700}.technician-label{cursor:pointer;display:flex;flex-direction:column;gap:.25rem;flex:1}.technician-name{font-weight:600;color:#1e293b;font-size:1rem}.technician-rates{font-size:.875rem;color:#64748b}.technician-rate-edit{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.technician-rate-edit label{font-size:.875rem;color:#64748b;font-weight:500;white-space:nowrap}.rate-input-group{display:flex;align-items:center;gap:.5rem}.rate-input{width:100px;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.rate-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.rate-unit{font-size:.875rem;color:#64748b;font-weight:500}@media(max-width:768px){.technician-selector{padding:1rem}.technician-selector h3{font-size:1rem}.technician-item{padding:.75rem}.rate-input{width:80px;padding:.4rem}.technician-rate-edit{flex-direction:column;align-items:flex-start}}.configurator-page{flex:1;padding:2rem;overflow-y:auto;height:100%;margin-bottom:50px}.page-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:2rem;height:100%}.top-grid{display:grid;grid-template-columns:1fr 350px;gap:2rem;align-items:start}@media(max-width:1024px){.top-grid{grid-template-columns:1fr}}@media(max-width:768px){.configurator-page{padding:1rem}.page-content,.top-grid{gap:1rem}}.catalog-section,.quote-section{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.catalog-section h2,.quote-section h2{margin-bottom:1.5rem;color:#1e293b}.search-bar{position:relative;margin-bottom:1.5rem}.search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid #e2e8f0;border-radius:.5rem;font-size:.95rem;transition:all .2s;background:#f8fafc}.search-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:#94a3b8}.clear-search{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:#e2e8f0;color:#64748b;border:none;border-radius:.25rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1.2rem;line-height:1}.clear-search:hover{background:#cbd5e1;color:#1e293b}.empty-quote{color:#64748b;text-align:center;padding:2rem}.no-results{color:#64748b;text-align:center;padding:2rem;font-style:italic;background:#f8fafc;border-radius:.5rem;border:2px dashed #e2e8f0}.global-search-results{display:flex;flex-direction:column;gap:2rem}.search-category-section{background:#fff;border-radius:.5rem;padding:1rem;border:1px solid #e2e8f0}.search-category-title{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #3b82f6}.no-global-results{text-align:center;padding:3rem 2rem;background:#f8fafc;border-radius:.5rem;border:2px dashed #e2e8f0}.no-global-results p:first-child{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.no-global-results p:last-child{color:#64748b;font-size:.875rem;font-style:italic}.tabs-root{width:100%}.tabs-list{display:flex;gap:.25rem;padding-bottom:1.5rem}.tabs-trigger{background:transparent;border:none;padding:.75rem 1.5rem;cursor:pointer;color:#64748b;font-weight:500;border-bottom:2px solid transparent;transition:all .2s}.tabs-trigger:hover{background:#f8fafc;color:#1e293b}.tabs-trigger[data-state=active]{color:#3b82f6;border-bottom-color:#3b82f6;background:transparent}.tabs-content{animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog-overlay{background:#00000080;position:fixed;inset:0;animation:fadeIn .2s}.dialog-content{background:#fff;border-radius:.5rem;box-shadow:0 10px 25px #0003;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90vw;max-width:500px;max-height:85vh;padding:1.5rem;animation:slideIn .2s}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.dialog-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:#1e293b}.dialog-description{color:#64748b;margin-bottom:1.5rem}.pack-items{margin-bottom:1.5rem}.pack-items h4{font-size:.875rem;font-weight:600;margin-bottom:1rem;color:#475569;text-transform:uppercase;letter-spacing:.05em}.pack-items-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.pack-item-detail{padding:.875rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;transition:all .2s}.pack-item-detail:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d}.pack-item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.pack-item-badge{display:inline-block;padding:.25rem .5rem;background:#3b82f6;color:#fff;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:.25rem}.pack-item-quantity{font-size:.875rem;font-weight:600;color:#64748b;background:#fff;padding:.25rem .5rem;border-radius:.25rem;border:1px solid #e2e8f0}.pack-item-info{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.pack-item-name{font-size:.9375rem;font-weight:500;color:#1e293b;flex:1}.pack-item-price{font-size:.875rem;font-weight:600;color:#0f172a;background:#fff;padding:.25rem .625rem;border-radius:.375rem;border:1px solid #e2e8f0;white-space:nowrap}.dialog-actions{display:flex;gap:.75rem;justify-content:flex-end}.qty-control{display:inline-flex;align-items:center;gap:.5rem}.qty-button{background:#eef2ff;border:1px solid #c7d2fe;color:#0f172a;border-radius:.375rem;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;padding:0}.qty-button:hover{background:#e0e7ff}.qty-button:disabled{opacity:.5;cursor:not-allowed}.qty-input{width:56px;text-align:center;padding:.35rem .4rem;border:1px solid #e2e8f0;border-radius:.375rem;background:#fff;font-size:.95rem}.qty-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614}.billing-group{display:flex;gap:.5rem;align-items:center}.billing-select{padding:.4rem .6rem;border:1px solid #e2e8f0;border-radius:.375rem;background:#fff;font-size:.95rem;color:#0f172a}.billing-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f60f}.add-button{padding:.4rem .6rem;border-radius:.375rem;border:1px solid transparent;background:#3b82f6;color:#fff;cursor:pointer;font-size:.95rem}.add-button:hover{background:#2563eb}.add-button.secondary{background:#e2e8f0;color:#0f172a}@media(max-width:768px){.qty-input{width:48px}.qty-button{width:28px;height:28px;font-size:16px}}.summary-page{flex:1;padding:2rem;overflow-y:auto;height:100%}.page-content{max-width:1400px;margin:0 auto;height:100%;padding-bottom:4rem}@media(max-width:768px){.summary-page{padding:1rem}}.summary-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.summary-header-row h2{color:#1e293b;margin:0}.location-mode-toggle{padding:8px 16px;border:2px solid #e2e8f0;border-radius:6px;background:#fff;color:#374151;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.location-mode-toggle:hover{border-color:#f59e0b;background:#fffbeb;color:#92400e}.location-mode-toggle.active{background:#f59e0b;border-color:#f59e0b;color:#fff}.location-section{background:#fffbeb;border:2px solid #f59e0b;border-radius:8px;padding:20px;margin-bottom:24px}.location-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.location-header h3{margin:0;font-size:16px;font-weight:700;color:#92400e}.duration-selector{display:flex;gap:8px;flex-wrap:wrap}.duration-btn{padding:6px 14px;border:2px solid #fcd34d;border-radius:6px;background:#fff;color:#92400e;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.duration-btn:hover{border-color:#f59e0b;background:#fef3c7}.duration-btn.active{background:#f59e0b;border-color:#f59e0b;color:#fff}.location-config-info{display:flex;gap:16px;font-size:13px;color:#92400e;margin-bottom:16px;flex-wrap:wrap}.location-config-info span strong{color:#78350f}.location-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.location-card{background:#fff;border:1px solid #fcd34d;border-radius:8px;padding:14px 16px}.location-card.highlight{border-color:#f59e0b}.location-card.total{background:#f59e0b;border-color:#d97706}.location-card-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#78350f;margin-bottom:6px}.location-card.total .location-card-label{color:#fff}.location-card-value{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:4px}.location-card.total .location-card-value{color:#fff;font-size:22px}.location-card-sub{font-size:11px;color:#92400e;line-height:1.4}.location-card.total .location-card-sub{color:#ffffffd9}.location-finance{margin-top:20px;padding-top:20px;border-top:2px dashed #fcd34d}.location-finance-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#92400e;margin-bottom:12px}.location-finance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.location-finance-card{background:#fff;border:1px solid #fcd34d;border-radius:8px;padding:14px 16px}.lf-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#78350f;margin-bottom:6px}.lf-value{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:4px}.lf-cost{color:#64748b}.lf-sub{font-size:11px;color:#92400e;line-height:1.4}.location-finance-card.lf-positive{background:#f0fdf4;border-color:#86efac}.location-finance-card.lf-positive .lf-label{color:#15803d}.location-finance-card.lf-positive .lf-value{color:#16a34a}.location-finance-card.lf-positive .lf-sub{color:#4ade80}.location-finance-card.lf-negative{background:#fef2f2;border-color:#fca5a5}.location-finance-card.lf-negative .lf-label{color:#991b1b}.location-finance-card.lf-negative .lf-value{color:#dc2626}.location-finance-card.lf-negative .lf-sub{color:#f87171}.location-finance-card.lf-roi{border-width:2px}.page-content>h2{margin-bottom:1.5rem;color:#1e293b}.empty-summary{background:#fff;border-radius:.5rem;padding:3rem;text-align:center;box-shadow:0 1px 3px #0000001a}.empty-summary h2{color:#1e293b;margin-bottom:1rem}.empty-summary p{color:#64748b;margin-bottom:1.5rem}.summary-section{background:#fff;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.summary-section h3{margin-bottom:1rem;color:#1e293b;font-size:1.125rem}.labor-section{background:#eff6ff;border:2px solid #3b82f6;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.labor-section h3{color:#1e40af;font-size:1.25rem;font-weight:700;margin-bottom:1rem}.labor-summary{display:flex;flex-direction:column;gap:1.5rem}.labor-header{background:#fff;padding:1rem;border-radius:.375rem;border:1px solid #bfdbfe}.labor-hours{color:#1e40af;font-size:1rem}.labor-hours strong{font-size:1.125rem;color:#1e3a8a}.labor-technicians{background:#fff;padding:1rem;border-radius:.375rem;border:1px solid #bfdbfe}.labor-technicians h4{font-size:.875rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.labor-technician-line{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f1f5f9;gap:1rem}.labor-technician-line:last-child{border-bottom:none}.tech-name{font-weight:600;color:#1e293b;white-space:nowrap}.tech-details{color:#64748b;font-size:.875rem;text-align:right}.labor-totals{background:#fff;padding:1rem;border-radius:.375rem;border:2px solid #3b82f6}.labor-total-line{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e0e7ff}.labor-total-line:last-child{border-bottom:none}.labor-total-line.highlight{padding:.75rem;margin:.5rem -.5rem -.5rem;background:#dbeafe;border-radius:0 0 .25rem .25rem}.labor-total-line span{color:#475569;font-size:.875rem}.labor-total-line strong{color:#1e293b;font-size:1.125rem}.labor-total-line.highlight span{font-weight:600;font-size:1rem}.labor-total-line.highlight strong{font-size:1.25rem}.labor-total-line .positive{color:#16a34a}.labor-total-line .negative{color:#dc2626}.financials-wrapper{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.financials-kpi-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:#e2e8f0;border:1px solid #e2e8f0;border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #00000014}.kpi-block{background:#fff;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}.kpi-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.kpi-value{font-size:1.5rem;font-weight:700;color:#1e293b;line-height:1.2}.kpi-cost{color:#64748b}.kpi-sub{font-size:.8125rem;color:#94a3b8}.kpi-block.kpi-divider,.kpi-block.kpi-profit,.kpi-block.kpi-profit-total{border-left:3px solid #e2e8f0}.kpi-block.kpi-positive{background:#f0fdf4}.kpi-block.kpi-positive .kpi-value{color:#16a34a}.kpi-block.kpi-positive .kpi-sub{color:#4ade80}.kpi-block.kpi-negative{background:#fef2f2}.kpi-block.kpi-negative .kpi-value{color:#dc2626}.kpi-block.kpi-negative .kpi-sub{color:#f87171}.billing-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.billing-card{background:#fff;border-radius:.5rem;padding:1.25rem;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:0}.billing-card-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#475569;margin-bottom:.75rem}.billing-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px solid #f1f5f9}.billing-row:last-child{border-bottom:none}.billing-row span{font-size:.8125rem;color:#64748b}.billing-row strong{font-size:.9375rem;font-weight:600;color:#1e293b}.billing-row-ttc{opacity:.65}.billing-row-ttc span,.billing-row-ttc strong{font-size:.8125rem}.billing-row-cost{border-top:1px dashed #e2e8f0;margin-top:.25rem;padding-top:.5rem}.billing-row-cost span{color:#94a3b8}.billing-row-cost strong{color:#94a3b8;font-weight:500}.billing-row-margin{border-top:1px solid #e2e8f0;margin-top:.25rem;padding-top:.5rem}.billing-row-margin span{font-weight:600;color:#374151}.billing-row-margin.positive strong{color:#16a34a}.billing-row-margin.negative strong{color:#dc2626}.json-section{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.json-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.json-header h3{color:#1e293b;font-size:1.125rem}.json-actions{display:flex;gap:.75rem;align-items:center}.json-actions button{padding:.5rem 1rem;border-radius:.375rem;border:none;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.json-actions button:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.json-actions button.primary{background:#3b82f6;color:#fff}.json-actions button.primary:hover{background:#2563eb}.json-actions button.secondary{background:#e2e8f0;color:#1e293b}.json-actions button.secondary:hover{background:#cbd5e1}.json-error{background:#fef2f2;border:2px solid #fca5a5;color:#991b1b;padding:1rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem;font-weight:500}.json-preview{background:#1e293b;color:#e2e8f0;padding:1.5rem;border-radius:.375rem;overflow-x:auto;font-family:Courier New,monospace;font-size:.875rem;line-height:1.5;max-height:600px;overflow-y:auto}.json-editor{width:100%;min-height:600px;background:#1e293b;color:#e2e8f0;padding:1.5rem;border:2px solid #3b82f6;border-radius:.375rem;font-family:Courier New,monospace;font-size:.875rem;line-height:1.5;resize:vertical;outline:none}.json-editor:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f61a}.save-section{margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.save-dialog{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.save-name-input{padding:.5rem .75rem;border:2px solid #3b82f6;border-radius:.375rem;font-size:.875rem;outline:none;min-width:280px}.save-name-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #3b82f61a}.save-error{font-size:.8125rem;color:#dc2626;font-weight:500}.save-success{padding:.5rem 1rem;background:#dcfce7;color:#15803d;border:1px solid #86efac;border-radius:.375rem;font-size:.875rem;font-weight:600}.nav-buttons{display:flex;gap:.75rem;align-items:center}@media(max-width:768px){.financials-kpi-bar{grid-template-columns:1fr 1fr}.billing-breakdown{grid-template-columns:1fr}.summary-section{padding:1rem}.summary-section h3{font-size:1rem}.labor-section{padding:1rem}.labor-section h3{font-size:1.125rem}.labor-summary{gap:1rem}.labor-technician-line{flex-direction:column;align-items:flex-start;gap:.5rem}.tech-details{text-align:left;font-size:.8rem}.labor-total-line{flex-wrap:wrap}.labor-total-line strong{font-size:1rem}.labor-total-line.highlight strong{font-size:1.125rem}table{font-size:.75rem;display:block;overflow-x:auto;white-space:nowrap}th,td{padding:.5rem}.json-section{padding:1rem}.json-preview{padding:1rem;font-size:.75rem}.json-header{flex-direction:column;align-items:flex-start;gap:1rem}.json-actions{width:100%;flex-direction:column}.json-actions button{width:100%}.json-editor{min-height:400px;font-size:.75rem;padding:1rem}.nav-buttons{flex-direction:column}.nav-buttons button{width:100%}}@media(max-width:1024px){.financials-kpi-bar,.billing-breakdown{grid-template-columns:repeat(2,1fr)}}.editor-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center}.editor-modal{background:#fff;padding:16px;width:480px;border-radius:6px}.editor-root{display:flex;flex-direction:column;gap:8px}.editor-header h3{margin:0 0 8px}.editor-body{display:flex;flex-direction:column;gap:12px}.editor-field label{display:block;font-size:13px;color:#374151;margin-bottom:6px}.editor-field input,.editor-field textarea,.editor-field select{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #e5e7eb}.editor-field input[type=checkbox]{width:auto;margin-right:6px}.editor-field small{display:block;margin-top:4px;font-size:11px;color:#6b7280}.editor-row{display:flex;gap:12px}.editor-row .editor-field{flex:1}.editor-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.secondary{background:#f3f4f6;border:1px solid #e5e7eb;padding:8px 10px;border-radius:6px;cursor:pointer}button[disabled]{opacity:.6;cursor:not-allowed}.pack-selected-items{margin-top:12px;margin-bottom:16px;padding:12px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px}.pack-selected-items h4{margin:0 0 10px;font-size:13px;color:#166534;font-weight:600}.pack-selected-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border-radius:6px;margin-bottom:6px;border:1px solid #86efac}.pack-selected-type{font-size:10px;color:#166534;text-transform:uppercase;font-weight:600;min-width:90px;padding:2px 6px;background:#dcfce7;border-radius:4px;text-align:center}.pack-selected-name{flex:1;font-size:13px;color:#0f172a;font-weight:500}.pack-selected-quantity{width:70px!important;padding:4px 6px!important;font-size:13px;border:1px solid #86efac!important;border-radius:4px;text-align:center}.pack-selected-remove{padding:4px 10px;background:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500}.pack-selected-remove:hover{background:#dc2626}.pack-catalog-section{margin-top:16px;padding:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.pack-catalog-section h4{margin:0 0 12px;font-size:13px;color:#0f172a;font-weight:600}.pack-search-bar{position:relative;margin-bottom:12px}.pack-search-input{width:100%;padding:10px 36px 10px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:13px;background:#fff;transition:all .2s}.pack-search-input:focus{outline:none;border-color:#0f172a;box-shadow:0 0 0 3px #0f172a1a}.pack-search-input::placeholder{color:#94a3b8}.pack-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#e2e8f0;border:none;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;font-size:14px;transition:all .2s}.pack-search-clear:hover{background:#cbd5e1;color:#0f172a}.pack-catalog-tabs{display:flex;gap:6px;margin-bottom:12px;border-bottom:2px solid #e2e8f0;padding-bottom:2px}.pack-tab{padding:8px 14px;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:13px;font-weight:500;color:#64748b;transition:all .2s;margin-bottom:-2px}.pack-tab:hover{color:#0f172a;background:#f1f5f9;border-radius:6px 6px 0 0}.pack-tab.active{color:#0f172a;border-bottom-color:#0f172a;font-weight:600}.pack-catalog-list{max-height:300px;overflow-y:auto;padding:4px}.pack-no-results{padding:40px 20px;text-align:center;color:#64748b;font-size:13px;font-style:italic}.pack-catalog-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:8px;transition:all .2s}.pack-catalog-item:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d}.pack-catalog-item.in-pack{background:#f0fdf4;border-color:#86efac}.pack-catalog-info{display:flex;flex-direction:column;gap:4px;flex:1}.pack-catalog-name{font-size:13px;font-weight:500;color:#0f172a}.pack-catalog-ref{font-size:11px;color:#64748b}.pack-catalog-price{font-size:12px;color:#0f172a;font-weight:600}.pack-catalog-actions{display:flex;align-items:center;gap:8px}.pack-catalog-quantity{width:60px!important;padding:4px 6px!important;font-size:13px;border:1px solid #86efac!important;border-radius:4px;text-align:center}.pack-catalog-add{padding:6px 14px;background:#0f172a;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;white-space:nowrap;transition:all .2s}.pack-catalog-add:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.pack-catalog-remove{padding:6px 12px;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s}.pack-catalog-remove:hover{background:#dc2626}.admin-page{padding:16px}.admin-header{display:flex;justify-content:space-between;align-items:center}.admin-nav a{margin-right:8px}.admin-controls{margin:12px 0}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:8px;border:1px solid #ddd}.error{color:red}.admin-page-root{display:flex;justify-content:center;padding:24px 12px;background:#f4f6f8;min-height:calc(100vh - 80px)}.admin-top-tabs{margin-bottom:16px;display:flex;justify-content:center}.tabs-list{display:flex;gap:8px}.tabs-trigger{background:#fff;border:1px solid #e6edf3;padding:8px 12px;border-radius:999px;cursor:pointer;font-weight:500;color:#0f172a;box-shadow:0 1px 3px #0f172a0a}.tabs-trigger[aria-selected=true]{background:#0f172a;color:#fff;border-color:#0f172a}.admin-main-container{width:80%;max-width:1200px;background:#fff;border-radius:12px;padding:20px;box-shadow:0 8px 30px #0f172a0f}.admin-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.admin-controls button{margin-left:8px;padding:8px 12px;border-radius:8px;border:none;background:#0f172a;color:#fff;cursor:pointer}.admin-controls button.secondary{background:#eef2f7;color:#0f172a;border:1px solid #e6edf3}.admin-search-bar{margin-bottom:16px}.admin-search-input{width:100%;padding:10px 14px;border-radius:8px;border:1px solid #e6edf3;font-size:14px;background:#f8fafc}.admin-search-input:focus{outline:none;border-color:#0f172a;background:#fff}.table-wrap{overflow-x:auto;overflow-y:auto;max-height:60vh;border-radius:8px;border:1px solid #e6edf3}.admin-table{width:100%;border-collapse:separate;border-spacing:0 8px}.admin-table thead th{text-align:left;padding:12px 14px;color:#64748b;font-weight:600}.admin-table tbody tr{background:linear-gradient(180deg,#fff,#fff);box-shadow:0 2px 6px #02061708}.admin-table td{padding:12px 14px}.admin-table tr td:last-child{text-align:right}.dialog-overlay{position:fixed;inset:0;background:#02061773;z-index:50}.dialog-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:24px;border-radius:12px;width:720px;max-width:96%;box-shadow:0 20px 60px #0206171f;z-index:51;max-height:90vh;overflow-y:auto}.dialog-content h3,.dialog-content h2{margin-top:0}.dialog-content-large{width:900px;max-width:96%}.error{color:#bf1650}@media(max-width:1000px){.admin-main-container{width:95%;padding:16px}.tabs-list{gap:6px}}@media(max-width:600px){.tabs-list{flex-wrap:wrap;justify-content:center}.tabs-trigger{font-size:13px;padding:6px 8px}.admin-controls button{padding:6px 8px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:420px;padding:40px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{margin:0 0 10px;color:#333;font-size:28px;font-weight:700}.login-header p{margin:0 0 8px;color:#666;font-size:16px}.sso-hint{font-size:14px!important;color:#999!important;font-style:italic}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .3s ease;outline:none}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;border-left:4px solid #c33;font-size:14px}.login-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center;padding-top:24px;border-top:1px solid #e0e0e0}.info-text{margin:0;color:#999;font-size:13px;text-align:center;font-style:italic}.saved-quotes-page{flex:1;padding:2rem;overflow-y:auto;height:100%}.saved-quotes-page .page-content{max-width:900px;margin:0 auto;padding-bottom:4rem}.saved-quotes-page h2{margin-bottom:1.5rem;color:#1e293b}.empty-saved{background:#fff;border-radius:.5rem;padding:3rem;text-align:center;box-shadow:0 1px 3px #0000001a}.empty-saved h3{color:#1e293b;margin-bottom:.75rem}.empty-saved p{color:#64748b;margin-bottom:1.5rem}.quotes-list{display:flex;flex-direction:column;gap:1rem}.quote-card{background:#fff;border-radius:.5rem;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.quote-card:hover{box-shadow:0 4px 12px #0000001a}.quote-card-info{flex:1;min-width:0}.quote-card-name{font-size:1.125rem;font-weight:600;color:#1e293b;margin-bottom:.375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quote-card-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.8125rem;color:#64748b}.quote-card-meta span:before{content:""}.quote-card-meta span+span:before{content:"·";margin-right:1rem}.quote-card-actions{display:flex;gap:.5rem;flex-shrink:0}@media(max-width:640px){.saved-quotes-page{padding:1rem}.quote-card{flex-direction:column;align-items:flex-start}.quote-card-actions{width:100%}.quote-card-actions button{flex:1}}.location-config-page{min-height:100vh;background:#f8fafc;padding:24px 0}.location-config-page .page-content{max-width:860px;margin:0 auto;padding:0 24px}.location-config-page h2{font-size:22px;font-weight:700;color:#1e293b;margin:0 0 8px}.location-config-desc{color:#64748b;font-size:14px;margin:0 0 24px;line-height:1.5}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:16px}.location-config-table-wrap{overflow-x:auto;border:1px solid #e2e8f0;border-radius:8px;background:#fff}.location-config-table{width:100%;border-collapse:collapse}.location-config-table th{background:#f1f5f9;padding:12px 16px;text-align:center;font-size:13px;font-weight:700;color:#374151;border-bottom:1px solid #e2e8f0}.location-config-table th:first-child{text-align:left}.location-config-table td{padding:10px 16px;border-bottom:1px solid #f1f5f9;text-align:center;vertical-align:middle}.location-config-table td:first-child{text-align:left}.location-config-table tbody tr:last-child td{border-bottom:none}.param-label{font-size:14px;font-weight:600;color:#374151;white-space:nowrap}.pct-input{width:70px;padding:5px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;text-align:right;color:#1e293b;background:#f9fafb;transition:border-color .15s}.pct-input:focus{outline:none;border-color:#3b82f6;background:#fff}.pct-symbol{margin-left:4px;font-size:13px;color:#64748b}.actions-row td{padding:12px 16px;background:#fafafa}.save-btn{padding:6px 14px;border:1px solid #d1d5db;border-radius:5px;font-size:13px;font-weight:500;background:#fff;color:#374151;cursor:pointer;transition:all .15s}.save-btn:disabled{opacity:.5;cursor:not-allowed}.save-btn.has-changes{background:#3b82f6;color:#fff;border-color:#3b82f6}.save-btn.has-changes:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.save-success-inline{font-size:13px;font-weight:600;color:#16a34a}.location-config-legend{margin-top:24px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px 20px}.location-config-legend h4{font-size:14px;font-weight:700;color:#374151;margin:0 0 10px}.location-config-legend ul{margin:0;padding-left:18px}.location-config-legend li{font-size:13px;color:#64748b;margin-bottom:6px;line-height:1.5}.location-config-legend li strong{color:#374151}.app-navbar{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#0b1220;color:#fff}.brand{font-weight:700;font-size:18px;color:#fff;margin-right:18px}.nav-left{display:flex;align-items:center;gap:12px}.main-links{display:flex;gap:10px}.nav-right{display:flex;align-items:center;gap:16px}.nav-link{color:#cbd5e1;text-decoration:none;padding:6px 10px;border-radius:6px;font-weight:500}.nav-link.active{background:#ffffff0f;color:#fff}.nav-link:hover{background:#ffffff08}.admin-links{display:flex;gap:8px}.admin-links .nav-link{background:transparent;padding:6px 8px}.admin-links .nav-link.active{background:#ffffff0f}.user-section{display:flex;align-items:center;gap:12px;margin-left:16px;padding-left:16px;border-left:1px solid rgba(255,255,255,.1)}.user-name{color:#cbd5e1;font-size:14px;font-weight:500}.logout-button{background:#dc262633;color:#fca5a5;border:1px solid rgba(220,38,38,.3);padding:6px 12px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.logout-button:hover{background:#dc26264d;border-color:#dc262666;color:#fff}@media(max-width:800px){.admin-links{display:none}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}.app-container{width:100%;height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{background:#1e293b;color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a}.app-header h1{font-size:1.75rem;font-weight:600}.loading,.error{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:50vh;padding:2rem;text-align:center}.error h2{color:#dc2626;margin-bottom:1rem}.error p{color:#64748b;margin-bottom:.5rem}button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .2s}button:hover{background:#2563eb}button:disabled{background:#cbd5e1;cursor:not-allowed}button.secondary{background:#64748b}button.secondary:hover{background:#475569}button.danger{background:#dc2626}button.danger:hover{background:#b91c1c}input[type=number]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem;width:80px}input[type=number]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}table{width:100%;border-collapse:collapse;background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}th{background:#f1f5f9;padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.875rem;color:#475569;text-transform:uppercase;letter-spacing:.05em}td{padding:.75rem 1rem;border-top:1px solid #e2e8f0;font-size:.875rem}.nav-buttons{display:flex;gap:1rem;margin-top:2rem;padding-bottom:2rem}@media(max-width:768px){.app-header{padding:1rem}.app-header h1{font-size:1.25rem}button{padding:.4rem .8rem;font-size:.8rem}input[type=number]{width:60px;padding:.4rem}th,td{font-size:.75rem;padding:.5rem .75rem}}@media(max-width:480px){.app-header{padding:.75rem}.app-header h1{font-size:1rem}}
