: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%}@media(max-width:768px){.summary-page{padding:1rem}}.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}.totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}.totals-section{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.totals-section h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:#475569;text-transform:uppercase;letter-spacing:.05em}.total-line{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.total-line:last-child{border-bottom:none}.total-line span{color:#64748b;font-size:.875rem}.total-line strong{color:#1e293b;font-size:1.125rem}.margin-section{background:#f8fafc;border:2px solid #e2e8f0}.margin-section .positive{color:#16a34a}.margin-section .negative{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}@media(max-width:768px){.totals-grid{grid-template-columns:1fr;gap:1rem}.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){.totals-grid{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}.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}@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}}
