: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;display:flex;place-items:center;min-width:320px;min-height:100vh}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}}.app-layout{height:100vh;display:flex;flex-direction:column;background-color:#f8f9fa}.top-bar{height:60px;background-color:#fff;border-bottom:1px solid #e9ecef;display:flex;align-items:center;justify-content:space-between;padding:0 20px;box-shadow:0 2px 4px #0000001a;z-index:1000}.top-bar-left{display:flex;align-items:center;gap:15px}.menu-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.menu-button:hover{background-color:#f8f9fa}.app-title{margin:0;font-size:20px;font-weight:600;color:#212529}.top-bar-right{display:flex;align-items:center;gap:10px}.icon-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.icon-button:hover{background-color:#f8f9fa}.main-container{flex:1;display:flex;overflow:hidden}.sidebar{width:280px;background-color:#fff;border-right:1px solid #e9ecef;transition:width .3s ease,transform .3s ease;position:relative;z-index:999}.sidebar.collapsed{width:60px}.sidebar-nav{padding:20px 0}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#6c757d;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{background-color:#f8f9fa;color:#495057}.nav-item.active{background-color:#e7f3ff;color:#06c;border-left-color:#06c}.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:12px}.main-content{flex:1;padding:30px;overflow-y:auto;background-color:#f8f9fa}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:60px;height:calc(100vh - 60px);transform:translate(-100%);z-index:999}.sidebar:not(.collapsed){transform:translate(0)}.main-content{margin-left:0}}.searchable-dropdown{position:relative;width:100%}.selected-values{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.selected-tag{display:inline-flex;align-items:center;gap:6px;background-color:#e5e7eb;color:#374151;padding:4px 8px;border-radius:4px;font-size:12px;cursor:default}.selected-tag svg{cursor:pointer;color:#6b7280;transition:color .2s}.selected-tag svg:hover{color:#374151}.dropdown-menu{position:fixed;z-index:9999;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:300px;min-width:200px;overflow:hidden}.search-container{padding:12px;border-bottom:1px solid #e5e7eb}.options-container{max-height:200px;overflow-y:auto}.dropdown-option{padding:12px 16px;cursor:pointer;font-size:14px;color:#374151;transition:background-color .2s}.dropdown-option:hover{background-color:#f3f4f6}.dropdown-option.selected{background-color:#e5e7eb;color:#1f2937;font-weight:500}.no-options{padding:12px 16px;color:#6b7280;font-style:italic;text-align:center}.searchable-dropdown.disabled .dropdown-trigger{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.searchable-dropdown.disabled .dropdown-trigger:hover{border-color:#d1d5db}.business-class-dropdown{position:relative;width:100%}.dropdown-trigger{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s;min-height:44px}.dropdown-trigger:hover{border-color:#9ca3af}.dropdown-trigger.open{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dropdown-trigger.placeholder .dropdown-value{color:#9ca3af}.dropdown-value{flex:1;text-align:left;color:#374151;font-size:14px}.dropdown-arrow{color:#6b7280;transition:transform .2s;flex-shrink:0}.dropdown-trigger.open .dropdown-arrow{transform:rotate(180deg)}.selected-count{margin-top:8px;font-size:12px;color:#6b7280;font-style:italic}.dropdown-menu{position:fixed;z-index:9999;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:400px;min-width:300px;overflow:hidden}.search-container{padding:12px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.search-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;outline:none;transition:border-color .2s}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.options-container{max-height:320px;overflow-y:auto}.no-options{padding:16px;color:#6b7280;font-style:italic;text-align:center}.group-container{border-bottom:1px solid #f3f4f6}.group-container:last-child{border-bottom:none}.group-header{display:flex;align-items:center;padding:12px 16px;cursor:pointer;background:#f9fafb;transition:background-color .2s;border-bottom:1px solid #e5e7eb}.group-header:hover{background:#f3f4f6}.group-left{display:flex;align-items:center;gap:8px;margin-right:12px}.expand-button,.group-checkbox-btn{background:none;border:none;cursor:pointer;padding:2px;border-radius:2px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.expand-button:hover,.group-checkbox-btn:hover{background:#0000000d}.group-info{flex:1;display:flex;align-items:center;gap:8px}.group-name{font-weight:500;color:#374151;font-size:14px}.risk-count{font-size:12px;color:#6b7280;font-weight:400}.group-checkbox{color:#6b7280;transition:color .2s}.group-checkbox.selected{color:#3b82f6}.group-checkbox.partial{color:#f59e0b}.risk-codes-container{background:#fff;border-top:1px solid #e5e7eb}.risk-code-option{display:flex;align-items:center;gap:8px;padding:8px 48px;cursor:pointer;transition:background-color .2s;font-size:13px}.risk-code-option:hover{background:#f9fafb}.risk-code-option.selected{background:#eff6ff;color:#1e40af}.risk-code-checkbox{display:flex;align-items:center;justify-content:center}.risk-code-checkbox svg{color:#6b7280;transition:color .2s}.risk-code-checkbox svg.selected{color:#3b82f6}.risk-code{font-family:inherit;font-weight:400;color:#374151}.business-class-dropdown.disabled .dropdown-trigger{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.business-class-dropdown.disabled .dropdown-trigger:hover{border-color:#d1d5db}.options-container::-webkit-scrollbar{width:6px}.options-container::-webkit-scrollbar-track{background:#f1f5f9}.options-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.options-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dropdown-search{padding:12px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.dropdown-content{max-height:320px;overflow-y:auto}.no-results{padding:16px;color:#6b7280;font-style:italic;text-align:center}.business-group{border-bottom:1px solid #f3f4f6}.business-group:last-child{border-bottom:none}.group-header-content{display:flex;align-items:center;gap:8px;width:100%}.expand-icon{color:#6b7280;transition:transform .2s;flex-shrink:0}.expand-icon.expanded{transform:rotate(90deg)}.group-checkbox{display:flex;align-items:center;justify-content:center;cursor:pointer;padding:2px;border-radius:2px;transition:background-color .2s;flex-shrink:0}.group-checkbox:hover{background:#0000000d}.group-count{font-size:12px;color:#6b7280;font-weight:400;margin-left:auto}.risk-codes-list{background:#fff;border-top:1px solid #e5e7eb}.risk-code-item{display:flex;align-items:center;gap:8px;padding:8px 48px;cursor:pointer;transition:background-color .2s;font-size:13px}.risk-code-item:hover{background:#f9fafb}.risk-code-item.selected{background:#eff6ff;color:#1e40af}.risk-code-checkbox{display:flex;align-items:center;justify-content:center;flex-shrink:0}.risk-code-text{flex:1}.entity-form-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.entity-form{padding:0}.form-header{background:#f8f9fa;padding:20px 30px;border-bottom:1px solid #e9ecef}.form-header h2{margin:0;color:#212529;font-size:24px;font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:30px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-label{font-weight:500;color:#374151;margin-bottom:6px;font-size:14px}.required{color:#dc3545;margin-left:2px}.form-input,.form-textarea{padding:12px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s,box-shadow .2s;min-height:44px}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;min-height:auto;font-family:inherit}.error-message{color:#dc3545;font-size:12px;margin-top:4px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding:20px 30px;background:#f8f9fa;border-top:1px solid #e9ecef}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none;min-width:100px}.btn-primary:active{transform:translateY(1px)}.btn-secondary:active{transform:translateY(1px)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary:disabled:hover,.btn-secondary:disabled:hover{background-color:#3b82f6;transform:none}.btn-secondary:disabled:hover{background-color:#6b7280}@media (max-width: 768px){.form-grid{grid-template-columns:1fr;gap:16px;padding:20px}.form-actions{flex-direction:column;padding:20px}.form-header{padding:16px 20px}}.csv-upload-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;max-height:90vh;overflow-y:auto}.upload-header{display:flex;justify-content:space-between;align-items:flex-start;padding:30px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.header-content h2{margin:0 0 8px;color:#212529;font-size:24px;font-weight:600}.header-content p{margin:0;color:#6c757d;font-size:14px}.close-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;color:#6c757d;transition:all .2s}.close-button:hover{background:#0000000d;color:#495057}.upload-section{padding:30px}.template-download{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;margin-bottom:30px}.template-info{display:flex;align-items:center;gap:12px}.template-info svg{color:#856404;flex-shrink:0}.template-info h3{margin:0 0 4px;color:#856404;font-size:16px;font-weight:600}.template-info p{margin:0;color:#856404;font-size:14px}.file-upload{display:flex;flex-direction:column;gap:20px}.upload-area{border:2px dashed #d1d5db;border-radius:8px;padding:40px;text-align:center;cursor:pointer;transition:all .2s}.upload-area:hover{border-color:#3b82f6;background:#3b82f605}.upload-area svg{color:#6b7280;margin-bottom:16px}.upload-area h3{margin:0 0 8px;color:#374151;font-size:18px;font-weight:600}.upload-area p{margin:0;color:#6b7280;font-size:14px}.validation-status{display:flex;align-items:center;gap:12px;padding:16px;background:#f8f9fa;border-radius:6px}.spinner{width:20px;height:20px;border:2px solid #e9ecef;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.preview-section{padding:30px}.preview-header h3{margin:0 0 8px;color:#212529;font-size:20px;font-weight:600}.preview-header p{margin:0 0 20px;color:#6c757d;font-size:14px}.validation-errors{background:#fff5f5;border:1px solid #fecaca;border-radius:6px;padding:20px;margin-bottom:20px}.error-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.error-header svg{color:#dc3545}.error-header h4{margin:0;color:#dc3545;font-size:16px;font-weight:600}.error-list{max-height:150px;overflow-y:auto}.error-item{color:#dc3545;font-size:13px;padding:4px 0;border-bottom:1px solid rgba(220,53,69,.1)}.error-item:last-child{border-bottom:none}.preview-table-container{background:#fff;border:1px solid #e9ecef;border-radius:6px;overflow:hidden;margin-bottom:20px}.preview-table{width:100%;border-collapse:collapse}.preview-table th,.preview-table td{padding:12px;text-align:left;border-bottom:1px solid #e9ecef;font-size:13px}.preview-table th{background:#f8f9fa;font-weight:600;color:#495057}.preview-table td{color:#212529;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-table tbody tr:hover{background:#f8f9fa}.preview-actions{display:flex;justify-content:flex-end;gap:12px}.upload-success{padding:60px 30px;text-align:center}.success-icon{color:#28a745;margin-bottom:20px}.upload-success h2{margin:0 0 12px;color:#212529;font-size:24px;font-weight:600}.upload-success p{margin:0 0 30px;color:#6c757d;font-size:16px}.success-actions{display:flex;justify-content:center;gap:12px}.upload-importing{padding:60px 30px;text-align:center}.importing-spinner{margin-bottom:20px;display:flex;justify-content:center}.importing-spinner .spinner{width:64px;height:64px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.upload-importing h2{margin:0 0 12px;color:#212529;font-size:24px;font-weight:600}.upload-importing p{margin:0 0 8px;color:#6c757d;font-size:16px}.btn-primary,.btn-secondary{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none;min-width:120px;justify-content:center}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-secondary{background-color:#6b7280;color:#fff}@media (max-width: 768px){.upload-header,.upload-section,.preview-section{padding:20px}.template-download{flex-direction:column;gap:16px;text-align:center}.preview-actions,.success-actions{flex-direction:column}.preview-table-container{overflow-x:auto}}.file-upload-zone{border:2px dashed #ccc;border-radius:8px;padding:12px 16px;text-align:center;background:#fafafa;cursor:pointer;transition:all .2s ease;position:relative;min-height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center}.file-upload-zone:hover{border-color:#007bff;background:#f0f8ff}.file-upload-zone.drag-over{border-color:#007bff;background:#e3f2fd;transform:scale(1.02)}.upload-icon{color:#007bff;margin-bottom:4px}.upload-text p{margin:1px 0;color:#333}.upload-text p:first-child{font-size:1rem}.upload-hint{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.85rem;color:#666;margin-top:2px}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:12px;color:#007bff}.spinner{width:24px;height:24px;border:2px solid #e3f2fd;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.file-upload-container{display:flex;flex-direction:column;gap:20px}.uploaded-files-section,.pending-files-section{display:flex;flex-direction:column;gap:12px}.file-upload-result{border:1px solid #e0e0e0;border-radius:6px;padding:16px;background:#fafafa}.pending-file-item{border:1px solid #ffc107;border-radius:6px;padding:16px;background:#fff8e1}.file-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.file-icon{color:#007bff;flex-shrink:0}.file-details{flex:1}.file-name{font-weight:500;color:#333;font-size:.9rem;word-break:break-all}.file-size{font-size:.8rem;color:#666;margin-top:2px}.remove-file-btn{background:#dc3545;color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;flex-shrink:0;padding:0;line-height:1}.remove-file-btn svg{width:16px;height:16px;stroke-width:2}.remove-file-btn:hover{background:#c82333}.file-actions{display:flex;justify-content:flex-start}.btn-sm{padding:6px 12px;font-size:.85rem}.btn-primary{background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;text-decoration:none;display:inline-block;text-align:center;transition:background-color .2s ease}.btn-primary:hover{background-color:#2563eb}.btn-secondary{background-color:#6b7280;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;text-decoration:none;display:inline-block;text-align:center;transition:background-color .2s ease}.btn-secondary:hover{background-color:#4b5563}.data-classification{display:inline-block;padding:2px 6px;border-radius:3px;font-size:.7rem;font-weight:500;text-transform:uppercase;margin-left:8px}.data-classification.public-data{background:#d4edda;color:#155724}.data-classification.internal-data{background:#cce5ff;color:#0056b3}.data-classification.confidential-data{background:#fff3cd;color:#856404}.data-classification.restricted-data{background:#f8d7da;color:#721c24}.classification-section{margin-top:12px;padding-top:12px;border-top:1px solid #dee2e6}.classification-options{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;min-height:48px;align-items:stretch}.classification-radio{display:flex;align-items:center;cursor:pointer;padding:8px 12px;border:1px solid #dee2e6;border-radius:6px;background:#fff;transition:all .2s ease;min-height:44px;-webkit-appearance:none;-moz-appearance:none;appearance:none;user-select:none;-webkit-user-select:none;-moz-user-select:none}.classification-radio:hover{background:#f8f9fa;border-color:#007bff}.classification-radio input[type=radio]{margin:0 8px 0 0;accent-color:#007bff;width:16px;height:16px;flex-shrink:0;-webkit-appearance:radio;-moz-appearance:radio;appearance:radio;cursor:pointer}.classification-radio input[type=radio]:checked+.classification-label{font-weight:600}.classification-label.public-data{color:#155724}.classification-label.internal-data{color:#0056b3}.classification-label.confidential-data{color:#856404}.classification-label.restricted-data{color:#721c24}.upload-file-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;outline:none;min-height:36px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:500;transition:all .2s ease}.upload-file-btn.disabled{opacity:.6;cursor:not-allowed}.upload-file-btn:focus{box-shadow:0 0 0 3px #007bff40;outline:none}@media screen and (-webkit-min-device-pixel-ratio: 2){.classification-radio{border-width:1px;border-style:solid}.classification-radio input[type=radio]{transform:scale(1.1)}}@supports (-webkit-appearance: none){.classification-radio input[type=radio]{-webkit-appearance:radio;appearance:radio}}@media (max-width: 480px){.file-upload-zone{padding:30px 15px;min-height:100px}.upload-icon{width:24px;height:24px}.upload-text p:first-child{font-size:.9rem}.file-name{font-size:.85rem}}.entity-details-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.details-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:30px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:20px}.header-left{display:flex;flex-direction:column;gap:16px;flex:1;min-width:0}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;color:#6c757d;font-size:14px;padding:8px 0;transition:color .2s}.back-button:hover{color:#495057}.entity-title{display:flex;flex-direction:column;gap:8px}.title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.title-icon{color:#3b82f6;flex-shrink:0}.entity-title h1{margin:0;color:#212529;font-size:28px;font-weight:600;flex:1;min-width:0;word-break:break-word}.entity-type{margin:0;color:#6c757d;font-size:16px;font-weight:500}.status-badge{padding:6px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.entity-meta{display:flex;flex-direction:column;gap:8px;align-items:flex-end;text-align:right}.meta-item{display:flex;align-items:center;gap:6px;color:#6c757d;font-size:13px}.meta-item svg{flex-shrink:0}.entity-id{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:500}.details-content{padding:30px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:30px}.info-section{background:#f8f9fa;border-radius:8px;padding:24px;border:1px solid #e9ecef}.section-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e9ecef}.section-header>div:first-child{display:flex;align-items:center;gap:10px}.card-actions{display:flex;align-items:center;gap:8px}.card-edit-btn,.card-save-btn,.card-cancel-btn{transition:all .2s}.card-edit-btn:hover{background-color:#e5e7eb!important;border-color:#9ca3af!important}.card-save-btn:hover{background-color:#059669!important}.card-cancel-btn:hover{background-color:#4b5563!important}.section-icon{color:#3b82f6;flex-shrink:0}.section-header h3{margin:0;color:#212529;font-size:18px;font-weight:600;flex:1}.section-content{background:#fff;border-radius:6px;padding:20px;border:1px solid #e9ecef}.fields-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.info-field{display:flex;flex-direction:column;gap:6px}.info-field.full-width{grid-column:1 / -1}.field-label{font-weight:500;color:#495057;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.field-value{color:#212529;font-size:14px;line-height:1.5;word-break:break-word}.business-classes,.regions{display:flex;flex-wrap:wrap;gap:8px}.business-class-tag,.region-tag{display:inline-block;background:#e7f3ff;color:#06c;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;border:1px solid #b3d9ff}.region-tag{background:#f0f9ff;color:#0284c7;border-color:#bae6fd}.trading-address .section-icon{color:#10b981}@media (max-width: 768px){.details-header{padding:20px;flex-direction:column;align-items:flex-start}.entity-meta{align-items:flex-start;text-align:left}.details-content{padding:20px}.details-grid{grid-template-columns:1fr;gap:20px}.info-section,.section-content{padding:16px}.fields-grid{grid-template-columns:1fr;gap:16px}.entity-title h1{font-size:24px}.title-row{align-items:flex-start;flex-direction:column;gap:8px}.status-badge{align-self:flex-start}}@media (max-width: 480px){.details-header,.details-content{padding:16px}.business-classes,.regions{flex-direction:column;align-items:flex-start}.business-class-tag,.region-tag{display:block;width:fit-content}}.question-topics{margin:30px 0}.topics-title{margin:0 0 20px;color:#1a1a1a;font-size:1.3rem;font-weight:600;display:flex;align-items:center;gap:8px}.topics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.topic-tile{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:20px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.topic-tile:hover{box-shadow:0 4px 12px #0000001a;border-color:#007bff;transform:translateY(-2px)}.topic-tile.completed{border-color:#28a745;background:linear-gradient(135deg,#fff,#f8f9fa)}.topic-tile.completed:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:#28a745}.topic-tile.in-progress{border-color:#ffc107;background:linear-gradient(135deg,#fff,#fffbf0)}.topic-tile.in-progress:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:#ffc107}.topic-tile.not-started{border-color:#dc3545;background:linear-gradient(135deg,#fff,#fff5f5)}.topic-tile.not-started:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:#dc3545}.topic-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.topic-info{display:flex;align-items:center;gap:8px;flex:1}.topic-info h4{margin:0;color:#1a1a1a;font-size:1.1rem;font-weight:600;line-height:1.3}.completion-icon{flex-shrink:0}.completion-icon.completed{color:#28a745}.completion-icon.in-progress{color:#ffc107}.completion-icon.not-started{color:#dc3545}.completion-status{font-size:.8rem;font-weight:500;padding:4px 8px;border-radius:12px;text-align:center;white-space:nowrap}.completion-status.completed{background-color:#d4edda;color:#155724}.completion-status.in-progress{background-color:#fff3cd;color:#856404}.completion-status.not-started{background-color:#f8d7da;color:#721c24}.progress-bar{width:100%;height:6px;background-color:#e9ecef;border-radius:3px;overflow:hidden;margin-bottom:12px}.progress-fill{height:100%;background:linear-gradient(90deg,#ffc107,#28a745);transition:width .3s ease;border-radius:3px}.completion-details{display:flex;flex-direction:column;gap:2px;font-size:.8rem;color:#888}.completion-details span{line-height:1.2}.question-topics-loading,.question-topics-error,.question-topics-empty{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px 20px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#666;font-size:.9rem;margin:20px 0}.question-topics-error{color:#dc3545;border-color:#f8d7da;background:#fff5f5}.question-topics-empty{flex-direction:column;gap:16px;padding:60px 20px}.question-topics-empty p{margin:0;font-size:1rem}.loading-spinner{width:20px;height:20px;border:2px solid #e0e0e0;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.topics-grid{grid-template-columns:1fr;gap:12px}.topic-tile{padding:16px}.topic-header{flex-direction:column;align-items:flex-start;gap:8px}.completion-status{align-self:flex-end}.topic-info{width:100%;justify-content:space-between}}@media (max-width: 480px){.topic-tile{padding:12px}.topic-info h4{font-size:1rem}.topic-description{font-size:.85rem}}.conditional-question-setup{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:16px;margin-top:8px}.conditional-question-setup .form-group{margin-bottom:12px}.conditional-question-setup .form-group:last-child{margin-bottom:0}.conditional-question-setup label{font-size:.9rem;font-weight:500;color:#495057;margin-bottom:4px}.conditional-question-setup select{background:#fff}.conditional-question-setup input[type=checkbox]{margin-right:6px}.conditional-info{background:#e7f3ff;color:#0056b3;padding:2px 6px;border-radius:4px;font-size:.75rem;font-weight:500;border:1px solid #bee5ff}.question-card.conditional-question{background:linear-gradient(135deg,#fff,#f8f9ff);position:relative;border-left:3px solid #007bff;box-sizing:border-box}.question-hierarchy{display:flex;align-items:center;gap:8px}.branch-indicator{display:flex;align-items:center;color:#007bff;margin-right:4px}.branch-icon{color:#007bff;opacity:.7}.children-indicator{display:flex;align-items:center;gap:3px;background:#e8f4fd;color:#0056b3;padding:2px 6px;border-radius:12px;font-size:.7rem;font-weight:500;border:1px solid #bee5ff;margin-left:4px}.children-count{font-size:.7rem;font-weight:600}.conditional-logic-display{display:flex;align-items:flex-start;gap:8px;margin:8px 0;padding:8px;background:#f8f9ff;border:1px solid #e0e7ff;border-radius:6px;font-size:.85rem}.condition-arrow{color:#007bff;margin-top:2px;flex-shrink:0}.condition-text{color:#495057;font-weight:500;line-height:1.3}.question-number{display:flex;align-items:center;gap:8px}.question-card.conditional-question:not(:last-child):after{content:"";position:absolute;left:15px;bottom:-8px;width:2px;height:16px;background:#dee2e6;z-index:1;pointer-events:none}.questions-list{position:relative}.questions-list>.question-card{margin-bottom:12px}.question-card.conditional-question{margin-bottom:8px;margin-top:4px}.question-card{position:relative;overflow:visible}.question-card:hover .children-indicator{background:#007bff;color:#fff;transform:scale(1.05);transition:all .2s ease}.question-card:hover .branch-indicator{transform:scale(1.1);transition:all .2s ease}.question-card.conditional-question:hover{border-left-color:#0056b3;box-shadow:-3px 0 #0056b3,0 2px 8px #007bff26}.drag-handle{display:flex;align-items:center;color:#6c757d;cursor:grab;padding:4px;border-radius:4px;transition:all .2s ease;margin-right:8px}.drag-handle:hover{color:#007bff;background:#007bff1a}.drag-handle:active{cursor:grabbing}.question-card.dragging{opacity:.5;transform:scale(.98);transition:all .2s ease}.question-card.drag-over-above{position:relative;border-top:3px solid #007bff;background:#007bff0d;transition:all .2s ease}.question-card.drag-over-below{position:relative;border-bottom:3px solid #007bff;background:#007bff0d;transition:all .2s ease}.question-card.drag-over-above:before{content:"Drop above";position:fixed;top:50%;right:20px;transform:translateY(-50%);background:#007bff;color:#fff;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;z-index:1000;box-shadow:0 2px 8px #007bff4d;pointer-events:none}.question-card.drag-over-below:after{content:"Drop below";position:fixed;top:50%;right:20px;transform:translateY(-50%);background:#007bff;color:#fff;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;z-index:1000;box-shadow:0 2px 8px #007bff4d;pointer-events:none}.question-card[draggable=true]:hover{cursor:grab}.question-card[draggable=true]:active{cursor:grabbing}.question-card.dragging .question-content{opacity:.7}.question-card.dragging .question-actions{opacity:.5;pointer-events:none}.question-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.question-header-left{display:flex;align-items:center;flex:1;gap:8px}.question-sets-container{max-width:1200px;margin:0 auto;padding:20px}.page-header{margin-bottom:30px}.page-header h1{margin:0 0 8px;color:#1a1a1a;font-size:2rem;font-weight:600}.page-header p{margin:0;color:#666;font-size:1.1rem}.entity-type-selector{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;display:flex;align-items:center;justify-content:space-between}.entity-type-selector h2{margin:0;color:#1a1a1a;font-size:1.5rem;font-weight:500}.entity-type-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:1rem;min-width:150px}.topics-section{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:1px solid #eee}.section-header h3{margin:0;color:#1a1a1a;font-size:1.3rem;font-weight:500}.topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.topic-card{border:1px solid #e0e0e0;border-radius:8px;padding:20px;background:#fafafa;transition:all .2s ease}.topic-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#ccc}.topic-card.inactive{background:#f8f8f8;border-color:#ddd;opacity:.7}.topic-card.inactive:hover{border-color:#bbb}.topic-card.inactive .topic-description{color:#888}.topic-card.inactive h4{color:#666}.topic-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.topic-title{display:flex;flex-direction:column;gap:8px;flex:1}.topic-title h4{margin:0;color:#1a1a1a;font-size:1.1rem;font-weight:600}.topic-actions{display:flex;gap:8px}.topic-description{margin:0 0 16px;color:#666;font-size:.9rem;line-height:1.4}.topic-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:500}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.topic-order{font-size:.8rem;color:#888}.topic-stats{margin-bottom:16px;font-size:.8rem;color:#888}.topic-stats span{display:block;margin-bottom:2px}.topic-footer{display:flex;justify-content:flex-end}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-icon{color:#ccc;margin-bottom:16px}.empty-state h3{margin:0 0 8px;color:#333;font-size:1.3rem;font-weight:500}.empty-state p{margin:0 0 24px;font-size:1rem;line-height:1.4}.loading-state{text-align:center;padding:40px;color:#666;font-size:1.1rem}.btn-primary{background-color:#007bff;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:background-color .2s ease}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#fff;color:#333;border:1px solid #ddd;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:.85rem;display:inline-flex;align-items:center;gap:6px;transition:all .2s ease}.btn-secondary:hover{background-color:#f8f9fa;border-color:#aaa}.btn-sm{padding:6px 10px;font-size:.8rem}.btn-icon{background:none;border:none;padding:6px;border-radius:4px;cursor:pointer;color:#666;display:inline-flex;align-items:center;transition:all .2s ease}.btn-icon:hover{background-color:#f0f0f0;color:#333}.btn-icon.btn-danger:hover{background-color:#f8d7da;color:#721c24}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #eee}.modal-header h2{margin:0;color:#1a1a1a;font-size:1.3rem;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:all .2s ease}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-form{padding:30px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;color:#333;font-weight:500;font-size:.9rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.form-group input.error,.form-group textarea.error{border-color:#dc3545}.checkbox-group{display:flex;align-items:center}.checkbox-group label{display:flex;align-items:center;margin-bottom:0;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;margin-right:8px}.error-message{color:#dc3545;font-size:.8rem;margin-top:4px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid #eee;margin-top:20px}.questions-manager{max-width:1200px;margin:0 auto;padding:20px}.questions-header{margin-bottom:30px}.btn-back{display:inline-flex;align-items:center;gap:8px;background:none;border:1px solid #ddd;padding:8px 12px;border-radius:4px;color:#666;cursor:pointer;font-size:.9rem;margin-bottom:15px;transition:all .2s ease}.btn-back:hover{background-color:#f8f9fa;border-color:#aaa;color:#333}.topic-info h2{margin:0 0 8px;color:#1a1a1a;font-size:1.8rem;font-weight:600}.topic-info .topic-description{margin:0;color:#666;font-size:1rem}.questions-section{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.questions-list{display:flex;flex-direction:column;gap:15px}.question-card{border:1px solid #e0e0e0;border-radius:6px;padding:20px;background:#fafafa;transition:all .2s ease}.question-card:hover{border-color:#ccc;box-shadow:0 2px 8px #00000014}.question-card.inactive{background:#f8f8f8;border-color:#ddd;opacity:.7}.question-card.inactive:hover{border-color:#bbb}.question-card.inactive .question-text{color:#666}.question-number{display:flex;align-items:center;gap:8px;font-weight:600;color:#007bff}.required-icon{color:#dc3545}.optional-icon{color:#6c757d}.inactive-label{font-size:.7rem;font-weight:600;color:#dc3545;background:#dc35451a;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.question-content{padding-left:32px}.question-text{font-size:1.1rem;color:#000;font-weight:700;line-height:1.5;margin-bottom:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.question-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;font-size:.85rem;color:#666}.question-type{font-weight:500}.question-options{font-style:italic}.form-row{display:grid;grid-template-columns:1fr auto auto;gap:20px;align-items:end}.options-manager{border:1px solid #ddd;border-radius:4px;padding:15px;background:#f9f9f9}.add-option{display:flex;gap:10px;margin-bottom:15px}.add-option input{flex:1;margin-bottom:0}.options-list{display:flex;flex-direction:column;gap:8px}.option-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border:1px solid #e0e0e0;border-radius:4px;font-size:.9rem}.option-item span{flex:1}.questionnaire-modal{max-width:1200px;width:95%;max-height:90vh}.questionnaire-title{display:flex;flex-direction:column;gap:8px}.questionnaire-title h2{margin:0}.completion-info{display:flex;align-items:center;gap:8px;font-size:.9rem}.completion-percentage{color:#007bff;font-weight:500}.complete-icon{color:#28a745}.modal-body{max-height:60vh;overflow-y:auto;padding:30px}.topic-description{margin:0 0 30px;padding:15px;background:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;color:#666;font-style:italic}.questions-form{display:flex;flex-direction:column;gap:30px}.question-group{border:1px solid #e0e0e0;border-radius:8px;padding:20px;background:#fafafa}.question-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.question-label{display:flex;flex-direction:column;gap:8px;cursor:default;flex:1}.question-number{font-weight:600;color:#007bff;font-size:.9rem}.question-text{font-size:1.1rem;color:#000;font-weight:700;line-height:1.5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.required{color:#dc3545;font-weight:700;margin-left:4px}.answered-icon{color:#28a745;margin-top:4px}.guidance-notes{margin-top:8px;padding:12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;font-size:.9rem;color:#6c757d;font-style:italic;line-height:1.4}.question-input{margin-top:12px}.question-input input,.question-input textarea,.question-input select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-weight:400;text-transform:none;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.question-input textarea{resize:vertical;min-height:100px}.radio-group{display:flex;flex-direction:column;gap:12px;align-items:flex-start}.radio-group.inline{flex-direction:row;gap:20px;align-items:center}.radio-group label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem}.radio-group input[type=radio]{width:auto;margin:0}.checkbox-group{display:flex;flex-direction:column;gap:12px;align-items:flex-start}.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem}.checkbox-group input[type=checkbox]{width:auto;margin:0}.modal-footer{padding:20px 30px;border-top:1px solid #eee;display:flex;flex-direction:column;gap:15px}.footer-info{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:#666}.incomplete-notice{display:flex;align-items:center;gap:6px;color:#856404;font-size:.85rem}.input-with-clear{position:relative;display:flex;align-items:stretch}.clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#dc3545;color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;z-index:1;transition:background-color .2s ease}.clear-btn:hover{background:#c82333}.clear-btn.textarea-clear{top:12px;transform:none}.input-with-clear input,.input-with-clear textarea{padding-right:35px}@media (max-width: 768px){.question-sets-container{padding:15px}.entity-type-selector{flex-direction:column;gap:15px;align-items:flex-start}.topics-grid{grid-template-columns:1fr}.topic-header{flex-direction:column;align-items:flex-start;gap:10px}.topic-actions{align-self:flex-end}.modal-content{width:95%;margin:20px}.questionnaire-modal{max-width:95%;width:95%}.modal-header{padding:15px 20px}.modal-form{padding:20px}}*{box-sizing:border-box}#root{width:100%;height:100vh;margin:0;padding:0;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}body{margin:0;padding:0}h1,h2,h3,h4,h5,h6{margin-top:0;color:#212529}p{color:#6c757d}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}
