:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;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:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}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:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#4f46e5,#7c3aed,#9333ea);padding:1rem}.login-container:before{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(255,255,255,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.login-card{background:#fff;padding:2.5rem 2.5rem 2rem;border-radius:20px;box-shadow:0 20px 60px #00000040,0 4px 16px #0000001a;width:100%;max-width:420px;animation:slideUp .4s cubic-bezier(.16,1,.3,1);position:relative;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-logo{display:flex;justify-content:center;margin-bottom:1.25rem}.login-logo svg{width:72px;height:72px;filter:drop-shadow(0 4px 12px rgba(79,70,229,.35))}.login-card h1{font-size:1.375rem;font-weight:700;color:#111827;text-align:center;margin:0 0 .35rem;letter-spacing:-.02em}.login-subtitle{font-size:.875rem;color:#6b7280;text-align:center;margin:0 0 2rem}.alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:10px;margin-bottom:1.25rem;font-size:.875rem}.alert-error{background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.login-card .form-group{margin-bottom:1.25rem}.login-card .form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.4rem}.login-card .input-wrapper{position:relative;display:flex;align-items:center}.login-card .input-icon{position:absolute;left:.875rem;color:#9ca3af;display:flex;align-items:center;pointer-events:none;z-index:2}.login-card .input-toggle{position:absolute;right:.5rem;background:none;border:none;cursor:pointer;color:#9ca3af;display:flex;align-items:center;padding:.25rem;border-radius:4px;transition:color .15s;z-index:2}.login-card .input-toggle:hover{color:#6b7280}.login-card .form-control{width:100%;padding:.65rem 2.5rem .65rem 2.75rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.9375rem;color:#111827;background:#f9fafb;transition:border-color .15s,box-shadow .15s,background .15s;outline:none;box-sizing:border-box;position:relative;z-index:1}.login-card .form-control::placeholder{color:#d1d5db}.login-card .form-control:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11f}.btn-login{width:100%;padding:.75rem;margin-top:.75rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:opacity .2s,transform .1s,box-shadow .2s;box-shadow:0 4px 14px #6366f166;letter-spacing:.01em}.btn-login:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #6366f180}.btn-login:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f159}.btn-login:disabled{opacity:.65;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.login-footer{margin-top:2rem;padding-top:1.25rem;border-top:1px solid #f3f4f6;text-align:center;color:#9ca3af;font-size:.78rem}.login-footer p{margin:0}.chart-card{padding:1.5rem;margin-bottom:1.5rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.chart-title{font-size:1.25rem;margin-bottom:1rem;color:#333;font-weight:600}.chart-empty{height:200px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:.9rem;font-style:italic}.recharts-wrapper{margin:0 auto}.recharts-legend-wrapper{padding-top:1rem}.recharts-legend-item{margin-right:1rem!important}.recharts-default-tooltip{background:#fff!important;border:1px solid #ccc!important;border-radius:4px!important;padding:.5rem!important;box-shadow:0 2px 8px #00000026!important}.recharts-tooltip-label{font-weight:600;margin-bottom:.25rem;color:#333}.recharts-tooltip-item{color:#666!important}@media(max-width:768px){.chart-card{padding:1rem}.chart-title{font-size:1.1rem}}.dashboard h1{margin-bottom:2rem;color:#333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;border-left:4px solid #007bff}.stat-card.warning{border-left-color:#ffc107}.stat-card.stat-card-blue{border-left-color:#2563eb}.stat-card.stat-card-orange{border-left-color:#f59e0b}.stat-card.stat-card-green{border-left-color:#10b981}.stat-card.stat-card-gray{border-left-color:#6b7280}.dashboard-section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#6b7280;margin-bottom:.75rem;padding-left:2px}.stat-card h3{font-size:.875rem;color:#666;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-number{font-size:2.5rem;font-weight:700;color:#333;margin:.5rem 0}.stat-label{font-size:.875rem;color:#666;margin:0}.card h2{margin-bottom:1rem;color:#333}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}@media(max-width:768px){.charts-grid{grid-template-columns:1fr}}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-height:90vh;overflow-y:auto;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-small{width:90%;max-width:400px}.modal-medium{width:90%;max-width:600px}.modal-large{width:90%;max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.modal-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background-color:#f5f5f5;color:#333}.modal-body{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #dee2e6}.btn-cancel{background-color:#6c757d;color:#fff}.btn-cancel:hover{background-color:#5a6268}select.form-control{cursor:pointer}textarea.form-control{min-height:100px;resize:vertical}.search-bar{position:relative;flex:1;max-width:400px}.search-input{width:100%;padding:.5rem 2.5rem .5rem 1rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.search-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:#666;pointer-events:none}.filter-panel{margin-bottom:1rem}.filter-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.filter-toggle{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid #dee2e6;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s}.filter-toggle:hover{background-color:#f8f9fa;border-color:#007bff}.filter-toggle svg{color:#666}.filter-count{background-color:#007bff;color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.btn-clear-filters{background:none;border:none;color:#dc3545;cursor:pointer;font-size:.875rem;padding:.25rem .5rem;text-decoration:underline}.btn-clear-filters:hover{color:#c82333}.filter-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;background:#fff;padding:1rem;border:1px solid #dee2e6;border-radius:4px;margin-top:.5rem}.filter-item{display:flex;flex-direction:column}.filter-item label{font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:#495057}.filter-item .form-control{font-size:.875rem}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #dee2e6}.pagination-info{font-size:.875rem;color:#666}.pagination{display:flex;gap:.25rem;align-items:center}.pagination-btn{padding:.375rem .75rem;border:1px solid #dee2e6;background:#fff;color:#495057;cursor:pointer;border-radius:4px;font-size:.875rem;transition:all .2s;min-width:40px}.pagination-btn:hover:not(:disabled){background-color:#f8f9fa;border-color:#007bff;color:#007bff}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.active{background-color:#007bff;color:#fff;border-color:#007bff}.pagination-ellipsis{padding:.375rem .5rem;color:#666}@media(max-width:768px){.pagination-container{flex-direction:column;gap:1rem}.pagination-info{text-align:center}}.file-upload-container{width:100%}.file-drop-zone{border:2px dashed #cbd5e0;border-radius:8px;padding:2rem;text-align:center;transition:all .3s ease;background:#f8f9fa;cursor:pointer}.file-drop-zone:hover{border-color:#667eea;background:#f1f3ff}.file-drop-zone.active{border-color:#667eea;background:#e6e9ff;transform:scale(1.02)}.file-input-hidden{display:none}.file-input-label{cursor:pointer;display:block;width:100%}.upload-icon{width:48px;height:48px;margin:0 auto 1rem;color:#667eea}.upload-text{font-size:1rem;color:#333;margin-bottom:.5rem;font-weight:500}.file-size{font-size:.875rem;color:#666;margin-bottom:.5rem}.upload-hint{font-size:.875rem;color:#999;margin:0}.file-upload-form{margin-top:1.5rem}.file-upload-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}@media(max-width:480px){.file-drop-zone{padding:1.5rem 1rem}.upload-icon{width:36px;height:36px}.upload-text{font-size:.875rem}.file-upload-actions{flex-direction:column}.file-upload-actions button{width:100%}}.attachment-list{margin-top:1.5rem}.attachment-list h4{margin-bottom:1rem;color:#333;font-size:1.1rem}.loading-small{padding:1rem;text-align:center;color:#666;font-size:.875rem}.no-attachments{padding:2rem;text-align:center;background:#f8f9fa;border-radius:8px;border:1px dashed #cbd5e0}.no-attachments p{color:#999;margin:0}.attachments-grid{display:grid;gap:1rem}.attachment-card{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px;transition:all .2s ease}.attachment-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#667eea}.attachment-icon{font-size:2rem;flex-shrink:0}.attachment-info{flex:1;min-width:0}.attachment-name{font-weight:500;margin:0 0 .25rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-meta{font-size:.75rem;color:#999;margin:0 0 .5rem}.attachment-description{font-size:.875rem;color:#666;margin:0 0 .5rem;line-height:1.4}.attachment-uploader{font-size:.75rem;color:#999;margin:0}.attachment-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-icon{width:36px;height:36px;padding:.5rem;border:1px solid #e0e0e0;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-icon svg{width:20px;height:20px;color:#666}.btn-icon:hover{background:#667eea;border-color:#667eea}.btn-icon:hover svg{color:#fff}.btn-delete:hover{background:#dc3545;border-color:#dc3545}@media(max-width:768px){.attachment-card{flex-direction:column}.attachment-actions{width:100%;justify-content:flex-end}}.comment-form{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.comment-form .form-group{margin-bottom:.75rem}.comment-textarea{resize:vertical;min-height:80px;font-family:inherit}.comment-form-actions{display:flex;justify-content:space-between;align-items:center}.comment-hint{font-size:.75rem;color:#999}.error-message{color:#dc3545;font-size:.875rem;margin-top:.25rem}@media(max-width:768px){.comment-form-actions{flex-direction:column;gap:.5rem;align-items:stretch}.comment-hint{order:2;text-align:center}.comment-form-actions button{order:1}}.comment-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.no-comments{padding:2rem;text-align:center;background:#f8f9fa;border-radius:8px;border:1px dashed #cbd5e0}.no-comments p{color:#999;margin:0}.comment-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;transition:box-shadow .2s ease}.comment-item:hover{box-shadow:0 2px 8px #00000014}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.comment-author{display:flex;align-items:center;gap:.75rem}.author-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.author-info{display:flex;flex-direction:column;gap:.125rem}.author-info strong{font-size:.875rem;color:#333}.comment-role{font-size:.75rem;color:#999;text-transform:capitalize}.comment-meta{display:flex;align-items:center;gap:.5rem}.comment-date{font-size:.75rem;color:#999}.comment-edited{font-size:.7rem;color:#999;font-style:italic}.comment-text{font-size:.875rem;color:#333;line-height:1.6;margin-bottom:.5rem;white-space:pre-wrap;word-wrap:break-word}.comment-actions{display:flex;gap:1rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #f0f0f0}.btn-text{background:none;border:none;color:#667eea;font-size:.75rem;font-weight:500;cursor:pointer;padding:0;transition:color .2s ease}.btn-text:hover{color:#4c5fd5;text-decoration:underline}.btn-text-danger{color:#dc3545}.btn-text-danger:hover{color:#c82333}.comment-edit-form{margin-top:.5rem}.comment-edit-form .form-control{width:100%;margin-bottom:.5rem}.edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn-cancel{background:#f0f0f0;color:#666;border:1px solid #e0e0e0}.btn-cancel:hover{background:#e0e0e0}@media(max-width:768px){.comment-header{flex-direction:column;gap:.5rem}.author-avatar{width:36px;height:36px;font-size:.8rem}.comment-actions{flex-wrap:wrap}}.wrp{display:flex;flex-direction:column;gap:18px}.wrp-filters{padding:20px 24px}.wrp-section-title{font-size:15px;font-weight:700;color:#111827;margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid #f3f4f6}.wrp-filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.wrp-field{display:flex;flex-direction:column;gap:4px}.wrp-label{font-size:12px;font-weight:600;color:#374151}.wrp-field-action{align-self:flex-end}.wrp-btn-generate{width:100%;padding:10px 20px;font-weight:600;font-size:14px}.wrp-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.wrp-stat{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:14px 18px;display:flex;flex-direction:column;gap:3px}.wrp-stat-num{font-size:28px;font-weight:700;line-height:1;color:#374151}.wrp-stat-lbl{font-size:11px;text-transform:uppercase;color:#9ca3af;letter-spacing:.5px}.wrp-stat-blue .wrp-stat-num{color:#2563eb}.wrp-stat-orange .wrp-stat-num{color:#d97706}.wrp-stat-green .wrp-stat-num{color:#059669}.wrp-stat-purple .wrp-stat-num{color:#7c3aed}.wrp-results-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.wrp-results-title{font-size:16px;font-weight:700;color:#111827;margin:0 0 4px;display:flex;align-items:center;gap:10px}.wrp-customer-tag{font-size:12px;font-weight:600;background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;border-radius:12px;padding:2px 10px}.wrp-results-sub{font-size:12px;color:#9ca3af;margin:0}.wrp-export-btns{display:flex;gap:8px;flex-shrink:0}.wrp-btn-excel{display:flex;align-items:center;gap:6px;background:#16a34a;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.wrp-btn-excel:hover:not(:disabled){background:#15803d}.wrp-btn-excel:disabled{opacity:.5;cursor:not-allowed}.wrp-btn-pdf{display:flex;align-items:center;gap:6px;background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.wrp-btn-pdf:hover:not(:disabled){background:#b91c1c}.wrp-btn-pdf:disabled{opacity:.5;cursor:not-allowed}.wrp-summary-card{padding:16px 20px}.wrp-summary-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6b7280;margin:0 0 12px}.wrp-summary-grid{display:flex;flex-wrap:wrap;gap:8px}.wrp-summary-item{display:flex;align-items:center;gap:8px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:6px 12px}.wrp-summary-name{font-size:13px;font-weight:600;color:#111827}.wrp-summary-ruc{font-size:11px;color:#9ca3af}.wrp-summary-count{font-size:13px;font-weight:700;color:#2563eb;background:#eff6ff;border-radius:10px;padding:1px 8px}.wrp-table-card{padding:0;overflow:hidden}.wrp-table-wrap{overflow-x:auto}.wrp-table{margin:0}.wrp-rec-num{font-family:monospace;font-size:12px;font-weight:700;color:#2563eb}.wrp-customer-cell,.wrp-asset-cell,.wrp-warranty-cell{display:flex;flex-direction:column;gap:2px;font-size:13px}.wrp-customer-cell small,.wrp-asset-cell small,.wrp-warranty-cell small{font-size:11px;color:#9ca3af}.wrp-warranty-type{font-size:11px;font-weight:600;color:#4b5563;text-transform:capitalize}.wrp-expired{color:#dc2626!important}.wrp-expiring{color:#d97706!important}.wrp-no-warranty{font-size:11px;color:#d1d5db;font-style:italic}.wrp-mono{font-family:monospace;font-size:12px;color:#374151}.wrp-date{font-size:12px;white-space:nowrap}.wrp-na{color:#d1d5db}.wr-badge{display:inline-block;padding:2px 9px;border-radius:10px;font-size:10px;font-weight:700;white-space:nowrap}.wr-badge-blue{background:#dbeafe;color:#1e40af}.wr-badge-purple{background:#ede9fe;color:#5b21b6}.wr-badge-red{background:#fee2e2;color:#991b1b}.wr-badge-orange{background:#fef3c7;color:#92400e}.wr-badge-green{background:#d1fae5;color:#065f46}.wr-badge-gray{background:#f3f4f6;color:#6b7280}.wrp-condition-dot{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--dot-color)}.wrp-condition-dot:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dot-color);flex-shrink:0}.wrp-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:14px 20px;border-top:1px solid #f3f4f6}.wrp-page-info{font-size:13px;color:#6b7280}.wrp-empty{text-align:center;color:#9ca3af;font-size:14px;padding:40px 20px;margin:0}.wrp-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:12px;color:#9ca3af;text-align:center}.wrp-placeholder-icon{font-size:40px;opacity:.6}.wrp-placeholder p{font-size:14px;margin:0;max-width:380px;line-height:1.6}.wrp-placeholder strong{color:#374151}@media(max-width:1100px){.wrp-filter-grid{grid-template-columns:repeat(2,1fr)}.wrp-stats{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.wrp-filter-grid{grid-template-columns:1fr}.wrp-stats{grid-template-columns:repeat(2,1fr)}.wrp-results-header{flex-direction:column}.wrp-export-btns{width:100%}.wrp-btn-excel,.wrp-btn-pdf{flex:1;justify-content:center}}.reports-page{max-width:1400px;margin:0 auto}.reports-header{margin-bottom:2rem}.reports-header h1{margin-bottom:.5rem;color:#333}.reports-subtitle{color:#666;font-size:1rem;margin:0}.reports-tabs{display:flex;gap:4px;border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem}.reports-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s;border-radius:4px 4px 0 0}.reports-tab:hover{color:#667eea;background:#f5f7ff}.reports-tab.active{color:#667eea;border-bottom-color:#667eea;font-weight:700;background:#fff}.reports-content{display:flex;flex-direction:column;gap:1.5rem}.report-selection-card h2,.export-actions-card h2,.report-info-card h2{font-size:1.25rem;margin-bottom:1.5rem;color:#333}.report-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.report-type-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#fff}.report-type-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a;transform:translateY(-2px)}.report-type-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.report-icon{font-size:2rem;flex-shrink:0}.report-label{font-size:1rem;font-weight:500;flex:1}.report-badge-pdf{font-size:.65rem;font-weight:700;background:#e0e7ff;color:#3730a3;padding:2px 7px;border-radius:10px;white-space:nowrap;flex-shrink:0}.report-type-card.selected .report-badge-pdf{background:#ffffff4d;color:#fff}.export-buttons{display:flex;gap:1rem;flex-wrap:wrap}.btn-export{flex:1;min-width:200px;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s ease}.btn-export:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.btn-export:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-icon{width:20px;height:20px}.btn-success{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1aa179)}.btn-danger{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#c82333,#bd2130)}.report-info-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.info-item{padding:1rem;border-left:4px solid #667eea;background:#f8f9fa;border-radius:4px}.info-item h3{font-size:1rem;margin-bottom:.5rem;color:#333}.info-item p{font-size:.875rem;color:#666;margin:0;line-height:1.5}@media(max-width:768px){.report-types{grid-template-columns:1fr}.export-buttons{flex-direction:column}.btn-export{width:100%}.report-info-content{grid-template-columns:1fr}}@media(max-width:480px){.reports-header h1{font-size:1.5rem}.reports-subtitle{font-size:.875rem}.report-type-card{padding:1rem}.report-icon{font-size:1.5rem}.report-label{font-size:.875rem}}.analytics-page{max-width:1400px;margin:0 auto}.analytics-header{margin-bottom:2rem}.analytics-header h1{margin-bottom:.5rem;color:#333}.analytics-subtitle{color:#666;font-size:1rem;margin:0}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.summary-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.summary-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.summary-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.summary-content{flex:1}.summary-content h3{font-size:.875rem;color:#666;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px}.summary-number{font-size:2rem;font-weight:700;color:#333;margin:0;line-height:1}.summary-label{font-size:.875rem;color:#999}.section-title{font-size:1.5rem;margin:2rem 0 1.5rem;color:#333;padding-bottom:.5rem;border-bottom:2px solid #667eea}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:1.5rem;margin-bottom:2rem}@media(max-width:1024px){.charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.summary-cards{grid-template-columns:1fr}.summary-card{padding:1.25rem}.summary-icon{width:50px;height:50px;font-size:1.5rem}.summary-number{font-size:1.75rem}.section-title{font-size:1.25rem}}@media(max-width:480px){.analytics-header h1{font-size:1.5rem}.analytics-subtitle{font-size:.875rem}.summary-card{flex-direction:column;text-align:center;gap:1rem}.summary-icon{margin:0 auto}}.reception-form{display:flex;flex-direction:column;gap:0}.form-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid var(--border-color, #e5e7eb)}.tab-btn{background:none;border:none;padding:8px 20px;cursor:pointer;font-size:14px;color:var(--text-secondary, #6b7280);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.tab-btn:hover{color:var(--primary, #667eea)}.tab-btn.active{color:var(--primary, #667eea);border-bottom-color:var(--primary, #667eea);font-weight:600}.tab-content{display:flex;flex-direction:column;gap:16px;min-height:260px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color, #e5e7eb)}.customer-picker-group{background:#f0f4ff;border:1px solid #c7d2fe;border-radius:8px;padding:12px 14px}.customer-picker{position:relative;display:flex;align-items:center;gap:8px}.customer-picker .form-control{flex:1}.btn-clear-customer{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer;padding:4px 8px;border-radius:4px;line-height:1;flex-shrink:0}.btn-clear-customer:hover{color:#ef4444;background:#fee2e2}.customer-suggestions{list-style:none;margin:4px 0 0;padding:0;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto}.customer-suggestions li{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:13px;border-bottom:1px solid #f3f4f6}.customer-suggestions li:last-child{border-bottom:none}.customer-suggestions li:hover{background:#f0f4ff}.suggestion-name{font-weight:600;color:#111827;flex:1}.suggestion-ruc{font-size:11px;color:#6b7280;background:#f3f4f6;padding:1px 6px;border-radius:4px}.suggestion-phone{font-size:11px;color:#9ca3af}.customer-linked-badge{margin-top:6px;font-size:11px;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:4px;padding:3px 8px;display:inline-block}.traceability-container{display:flex;flex-direction:column;gap:20px}.current-location-banner{display:flex;align-items:center;justify-content:space-between;background:#f9fafb;border-radius:8px;padding:16px;border:1px solid #e5e7eb}.location-indicator{display:flex;align-items:center;gap:12px}.location-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.location-indicator.workshop .location-dot{background:#10b981;box-shadow:0 0 0 3px #10b98133}.location-indicator.external_service .location-dot{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.location-indicator>div{display:flex;flex-direction:column;gap:2px}.location-label{font-size:11px;text-transform:uppercase;color:#6b7280;letter-spacing:.5px}.location-indicator strong{font-size:15px;color:#111827}.location-detail{font-size:12px;color:#6b7280}.move-form{padding:16px;background:#fffbeb;border:1px solid #fbbf24;border-radius:8px;display:flex;flex-direction:column;gap:12px}.move-form h4{margin:0;font-size:14px;font-weight:600;color:#92400e}.move-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.timeline-section h4{margin:0 0 16px;font-size:14px;font-weight:600;color:#374151}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:12px;padding-bottom:20px}.timeline-marker{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:16px}.marker-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:4px}.timeline-item.workshop .marker-dot{background:#10b981}.timeline-item.external_service .marker-dot{background:#f59e0b}.marker-line{width:2px;flex:1;background:#e5e7eb;margin-top:4px}.timeline-content{flex:1;padding-bottom:4px}.timeline-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.location-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px}.location-badge.workshop{background:#d1fae5;color:#065f46}.location-badge.external_service{background:#fef3c7;color:#92400e}.timeline-date{font-size:11px;color:#9ca3af}.timeline-detail{font-size:13px;font-weight:500;color:#374151;margin-bottom:2px}.timeline-notes{font-size:12px;color:#6b7280;font-style:italic;margin-bottom:2px}.timeline-user{font-size:11px;color:#9ca3af}.loading-text,.empty-state{text-align:center;color:#9ca3af;padding:24px 0;font-size:14px}.tr-overlay{position:fixed;inset:0;background:#00000080;z-index:300;display:flex;justify-content:flex-end}.tr-panel{background:#fff;width:580px;max-width:100vw;height:100%;display:flex;flex-direction:column;box-shadow:-6px 0 32px #00000026;animation:trSlideIn .25s ease}@keyframes trSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.tr-header{display:flex;align-items:flex-start;gap:12px;padding:18px 20px 14px;background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;flex-shrink:0}.tr-header-info{flex:1;min-width:0}.tr-reception-num{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:#fff3;padding:2px 8px;border-radius:10px;display:inline-block;margin-bottom:4px}.tr-header h2{margin:4px 0 2px;font-size:17px}.tr-header p{margin:0;font-size:12px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tr-close{background:none;border:none;color:#ffffffb3;font-size:26px;line-height:1;cursor:pointer;padding:0;flex-shrink:0;margin-top:-2px}.tr-close:hover{color:#fff}.tr-tabs{display:flex;gap:0;background:#f8fafc;border-bottom:1px solid #e5e7eb;flex-shrink:0;overflow-x:auto}.tr-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 14px;font-size:12px;font-weight:500;color:#6b7280;cursor:pointer;white-space:nowrap;transition:all .15s}.tr-tab:hover{color:#2563eb}.tr-tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600;background:#fff}.tr-body{flex:1;overflow-y:auto;padding:20px}.tr-section{display:flex;flex-direction:column;gap:12px}.tr-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#2563eb;margin:0 0 2px}.tr-hint{font-size:12px;color:#9ca3af;margin:0;line-height:1.5}.tr-textarea{width:100%;border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;font-size:13px;font-family:inherit;color:#111827;resize:vertical;transition:border-color .15s;box-sizing:border-box;line-height:1.6}.tr-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.tr-input{width:100%;border:1px solid #e5e7eb;border-radius:8px;padding:8px 12px;font-size:13px;color:#111827;box-sizing:border-box}.tr-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.tr-label{font-size:12px;font-weight:600;color:#374151;margin-bottom:4px;display:block}.tr-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tr-field{display:flex;flex-direction:column}.condition-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.condition-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .15s;background:#fafafa}.condition-card input{display:none}.condition-card:hover{border-color:var(--cond-color);background:#fff}.condition-card.selected{border-color:var(--cond-color);background:#f0f4ff}.cond-dot{width:16px;height:16px;border-radius:50%;background:var(--cond-color)}.cond-label{font-size:11px;font-weight:600;color:#374151;text-align:center}.condition-card.selected .cond-label{color:var(--cond-color)}.condition-preview{border:1.5px solid;border-radius:6px;padding:8px 12px;font-size:13px;background:#f9fafb}.tr-dropzone{border:2px dashed #d1d5db;border-radius:12px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:6px;background:#fafafa}.tr-dropzone:hover,.tr-dropzone.dragging{border-color:#2563eb;background:#eff6ff}.tr-dropzone.uploading{cursor:not-allowed;opacity:.7}.dz-icon{font-size:32px}.dz-text{display:flex;flex-direction:column;gap:2px}.dz-text strong{font-size:14px;color:#374151}.dz-text span{font-size:12px;color:#6b7280}.dz-hint{font-size:11px;color:#9ca3af;margin-top:4px}.dz-uploading{display:flex;align-items:center;gap:10px;color:#2563eb;font-size:14px}.dz-spinner{width:20px;height:20px;border:3px solid #bfdbfe;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tr-file-list{display:flex;flex-direction:column;gap:6px;margin-top:4px}.tr-file-item{display:flex;align-items:center;gap:10px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:8px 10px}.file-thumb{width:48px;height:48px;border-radius:6px;background-size:cover;background-position:center;flex-shrink:0;cursor:pointer;border:1px solid #e5e7eb}.file-icon-box{width:48px;height:48px;border-radius:6px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.file-name{font-size:13px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:11px;color:#9ca3af}.file-actions{display:flex;gap:4px;flex-shrink:0}.btn-file-action{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:4px 7px;cursor:pointer;font-size:14px;line-height:1;color:#6b7280;transition:all .15s}.btn-file-action:hover{background:#f3f4f6;color:#374151}.btn-file-delete:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.tr-empty{text-align:center;color:#9ca3af;font-size:13px;padding:16px 0;margin:0}.tr-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid #e5e7eb;background:#f9fafb;flex-shrink:0;gap:12px}.tr-footer-left{flex:1;min-width:0}.tr-footer-right{display:flex;gap:8px;flex-shrink:0}.tr-saved-info{font-size:11px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.tr-lightbox{position:fixed;inset:0;z-index:500;background:#000000d9;display:flex;align-items:center;justify-content:center}.tr-lightbox-inner{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:8px}.tr-lightbox-inner img{max-width:100%;max-height:82vh;border-radius:8px;object-fit:contain}.tr-lb-close{position:absolute;top:-36px;right:0;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;line-height:1}.tr-lb-name{color:#ffffffb3;font-size:12px;margin:0}.btn-outline-pdf{background:transparent;border:1.5px solid #6366f1;color:#6366f1;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.btn-outline-pdf:hover{background:#6366f1;color:#fff}@media(max-width:640px){.tr-panel{width:100vw}.condition-grid{grid-template-columns:repeat(3,1fr)}.tr-row{grid-template-columns:1fr}}.receptions-page{padding:24px;display:flex;flex-direction:column;gap:20px}.page-header{display:flex;justify-content:space-between;align-items:flex-start}.page-header h1{margin:0;font-size:24px;color:#111827}.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-number{font-size:28px;font-weight:700;color:#374151;line-height:1}.stat-label{font-size:12px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.stat-card-blue .stat-number{color:#2563eb}.stat-card-orange .stat-number{color:#d97706}.stat-card-green .stat-number{color:#059669}.stat-card-gray .stat-number{color:#6b7280}.filters-bar{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.reception-number{font-family:monospace;font-weight:600;font-size:13px;color:#667eea}.customer-cell{display:flex;flex-direction:column;gap:2px}.customer-cell strong{font-size:14px}.customer-cell small{font-size:12px;color:#9ca3af}.customer-linked-tag{font-size:10px;font-weight:600;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;padding:1px 7px;width:fit-content;cursor:default}.asset-cell{display:flex;flex-direction:column;gap:2px;max-width:160px}.asset-cell span{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-cell small{font-size:11px;color:#9ca3af}.location-tag{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;white-space:nowrap}.location-tag.workshop{background:#d1fae5;color:#065f46}.location-tag.external_service{background:#fef3c7;color:#92400e}.location-tag-detail{font-weight:400;opacity:.8}.status-cell{display:flex;align-items:center;gap:4px;position:relative}.status-menu-wrapper{position:relative}.btn-icon-sm{background:none;border:1px solid #e5e7eb;border-radius:4px;padding:2px 6px;cursor:pointer;font-size:10px;color:#6b7280;line-height:1}.btn-icon-sm:hover{background:#f3f4f6}.status-dropdown{position:absolute;top:100%;left:0;z-index:100;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:180px;overflow:hidden}.status-dropdown button{display:block;width:100%;padding:8px 14px;text-align:left;background:none;border:none;cursor:pointer;font-size:13px;color:#374151}.status-dropdown button:hover{background:#f9fafb}.action-buttons{display:flex;flex-wrap:wrap;gap:4px}.report-condition-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.no-report-tag{font-size:11px;color:#d1d5db;font-style:italic}.btn-report-new{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.btn-report-new:hover{background:#dbeafe}.btn-report-done{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.btn-report-done:hover{background:#d1fae5}.badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.badge-info{background:#dbeafe;color:#1e40af}.badge-warning{background:#fef3c7;color:#92400e}.badge-primary{background:#ede9fe;color:#4c1d95}.badge-danger{background:#fee2e2;color:#991b1b}@media(max-width:1200px){.stats-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.stats-row{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;gap:12px}}.catalogs-page{padding:24px;display:flex;flex-direction:column;gap:20px}.catalogs-header h1{margin:0;font-size:24px;color:#111827}.catalogs-tabs{display:flex;gap:0;border-bottom:2px solid #e5e7eb}.catalog-tab{background:none;border:none;padding:10px 24px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:8px;transition:color .2s}.catalog-tab:hover{color:#667eea}.catalog-tab.active{color:#667eea;border-bottom-color:#667eea}.tab-count{background:#e0e7ff;color:#3730a3;font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px;min-width:22px;text-align:center}.catalog-tab.active .tab-count{background:#667eea;color:#fff}.tab-panel{display:flex;flex-direction:column;gap:16px}.panel-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.panel-info p{margin:0;font-size:13px;color:#6b7280}.panel-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.toggle-inactive{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;cursor:pointer;-webkit-user-select:none;user-select:none}.types-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px}.type-column{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.type-column-header{background:#f9fafb;padding:12px 16px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.type-column-header h3{margin:0;font-size:14px;font-weight:600;color:#374151}.col-count{font-size:12px;font-weight:700;color:#6b7280;background:#e5e7eb;padding:2px 8px;border-radius:10px}.col-empty{padding:24px;text-align:center;color:#9ca3af;font-size:13px}.type-list{display:flex;flex-direction:column;gap:0}.type-card{border-bottom:1px solid #f3f4f6;padding:12px 16px;display:flex;flex-direction:column;gap:8px;transition:background .15s}.type-card:last-child{border-bottom:none}.type-card:hover{background:#fafafa}.type-card.inactive{opacity:.55}.type-card-main{display:flex;align-items:center;gap:10px}.type-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.type-card-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.type-name{font-size:14px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.type-desc{font-size:11px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.type-asset-count{font-size:12px;font-weight:600;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:10px;flex-shrink:0}.type-card-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.inactive-badge{font-size:10px;font-weight:700;color:#9ca3af;background:#f3f4f6;padding:2px 8px;border-radius:10px;text-transform:uppercase}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.category-card{padding:20px;display:flex;flex-direction:column;gap:12px}.category-card-header{display:flex;align-items:center;gap:12px}.category-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0}.category-info h3{margin:0;font-size:15px;color:#111827}.asset-count-badge{font-size:11px;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:10px}.category-description{margin:0;font-size:13px;color:#6b7280;line-height:1.4}.category-actions{display:flex;gap:8px;margin-top:auto}.catalog-form{display:flex;flex-direction:column;gap:16px}.base-type-toggle{display:flex;gap:0;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.base-type-btn{flex:1;padding:8px 16px;border:none;background:#fff;font-size:14px;cursor:pointer;transition:all .15s;color:#6b7280}.base-type-btn:hover{background:#f9fafb}.base-type-btn.active.hw{background:#dbeafe;color:#1d4ed8;font-weight:600}.base-type-btn.active.sw{background:#dcfce7;color:#15803d;font-weight:600}.color-picker{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.color-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s;padding:0}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:#111827;transform:scale(1.15)}.color-custom{width:26px;height:26px;border-radius:50%;border:2px solid #e5e7eb;padding:0;cursor:pointer;background:none}.color-preview{margin-top:8px}.type-badge-preview{display:inline-block;padding:3px 12px;border-radius:12px;font-size:12px;font-weight:600}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:12px;border-top:1px solid #e5e7eb}.loading-text{text-align:center;color:#9ca3af;padding:40px;font-size:14px}.empty-catalog{text-align:center;padding:48px 24px;color:#6b7280;display:flex;flex-direction:column;align-items:center;gap:16px;background:#f9fafb;border-radius:10px;border:2px dashed #e5e7eb}.empty-catalog p{margin:0;font-size:14px}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:6px;padding:8px 12px;font-size:13px}@media(max-width:768px){.types-columns,.categories-grid{grid-template-columns:1fr}.panel-toolbar{flex-direction:column}}.customer-form{display:flex;flex-direction:column;gap:0}.cf-tabs{display:flex;gap:0;border-bottom:2px solid #e5e7eb;margin-bottom:20px}.cf-tab{background:none;border:none;padding:9px 22px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s;white-space:nowrap}.cf-tab:hover{color:#667eea}.cf-tab.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.cf-panel{display:flex;flex-direction:column;gap:14px;min-height:240px}.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-label.required:after{content:" *";color:#ef4444}.is-invalid{border-color:#ef4444!important}.field-error{display:block;font-size:11px;color:#ef4444;margin-top:3px}.contact-section-label{font-size:12px;color:#6b7280;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px}.cf-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #e5e7eb}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:6px;padding:8px 12px;font-size:13px;margin-bottom:12px}@media(max-width:600px){.cf-row{grid-template-columns:1fr}}.customers-page{padding:24px;display:flex;flex-direction:column;gap:20px}.cust-header{display:flex;justify-content:space-between;align-items:flex-start}.cust-header h1{margin:0;font-size:24px;color:#111827}.page-subtitle{margin:4px 0 0;color:#6b7280;font-size:14px}.cust-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.cust-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:18px 24px;display:flex;flex-direction:column;gap:4px}.cstat-num{font-size:32px;font-weight:700;color:#374151;line-height:1}.cstat-lbl{font-size:12px;text-transform:uppercase;color:#9ca3af;letter-spacing:.5px}.cst-green .cstat-num{color:#059669}.cst-gray .cstat-num{color:#9ca3af}.cust-filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.filter-select{width:auto;min-width:130px;flex-shrink:0}.ruc-cell{font-family:monospace;font-size:13px;color:#374151}.no-data{color:#d1d5db}.row-inactive td{opacity:.6}.empty-row{text-align:center;color:#9ca3af;padding:32px!important;font-size:14px}.name-link{background:none;border:none;padding:0;color:#667eea;font-weight:600;font-size:14px;cursor:pointer;text-decoration:underline;text-underline-offset:2px;text-align:left}.name-link:hover{color:#4f46e5}.phone-cell{display:flex;flex-direction:column;gap:2px}.phone-cell small{font-size:11px;color:#9ca3af}.contact-cell{display:flex;flex-direction:column;gap:2px}.contact-cell small{font-size:11px;color:#9ca3af}.activity-cell{max-width:220px;font-size:13px;color:#4b5563}.action-btns{display:flex;gap:4px;flex-wrap:wrap}.badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-secondary{background:#f3f4f6;color:#6b7280}.detail-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;justify-content:flex-end}.detail-panel{background:#fff;width:420px;max-width:100vw;height:100%;display:flex;flex-direction:column;box-shadow:-4px 0 24px #0000001f;animation:slideIn .25s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.detail-header{display:flex;align-items:center;gap:14px;padding:20px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.detail-avatar{width:52px;height:52px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;flex-shrink:0}.detail-header>div{flex:1;min-width:0}.detail-header h2{margin:0;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ruc-badge{display:inline-block;margin-top:4px;font-size:11px;background:#fff3;padding:2px 8px;border-radius:10px}.detail-close{background:none;border:none;color:#fffc;font-size:24px;cursor:pointer;line-height:1;padding:0;flex-shrink:0}.detail-close:hover{color:#fff}.detail-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}.detail-section h3{margin:0 0 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#667eea}.detail-row{display:flex;gap:8px;padding:7px 0;border-bottom:1px solid #f3f4f6;font-size:13px}.detail-label{flex-shrink:0;width:155px;color:#6b7280;font-weight:500}.detail-value{color:#111827;word-break:break-word}.no-data{color:#d1d5db;font-style:italic}.detail-activity,.detail-notes{margin:0;font-size:13px;color:#4b5563;line-height:1.6;background:#f9fafb;border-radius:6px;padding:10px 12px;border-left:3px solid #667eea}.detail-footer{padding:14px 20px;border-top:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}.detail-footer>div{display:flex;align-items:center;gap:12px}.detail-meta{font-size:11px;color:#9ca3af}@media(max-width:768px){.cust-stats{grid-template-columns:repeat(3,1fr)}.cust-header{flex-direction:column;gap:12px}.detail-panel{width:100vw}}.notification-panel{position:fixed;top:60px;right:20px;width:400px;max-height:600px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:999;display:flex;flex-direction:column;overflow:hidden}.notification-header{padding:1rem 1.25rem;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.notification-header-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.notification-header-title h3{margin:0;font-size:1.1rem;font-weight:600;color:#333}.unread-count{font-size:.75rem;color:#667eea;font-weight:500;background:#e8eaf6;padding:.25rem .5rem;border-radius:12px}.notification-header-actions{display:flex;align-items:center;gap:.5rem}.btn-link{background:none;border:none;color:#667eea;font-size:.875rem;cursor:pointer;padding:0;font-weight:500}.btn-link:hover{text-decoration:underline}.btn-close-panel{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;line-height:1}.btn-close-panel:hover{color:#333}.notification-list{flex:1;overflow-y:auto;max-height:450px}.no-notifications{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.no-notifications-icon{font-size:3rem;opacity:.3;margin-bottom:.5rem}.no-notifications p{color:#999;margin:0}.notification-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s ease;position:relative}.notification-item:hover{background:#f8f9fa}.notification-item.unread{background:#f5f7ff}.notification-item.unread:hover{background:#ebeeff}.notification-icon{font-size:1.5rem;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:8px}.notification-content{flex:1;min-width:0}.notification-title{font-weight:600;font-size:.875rem;color:#333;margin-bottom:.25rem}.notification-message{font-size:.8rem;color:#666;line-height:1.4;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{font-size:.75rem;color:#999}.notification-unread-dot{position:absolute;top:1.25rem;right:1rem;width:8px;height:8px;background:#667eea;border-radius:50%}.notification-footer{padding:.75rem 1.25rem;border-top:1px solid #e0e0e0;background:#f8f9fa}.btn-view-all{width:100%;padding:.5rem;background:none;border:none;color:#667eea;font-weight:500;cursor:pointer;border-radius:6px;transition:background .2s ease}.btn-view-all:hover{background:#e8eaf6}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f0f0f0}.notification-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media(max-width:768px){.notification-panel{top:56px;right:10px;left:10px;width:auto;max-height:calc(100vh - 70px)}.notification-header-actions{flex-direction:column;align-items:flex-start;gap:.25rem}}.notification-bell-container{position:relative}.notification-bell{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#333;transition:all .2s ease}.notification-bell:hover{background:#f0f0f0}.notification-bell.disconnected{opacity:.5}.notification-bell.disconnected:after{content:"";position:absolute;top:8px;right:8px;width:8px;height:8px;background:#ff9800;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.notification-bell svg{width:22px;height:22px}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 4px;display:flex;align-items:center;justify-content:center;background:#dc3545;color:#fff;font-size:.7rem;font-weight:600;border-radius:9px;line-height:1}.notification-overlay{position:fixed;inset:0;background:#0000004d;z-index:998}@media(max-width:768px){.notification-bell{width:36px;height:36px}.notification-bell svg{width:20px;height:20px}}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;gap:1rem}.navbar-brand h1{font-size:1.5rem;margin:0}.navbar-brand span{font-size:.875rem;opacity:.9}.navbar-menu{display:flex;gap:1rem;flex:1;justify-content:center}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav-link:hover,.nav-link.active{background-color:#fff3}.navbar-user{display:flex;align-items:center;gap:1rem}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-info small{font-size:.75rem;opacity:.8;text-transform:uppercase}.btn-sm{padding:.375rem .75rem;font-size:.875rem}.main-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}.navbar .notification-bell{color:#fff}.navbar .notification-bell:hover{background:#fff3}*{margin:0;padding:0;box-sizing:border-box}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-color:#f5f5f5}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:#666}.container{max-width:1200px;margin:0 auto;padding:2rem}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;margin-bottom:1rem}.btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.table{width:100%;border-collapse:collapse;margin-top:1rem}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid #dee2e6}.table th{background-color:#f8f9fa;font-weight:600}.badge{display:inline-block;padding:.25rem .5rem;font-size:.875rem;border-radius:4px}.badge-success{background-color:#d4edda;color:#155724}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-info{background-color:#d1ecf1;color:#0c5460}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-control{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem}.form-control:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.tabs-container{margin:1.5rem 0}.tabs{display:flex;border-bottom:2px solid #e0e0e0;gap:.5rem;margin-bottom:1.5rem}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#666;transition:all .2s ease;position:relative;bottom:-2px}.tab:hover{color:#667eea;background:#f8f9fa}.tab.active{color:#667eea;border-bottom-color:#667eea}.tab-content{padding:1rem 0}
