/* /Components/DataAcquisitionAIAnalysis.razor.rz.scp.css */
.spinner-border-sm[b-7niip82rv1] {
  display: inline-block;
  width: 1rem;
  height: 1rem;
  vertical-align: text-bottom;
  border: .15em solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spinner-border-b-7niip82rv1 .75s linear infinite;
}

@keyframes spinner-border-b-7niip82rv1 {
  to { transform: rotate(360deg); }
}

.ai-analysis-component[b-7niip82rv1] {
  height: 100%;
  display: flex;
  flex-direction: column;
  background: #fafbfc;
  overflow: auto;
}

/* Loading State */
.ai-loading-state[b-7niip82rv1] {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
  padding: 40px;
}

.ai-loading-card[b-7niip82rv1] {
  background: white;
  border-radius: 20px;
  padding: 50px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  max-width: 500px;
  animation: fadeIn-b-7niip82rv1 0.5s ease-out;
}

.ai-loading-icon[b-7niip82rv1] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  border-radius: 50%;
  margin-bottom: 30px;
  animation: pulse-b-7niip82rv1 2s infinite;
}

@keyframes pulse-b-7niip82rv1 {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(102, 126, 234, 0.4);
  }
  50% {
    transform: scale(1.05);
    box-shadow: 0 0 0 20px rgba(102, 126, 234, 0);
  }
}

.spinner-border[b-7niip82rv1] {
  width: 3rem;
  height: 3rem;
}

.progress[b-7niip82rv1] {
  height: 8px;
  background-color: #e2e8f0;
  border-radius: 4px;
}

.progress-bar[b-7niip82rv1] {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  transition: width 0.3s ease;
}

/* Error State */
.ai-error-state[b-7niip82rv1] {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
  padding: 40px;
}

.ai-error-card[b-7niip82rv1] {
  background: white;
  border-radius: 20px;
  padding: 50px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  max-width: 500px;
}

.ai-error-icon[b-7niip82rv1] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  background: linear-gradient(135deg, #f56565 0%, #e53e3e 100%);
  color: white;
  border-radius: 50%;
  margin-bottom: 30px;
}

.error-message[b-7niip82rv1] {
  color: #e53e3e;
  margin-bottom: 30px;
  font-size: 16px;
}

.retry-button[b-7niip82rv1] {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  border: none !important;
  padding: 12px 30px !important;
  border-radius: 25px !important;
  font-weight: 600 !important;
  transition: transform 0.2s ease !important;
}
.retry-button:hover[b-7niip82rv1] {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

/* Results State */
.ai-results-container[b-7niip82rv1] {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 20px;
  background: #ffffff;
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  margin: 20px;
  overflow: hidden;
  max-height: calc(100vh - 40px);
}

.ai-risk-assessment[b-7niip82rv1] {
  background: #f0f8ff;
  border: 1px solid #87cefa;
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 20px;
}

.risk-assessment-header[b-7niip82rv1] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.risk-assessment-header h4[b-7niip82rv1] {
  margin: 0;
  font-size: 18px;
  color: #333;
}

.risk-score-container[b-7niip82rv1] {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.risk-score-visual[b-7niip82rv1] {
  display: flex;
  align-items: center;
}

.score-circle-large[b-7niip82rv1] {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  margin-right: 20px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 4px solid;
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.score-circle-large:hover[b-7niip82rv1] {
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}

.score-value-large[b-7niip82rv1] {
  font-size: 3rem;
  line-height: 1;
  font-weight: 700;
}

.score-label[b-7niip82rv1] {
  font-size: 0.85rem;
  opacity: 0.9;
  margin-top: 5px;
  font-weight: 500;
}

.risk-level-indicator[b-7niip82rv1] { flex: 1; }

.risk-level-text[b-7niip82rv1] {
  font-size: 1.2rem;
  font-weight: 500;
}

.risk-level-description[b-7niip82rv1] {
  font-size: 0.9rem;
  color: #666;
}

.risk-metadata[b-7niip82rv1] {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-top: 10px;
}

.metadata-item[b-7niip82rv1] {
  display: flex;
  align-items: center;
  gap: 5px;
}

.metadata-label[b-7niip82rv1] {
  font-weight: 600;
  color: #333;
}

.metadata-value[b-7niip82rv1] { color: #555; }

/* Detailed Report */
.ai-detailed-report[b-7niip82rv1] {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.report-header[b-7niip82rv1] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 15px;
}
.report-header h4[b-7niip82rv1] {
  margin: 0;
  font-size: 18px;
  color: #333;
}

.demo-report-badge[b-7niip82rv1] {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  box-shadow: 0 4px 10px rgba(217, 119, 6, 0.25);
}

.report-content[b-7niip82rv1] {
  flex: 1;
  overflow-y: auto;
  padding: 15px;
  background: #f4f9ff;
  border-radius: 10px;
  border: 1px solid #bee3f8;
  min-height: 200px;
  max-height: calc(100vh - 400px);
}

/* Scrollbar per il report content */
.report-content[b-7niip82rv1]::-webkit-scrollbar { width: 8px; }
.report-content[b-7niip82rv1]::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 4px;
}
.report-content[b-7niip82rv1]::-webkit-scrollbar-thumb {
  background: #888;
  border-radius: 4px;
}
.report-content[b-7niip82rv1]::-webkit-scrollbar-thumb:hover { background: #555; }

.ai-formatted-content[b-7niip82rv1] {
  font-size: 14px;
  line-height: 1.6;
  color: #333;
}
.ai-formatted-content h2[b-7niip82rv1] {
  color: #0d6efd;
  font-size: 18px;
  margin-top: 15px;
  margin-bottom: 10px;
  border-bottom: 2px solid #0d6efd;
  padding-bottom: 5px;
}
.ai-formatted-content h3[b-7niip82rv1] {
  color: #495057;
  font-size: 16px;
  margin-top: 12px;
  margin-bottom: 8px;
  font-weight: 600;
}
.ai-formatted-content h4[b-7niip82rv1] {
  color: #6c757d;
  font-size: 14px;
  margin-top: 10px;
  margin-bottom: 6px;
  font-weight: 600;
}
.ai-formatted-content strong[b-7niip82rv1] {
  color: #212529;
  font-weight: 600;
}
.ai-formatted-content li[b-7niip82rv1] {
  margin-left: 20px;
  margin-bottom: 5px;
}
.ai-formatted-content p[b-7niip82rv1] { margin-bottom: 10px; }

/* Actions Bar */
.ai-actions-bar[b-7niip82rv1] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  margin-top: 20px;
  border-top: 1px solid #e2e8f0;
  background: white;
  position: sticky;
  bottom: 0;
  z-index: 10;
}

.actions-left[b-7niip82rv1],
.actions-right[b-7niip82rv1] {
  display: flex;
  gap: 10px;
  align-items: center;
}

.action-button[b-7niip82rv1] {
  padding: 10px 20px !important;
  border-radius: 5px !important;
  font-weight: 500 !important;
  transition: all 0.3s ease !important;
  min-width: 120px !important;
}
.action-button:hover[b-7niip82rv1] {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.save-button[b-7niip82rv1] {
  background: linear-gradient(135deg, #28a745, #218838) !important;
  color: white !important;
  border: none !important;
}
.save-button:hover[b-7niip82rv1] {
  background: linear-gradient(135deg, #218838, #1e7e34) !important;
}

/* Welcome State */
.ai-welcome-state[b-7niip82rv1] {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 40px;
}

.ai-welcome-card[b-7niip82rv1] {
  background: white;
  border-radius: 20px;
  padding: 50px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  max-width: 600px;
  width: 100%;
  animation: fadeIn-b-7niip82rv1 0.5s ease-out;
}

.welcome-icon[b-7niip82rv1] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  background: linear-gradient(135deg, #28a745 0%, #218838 100%);
  color: white;
  border-radius: 50%;
  margin-bottom: 30px;
  animation: pulse-b-7niip82rv1 2s infinite;
}

/* Feature Items */
.analysis-features[b-7niip82rv1] {
  display: flex;
  flex-direction: column;
  gap: 15px;
  margin-bottom: 30px;
}

.feature-item[b-7niip82rv1] {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 5px;
  background: #f1f3f5;
  transition: transform 0.2s ease;
}
.feature-item:hover[b-7niip82rv1] {
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

/* Score Classes con bordini coordinati */
.score-low[b-7niip82rv1] {
  background-color: #4caf50;
  color: white;
  border-color: #2e7d32 !important;
}
.score-medium[b-7niip82rv1] {
  background-color: #ff9800;
  color: white;
  border-color: #f57c00 !important;
}
.score-high[b-7niip82rv1] {
  background-color: #ff5722;
  color: white;
  border-color: #d84315 !important;
}
.score-critical[b-7niip82rv1] {
  background-color: #d32f2f;
  color: white;
  border-color: #b71c1c !important;
}

/* Fade In Animation */
@keyframes fadeIn-b-7niip82rv1 {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Scrollbar per il contenuto AI */
.ai-response-content[b-7niip82rv1]::-webkit-scrollbar { width: 6px; }
.ai-response-content[b-7niip82rv1]::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 3px;
}
.ai-response-content[b-7niip82rv1]::-webkit-scrollbar-thumb {
  background: #888;
  border-radius: 3px;
}
.ai-response-content[b-7niip82rv1]::-webkit-scrollbar-thumb:hover { background: #555; }
/* /Components/NetworkConfiguration.razor.rz.scp.css */
.network-configuration-container[b-zmfhsiz76j] {
    padding: 20px;
}

.loading-container[b-zmfhsiz76j] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 200px;
}

.network-header h5[b-zmfhsiz76j] {
    color: #2c3e50;
    font-weight: 600;
}

.network-interface-card[b-zmfhsiz76j] {
    transition: all 0.3s ease;
    border-left: 4px solid #e0e0e0;
}

.network-interface-card:hover[b-zmfhsiz76j] {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.network-interface-card.monitored-interface[b-zmfhsiz76j] {
    border-left-color: #28a745;
    background-color: #f8fff9;
}

.network-interface-card.monitored-interface .card-header[b-zmfhsiz76j] {
    background-color: #d4edda;
    border-bottom: 1px solid #c3e6cb;
}

.network-interface-card.interface-down[b-zmfhsiz76j] {
    opacity: 0.7;
    border-left-color: #6c757d;
}

.network-interface-card .card-header[b-zmfhsiz76j] {
    background-color: #f8f9fa;
    border-bottom: 1px solid #dee2e6;
    font-size: 0.95rem;
    padding: 0.75rem 1rem;
}

.network-interface-card .card-body[b-zmfhsiz76j] {
    padding: 1rem;
}

.network-appliance-card[b-zmfhsiz76j] {
    border-left: 4px solid #0d6efd;
}

.network-appliance-card .card-header[b-zmfhsiz76j] {
    background-color: #eef5ff;
}

.network-diagnostics-card[b-zmfhsiz76j] {
    border-left: 4px solid #17a2b8;
}

.network-diagnostics-card .card-header[b-zmfhsiz76j] {
    background-color: #eefbfd;
}

.command-preview[b-zmfhsiz76j] {
    background-color: #212529;
    border-radius: 0.375rem;
    color: #f8f9fa;
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.8rem;
    max-height: 90px;
    overflow: auto;
    padding: 0.6rem;
    white-space: pre-wrap;
}

.diagnostic-grid[b-zmfhsiz76j] {
    display: grid;
    gap: 1rem;
}

.diagnostic-entry[b-zmfhsiz76j] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    padding: 0.75rem;
    background-color: #fff;
}

.diagnostic-title[b-zmfhsiz76j] {
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.diagnostic-command[b-zmfhsiz76j] {
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.75rem;
    color: #6c757d;
    margin-bottom: 0.5rem;
    word-break: break-all;
}

.diagnostic-output[b-zmfhsiz76j] {
    background-color: #212529;
    border-radius: 0.375rem;
    color: #f8f9fa;
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.8rem;
    margin: 0;
    max-height: 280px;
    overflow: auto;
    padding: 0.75rem;
    white-space: pre-wrap;
}

.interface-info[b-zmfhsiz76j] {
    font-size: 0.875rem;
}

.info-row[b-zmfhsiz76j] {
    display: flex;
    align-items: center;
    padding: 0.4rem 0;
    border-bottom: 1px solid #f0f0f0;
}

.info-row:last-child[b-zmfhsiz76j] {
    border-bottom: none;
}

.info-row i[b-zmfhsiz76j] {
    width: 20px;
    margin-right: 8px;
    color: #6c757d;
}

.info-row .label[b-zmfhsiz76j] {
    font-weight: 600;
    color: #495057;
    min-width: 60px;
}

.info-row .value[b-zmfhsiz76j] {
    color: #212529;
    flex: 1;
}

.text-monospace[b-zmfhsiz76j] {
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.85rem;
}

.info-section[b-zmfhsiz76j] {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 2px solid #e9ecef;
}

.section-title[b-zmfhsiz76j] {
    font-weight: 600;
    color: #495057;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
}

.section-title i[b-zmfhsiz76j] {
    margin-right: 5px;
    color: #007bff;
}

.ip-address[b-zmfhsiz76j] {
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 4px;
    padding: 0.35rem 0.6rem;
    margin: 0.25rem 0;
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.8rem;
    color: #212529;
}

.monitored-interface .ip-address[b-zmfhsiz76j] {
    background-color: #d4edda;
    border-color: #c3e6cb;
}

/* Badge styles */
.badge[b-zmfhsiz76j] {
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.35em 0.65em;
}

.badge i[b-zmfhsiz76j] {
    margin-right: 3px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .network-configuration-container[b-zmfhsiz76j] {
        padding: 10px;
    }

    .network-interface-card[b-zmfhsiz76j] {
        margin-bottom: 1rem;
    }

    .info-row[b-zmfhsiz76j] {
        flex-wrap: wrap;
    }

    .info-row .label[b-zmfhsiz76j] {
        min-width: 100%;
        margin-bottom: 0.25rem;
    }
}

/* Alert customizations */
.alert[b-zmfhsiz76j] {
    font-size: 0.9rem;
}

.alert i[b-zmfhsiz76j] {
    margin-right: 8px;
}

/* Traffic Statistics Section */
.traffic-section[b-zmfhsiz76j] {
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 0.375rem;
    padding: 0.75rem;
}

.traffic-section .section-title[b-zmfhsiz76j] {
    color: #0d6efd;
    font-weight: 600;
    margin-bottom: 0.75rem;
}

.traffic-stats[b-zmfhsiz76j] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.traffic-row[b-zmfhsiz76j] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem;
    background-color: white;
    border-radius: 0.25rem;
}

.traffic-row i[b-zmfhsiz76j] {
    font-size: 1.25rem;
    min-width: 24px;
}

.traffic-data[b-zmfhsiz76j] {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    flex: 1;
}

.traffic-label[b-zmfhsiz76j] {
    font-weight: 600;
    color: #495057;
    min-width: 30px;
}

.traffic-value[b-zmfhsiz76j] {
    color: #212529;
    font-size: 0.95rem;
}

.traffic-data small[b-zmfhsiz76j] {
    font-size: 0.75rem;
    color: #6c757d;
}

@media (max-width: 768px) {
    .traffic-data[b-zmfhsiz76j] {
        flex-wrap: wrap;
    }
}

/* /Editors/AlertMessageCardList.razor.rz.scp.css */
/* === CONTAINER === */
.alert-card-list-container[b-u3k6g1txq0] {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 0.5rem;
    height: 100%;
}

/* === FILTER TABLE (stile grid filter row) === */
.alert-filter-table[b-u3k6g1txq0] {
    width: 100%;
    border-collapse: collapse;
    background: var(--dxbl-grid-header-bg, var(--dxbl-surface-alt-bg, #f8f9fa));
    border: 1px solid var(--dxbl-border-color, #dee2e6);
    border-radius: 6px;
    table-layout: fixed;
}

.alert-filter-table tr[b-u3k6g1txq0] {
    display: table-row;
}

.filter-td[b-u3k6g1txq0] {
    padding: 0.4rem 0.3rem;
    vertical-align: middle;
}

.filter-td:first-child[b-u3k6g1txq0] {
    padding-left: 0.5rem;
}

.filter-td:last-child[b-u3k6g1txq0] {
    padding-right: 0.5rem;
}

/* === TOOLBAR === */
.alert-toolbar[b-u3k6g1txq0] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0.75rem;
    background: var(--dxbl-surface-bg, #fff);
    border: 1px solid var(--dxbl-border-color, #dee2e6);
    border-radius: 6px;
}

.toolbar-left[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.toolbar-right[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.stats-text[b-u3k6g1txq0] {
    font-size: 0.85rem;
    color: var(--dxbl-text-muted, #6c757d);
}

.total-count[b-u3k6g1txq0] {
    font-size: 0.8rem;
    color: var(--dxbl-text-muted, #999);
    margin-left: 0.25rem;
}

.filter-active-badge[b-u3k6g1txq0] {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.15rem 0.5rem;
    margin-left: 0.5rem;
    border-radius: 10px;
    font-size: 0.75rem;
    background: var(--dxbl-info-bg, #cfe2ff);
    color: var(--dxbl-info-color, #084298);
}

.page-size-label[b-u3k6g1txq0] {
    font-size: 0.8rem;
    color: var(--dxbl-text-muted, #6c757d);
}

[b-u3k6g1txq0] .page-size-combo {
    width: 80px;
}

/* === CARD GRID === */
.alerts-wrap[b-u3k6g1txq0] {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: flex-start;
    flex: 1;
    overflow-y: auto;
}

/* === CARD === */
.alert-card-shadow[b-u3k6g1txq0] {
    width: 380px;
    border-radius: 12px;
    box-shadow: 0 4px 12px var(--dxbl-shadow-color, rgba(0,0,0,.1));
    background-color: var(--dxbl-surface-bg, var(--bs-body-bg, #fff));
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    cursor: pointer;
    overflow: hidden;
}

.alert-card-shadow:hover[b-u3k6g1txq0] {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px var(--dxbl-shadow-color, rgba(0,0,0,.15));
}

/* Risk level border colors */
.alert-card-shadow.risk-critical[b-u3k6g1txq0] {
    border-left: 4px solid #dc3545;
}

.alert-card-shadow.risk-high[b-u3k6g1txq0] {
    border-left: 4px solid #fd7e14;
}

.alert-card-shadow.risk-medium[b-u3k6g1txq0] {
    border-left: 4px solid #ffc107;
}

.alert-card-shadow.risk-low[b-u3k6g1txq0] {
    border-left: 4px solid #28a745;
}

/* === CARD HEADER === */
[b-u3k6g1txq0] .alert-card-shadow .alert-card-header {
    padding: 0.6rem 0.8rem;
    border-bottom: 1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6));
}

.alert-card-header.risk-critical[b-u3k6g1txq0] {
    background: linear-gradient(90deg, #ffe4e4 0%, #fff 100%);
}

.alert-card-header.risk-high[b-u3k6g1txq0] {
    background: linear-gradient(90deg, #fff3e0 0%, #fff 100%);
}

.alert-card-header.risk-medium[b-u3k6g1txq0] {
    background: linear-gradient(90deg, #fff8e1 0%, #fff 100%);
}

.alert-card-header.risk-low[b-u3k6g1txq0] {
    background: linear-gradient(90deg, #e8f5e9 0%, #fff 100%);
}

.header-content[b-u3k6g1txq0] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.header-left[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.risk-badge[b-u3k6g1txq0] {
    padding: 0.2rem 0.6rem;
    border-radius: 12px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.risk-badge.risk-critical[b-u3k6g1txq0] {
    background: #dc3545;
    color: white;
}

.risk-badge.risk-high[b-u3k6g1txq0] {
    background: #fd7e14;
    color: white;
}

.risk-badge.risk-medium[b-u3k6g1txq0] {
    background: #ffc107;
    color: #212529;
}

.risk-badge.risk-low[b-u3k6g1txq0] {
    background: #28a745;
    color: white;
}

.score-badge[b-u3k6g1txq0] {
    padding: 0.2rem 0.5rem;
    border-radius: 8px;
    font-size: 0.75rem;
    font-weight: 600;
    background: var(--dxbl-surface-alt-bg, #f8f9fa);
    color: var(--dxbl-text-color, #212529);
}

.timestamp[b-u3k6g1txq0] {
    font-size: 0.75rem;
    color: var(--dxbl-text-muted, #6c757d);
}

/* === CARD BODY === */
[b-u3k6g1txq0] .alert-card-shadow .dxbl-card-body {
    padding: 0.75rem 0.8rem;
}

.alert-card-body[b-u3k6g1txq0] {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.signature-row[b-u3k6g1txq0] {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.severity-icon[b-u3k6g1txq0] {
    font-size: 1rem;
    flex-shrink: 0;
}

.signature-text[b-u3k6g1txq0] {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--dxbl-text-color, #212529);
    line-height: 1.3;
    word-break: break-word;
}

/* === NETWORK INFO === */
.network-info[b-u3k6g1txq0] {
    background: var(--dxbl-surface-alt-bg, #f8f9fa);
    border-radius: 8px;
    padding: 0.5rem;
}

.ip-row[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 0.8rem;
}

.ip-item[b-u3k6g1txq0] {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.ip-label[b-u3k6g1txq0] {
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--dxbl-text-muted, #6c757d);
    text-transform: uppercase;
}

.ip-value[b-u3k6g1txq0] {
    color: var(--dxbl-text-color, #212529);
}

.ip-item.src .ip-value[b-u3k6g1txq0] {
    color: #0d6efd;
}

.ip-item.dest .ip-value[b-u3k6g1txq0] {
    color: #198754;
}

.arrow[b-u3k6g1txq0] {
    color: var(--dxbl-text-muted, #6c757d);
    font-weight: bold;
    flex-shrink: 0;
}

/* === META ROW === */
.meta-row[b-u3k6g1txq0] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.category-badge[b-u3k6g1txq0] {
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.7rem;
    background: #e9ecef;
    color: #495057;
}

.proto-badge[b-u3k6g1txq0] {
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    background: #cfe2ff;
    color: #084298;
}

.app-proto-badge[b-u3k6g1txq0] {
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    background: #d1e7dd;
    color: #0f5132;
}

/* === COMMUNITY ID === */
.alert-community-id[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.5rem;
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    border-radius: 6px;
    border: 1px solid #f59e0b;
    margin-top: 0.25rem;
}

.community-icon[b-u3k6g1txq0] {
    width: 14px;
    height: 14px;
    color: #d97706;
    flex-shrink: 0;
}

.community-id-text[b-u3k6g1txq0] {
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 0.7rem;
    font-weight: 600;
    color: #92400e;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* === EXTRA INFO === */
.extra-info[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    color: var(--dxbl-text-muted, #6c757d);
    padding: 0.25rem 0;
    border-top: 1px dashed var(--dxbl-border-color, #dee2e6);
}

.extra-info span[b-u3k6g1txq0] {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* === AI INDICATOR === */
.ai-indicator[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    color: #6f42c1;
    background: #f3e8ff;
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    margin-top: 0.25rem;
}

/* === CARD FOOTER === */
[b-u3k6g1txq0] .alert-card-shadow .alert-card-footer {
    padding: 0.5rem 0.8rem;
    background: var(--dxbl-surface-alt-bg, #f8f9fa);
    border-top: 1px solid var(--dxbl-border-color, #dee2e6);
}

.footer-content[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.75rem;
}

.action-badge[b-u3k6g1txq0] {
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
}

.action-badge.blocked[b-u3k6g1txq0] {
    background: #dc3545;
    color: white;
}

.action-badge.allowed[b-u3k6g1txq0] {
    background: #6c757d;
    color: white;
}

.flow-id[b-u3k6g1txq0] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--dxbl-text-muted, #6c757d);
    font-family: 'Consolas', 'Monaco', monospace;
}

.duplicate-badge[b-u3k6g1txq0] {
    padding: 0.15rem 0.4rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    background: #6c757d;
    color: white;
}

/* === PAGINATION === */
.alert-pagination[b-u3k6g1txq0] {
    display: flex;
    justify-content: center;
    padding: 0.75rem;
    background: var(--dxbl-surface-bg, #fff);
    border: 1px solid var(--dxbl-border-color, #dee2e6);
    border-radius: 6px;
}

/* === NO ALERTS === */
.no-alerts[b-u3k6g1txq0] {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    color: var(--dxbl-text-muted, #6c757d);
    background: var(--dxbl-surface-bg, #fff);
    border: 1px dashed var(--dxbl-border-color, #dee2e6);
    border-radius: 12px;
}

.no-alerts p[b-u3k6g1txq0] {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
    font-size: 1rem;
}

/* === RESPONSIVE === */
@media (max-width: 1200px) {
    .alert-card-shadow[b-u3k6g1txq0] {
        width: calc(50% - 0.5rem);
        min-width: 320px;
    }
}

@media (max-width: 992px) {
    .alert-card-shadow[b-u3k6g1txq0] {
        width: calc(50% - 0.5rem);
        min-width: 320px;
    }
    
    .filter-cell[b-u3k6g1txq0] {
        min-width: 100px;
    }
}

@media (max-width: 768px) {
    .alert-card-shadow[b-u3k6g1txq0] {
        width: 100%;
    }
    
    .alert-filter-table[b-u3k6g1txq0] {
        display: block;
    }
    
    .alert-filter-table tr[b-u3k6g1txq0] {
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem;
    }
    
    .filter-td[b-u3k6g1txq0] {
        flex: 1 1 45%;
        min-width: 120px;
    }
    
    .alert-toolbar[b-u3k6g1txq0] {
        flex-direction: column;
        gap: 0.5rem;
    }
}
/* /Editors/ApplicationUserCardList.razor.rz.scp.css */
/* ===== ApplicationUser Card List ===== */

.user-cards-wrap[b-svs53r80kk] {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: 8px 4px;
}

.user-group-section[b-svs53r80kk] {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

.user-group-header[b-svs53r80kk] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 4px;
    border-bottom: 1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6));
}

.user-group-title-wrap[b-svs53r80kk] {
    display: flex;
    align-items: center;
    gap: 10px;
}

.user-group-title[b-svs53r80kk] {
    font-size: 1rem;
    font-weight: 700;
    color: inherit;
}

.user-group-count[b-svs53r80kk] {
    font-size: .8rem;
    font-weight: 600;
    color: var(--dxbl-text-secondary, #6c757d);
}

.user-group-cards[b-svs53r80kk] {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
    justify-content: flex-start;
}

/* --- Card container --- */
.user-card-shadow[b-svs53r80kk] {
    width: 340px;
    border-radius: 1rem;
    background: var(--dxbl-surface-bg, var(--bs-body-bg, #fff));
    box-shadow: 0 4px 12px var(--dxbl-shadow-color, rgba(0, 0, 0, .10));
    transition: transform .2s ease, box-shadow .2s ease;
    overflow: hidden;
    cursor: pointer;
    display: flex;
    flex-direction: column;
}

    .user-card-shadow:hover[b-svs53r80kk] {
        transform: translateY(-6px);
        box-shadow: 0 8px 24px var(--dxbl-shadow-color, rgba(0, 0, 0, .18));
    }

/* --- Header --- */
.user-card-header[b-svs53r80kk] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 16px 12px;
    background: var(--dxbl-grid-header-bg, var(--dxbl-surface-alt-bg, var(--bs-secondary-bg, #f8f9fa)));
    border-bottom: 1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6));
    flex-wrap: wrap;
}

.user-avatar[b-svs53r80kk] {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    color: #fff;
    flex-shrink: 0;
    letter-spacing: 1px;
    text-shadow: 0 1px 2px rgba(0, 0, 0, .25);
}

.user-header-info[b-svs53r80kk] {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1;
}

.user-name[b-svs53r80kk] {
    font-weight: 700;
    font-size: 1.05rem;
    color: inherit;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-email[b-svs53r80kk] {
    font-size: .78rem;
    color: var(--dxbl-text-secondary, #6c757d);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-status-badges[b-svs53r80kk] {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

.status-pill[b-svs53r80kk] {
    padding: 3px 10px;
    border-radius: 12px;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

    .status-pill.active[b-svs53r80kk] {
        background: linear-gradient(135deg, #d4edda, #c3e6cb);
        color: #155724;
    }

    .status-pill.inactive[b-svs53r80kk] {
        background: linear-gradient(135deg, #f8d7da, #f5c6cb);
        color: #721c24;
    }

    .status-pill.locked[b-svs53r80kk] {
        background: linear-gradient(135deg, #fff3cd, #ffeeba);
        color: #856404;
    }

/* --- Body --- */
.user-card-body[b-svs53r80kk] {
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    flex: 1;
}

.user-section[b-svs53r80kk] {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.section-label[b-svs53r80kk] {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--dxbl-text-secondary, #6c757d);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Role badges */
.role-badges[b-svs53r80kk] {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.role-badge[b-svs53r80kk] {
    padding: 3px 10px;
    border-radius: 10px;
    font-size: .72rem;
    font-weight: 600;
    white-space: nowrap;
}

    .role-badge.role-admin[b-svs53r80kk] {
        background: linear-gradient(135deg, #667eea, #764ba2);
        color: #fff;
    }

    .role-badge.role-default[b-svs53r80kk] {
        background: var(--dxbl-surface-alt-bg, #e9ecef);
        color: var(--dxbl-text-primary, #495057);
    }

    .role-badge.role-none[b-svs53r80kk] {
        background: transparent;
        color: var(--dxbl-text-secondary, #adb5bd);
        border: 1px dashed var(--dxbl-border-color, #ced4da);
    }

    .role-badge.billing-subscriber[b-svs53r80kk] {
        background: linear-gradient(135deg, #d4edda, #c3e6cb);
        color: #155724;
    }

    .role-badge.billing-pay-per-use[b-svs53r80kk] {
        background: linear-gradient(135deg, #fff3cd, #ffeeba);
        color: #856404;
    }

    .role-badge.billing-sentrynet[b-svs53r80kk] {
        background: linear-gradient(135deg, #d1ecf1, #bee5eb);
        color: #0c5460;
    }

/* Device usage */
.device-usage[b-svs53r80kk] {
    display: flex;
    align-items: center;
    gap: 10px;
}

.device-usage-text[b-svs53r80kk] {
    font-size: .85rem;
    min-width: 50px;
    white-space: nowrap;
}

    .device-usage-text strong[b-svs53r80kk] {
        font-size: 1rem;
    }

.device-progress-track[b-svs53r80kk] {
    flex: 1;
    height: 6px;
    background: var(--dxbl-surface-alt-bg, #e9ecef);
    border-radius: 3px;
    overflow: hidden;
}

.device-progress-bar[b-svs53r80kk] {
    height: 100%;
    border-radius: 3px;
    transition: width .3s ease;
}

/* Info grid */
.user-info-grid[b-svs53r80kk] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.info-item[b-svs53r80kk] {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 8px;
    border-radius: 8px;
    background: var(--dxbl-surface-alt-bg, rgba(0, 0, 0, .02));
    min-width: 0;
}

.info-icon[b-svs53r80kk] {
    font-size: .9rem;
    flex-shrink: 0;
}

.info-label[b-svs53r80kk] {
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--dxbl-text-secondary, #6c757d);
    flex-shrink: 0;
}

.info-value[b-svs53r80kk] {
    font-size: .78rem;
    font-weight: 600;
    margin-left: auto;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.text-success[b-svs53r80kk] {
    color: #28a745 !important;
}

.text-muted[b-svs53r80kk] {
    color: #adb5bd !important;
}

/* Basket grid */
.basket-grid[b-svs53r80kk] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
}

.basket-item[b-svs53r80kk] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 10px;
    border-radius: 8px;
    background: linear-gradient(135deg, #e7f3ff 0%, #d0e7ff 100%);
    border: 1px solid #b3d9ff;
}

.basket-label[b-svs53r80kk] {
    font-size: .7rem;
    font-weight: 600;
    text-transform: uppercase;
    color: #004080;
}

.basket-value[b-svs53r80kk] {
    font-size: .85rem;
    font-weight: 700;
    color: #004080;
}

.basket-total[b-svs53r80kk] {
    font-size: .7rem;
    font-weight: 400;
    opacity: .65;
}

/* --- Footer --- */
.user-card-footer[b-svs53r80kk] {
    padding: 10px 16px 14px;
    display: flex;
    gap: 8px;
    border-top: 1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6));
}

/* --- Empty state --- */
.user-empty-state[b-svs53r80kk] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 48px;
    color: var(--dxbl-text-secondary, #6c757d);
    width: 100%;
}

    .user-empty-state p[b-svs53r80kk] {
        margin: 0;
        font-size: .95rem;
    }
/* /Editors/HoneypotInstanceCardList.razor.rz.scp.css */
.honeypot-card-list[b-qg2qn5cj74] {
    padding: 1rem 0.25rem 2rem;
    color: var(--bs-body-color, #0f172a);
}

.honeypot-hero[b-qg2qn5cj74] {
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    align-items: stretch;
    padding: 1.5rem;
    margin-bottom: 1rem;
    border-radius: 1.5rem;
    background:
        radial-gradient(circle at top left, rgba(244, 122, 32, 0.28), transparent 34%),
        linear-gradient(135deg, #071827 0%, #10283f 55%, #163a59 100%);
    color: #f8fafc;
    box-shadow: 0 18px 45px rgba(7, 24, 39, 0.22);
    overflow: hidden;
    position: relative;
}

.honeypot-hero[b-qg2qn5cj74]::after {
    content: "";
    position: absolute;
    right: -70px;
    top: -90px;
    width: 260px;
    height: 260px;
    border: 18px solid rgba(244, 122, 32, 0.65);
    border-radius: 50%;
}

.eyebrow[b-qg2qn5cj74] {
    color: #fb923c;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.honeypot-hero h3[b-qg2qn5cj74] {
    margin: 0;
    font-size: clamp(1.55rem, 3vw, 2.35rem);
    font-weight: 800;
    letter-spacing: -0.03em;
}

.honeypot-hero p[b-qg2qn5cj74] {
    margin: 0.45rem 0 0;
    max-width: 720px;
    color: rgba(248, 250, 252, 0.78);
}

.hero-stats[b-qg2qn5cj74] {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    z-index: 1;
}

.hero-stat[b-qg2qn5cj74] {
    min-width: 92px;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(10px);
    text-align: center;
}

.hero-stat span[b-qg2qn5cj74] {
    display: block;
    font-size: 1.65rem;
    font-weight: 800;
    line-height: 1;
}

.hero-stat small[b-qg2qn5cj74] {
    display: block;
    margin-top: 0.35rem;
    color: rgba(248, 250, 252, 0.72);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.68rem;
}

.hero-stat.running span[b-qg2qn5cj74] {
    color: #22c55e;
}

.hero-stat.warning span[b-qg2qn5cj74] {
    color: #fb923c;
}

.honeypot-grid[b-qg2qn5cj74] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1rem;
}

.honeypot-card[b-qg2qn5cj74] {
    position: relative;
    overflow: hidden;
    min-height: 385px;
    padding: 1.1rem;
    border-radius: 1.35rem;
    border: 1px solid rgba(148, 163, 184, 0.24);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.92)),
        radial-gradient(circle at top right, rgba(244, 122, 32, 0.16), transparent 42%);
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.10);
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.honeypot-card:hover[b-qg2qn5cj74] {
    transform: translateY(-5px);
    border-color: rgba(244, 122, 32, 0.52);
    box-shadow: 0 18px 46px rgba(15, 23, 42, 0.18);
}

.status-strip[b-qg2qn5cj74] {
    position: absolute;
    inset: 0 auto 0 0;
    width: 7px;
    background: #94a3b8;
}

.honeypot-card.running .status-strip[b-qg2qn5cj74] {
    background: linear-gradient(180deg, #22c55e, #16a34a);
}

.honeypot-card.stopped .status-strip[b-qg2qn5cj74] {
    background: linear-gradient(180deg, #64748b, #334155);
}

.honeypot-card.degraded .status-strip[b-qg2qn5cj74] {
    background: linear-gradient(180deg, #f59e0b, #ea580c);
}

.honeypot-card.unreachable .status-strip[b-qg2qn5cj74] {
    background: linear-gradient(180deg, #ef4444, #991b1b);
}

.card-topline[b-qg2qn5cj74],
.card-title-row[b-qg2qn5cj74],
.card-footer-row[b-qg2qn5cj74] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.provider-badge[b-qg2qn5cj74],
.runtime-pill[b-qg2qn5cj74] {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 999px;
    padding: 0.4rem 0.7rem;
    font-size: 0.78rem;
    font-weight: 700;
}

.provider-badge[b-qg2qn5cj74] {
    color: #0f172a;
    background: #f1f5f9;
}

.provider-icon[b-qg2qn5cj74] {
    font-size: 1.05rem;
}

.runtime-pill[b-qg2qn5cj74] {
    color: #334155;
    background: #e2e8f0;
}

.runtime-pill.running[b-qg2qn5cj74] {
    color: #166534;
    background: #dcfce7;
}

.runtime-pill.stopped[b-qg2qn5cj74] {
    color: #334155;
    background: #e2e8f0;
}

.runtime-pill.degraded[b-qg2qn5cj74] {
    color: #9a3412;
    background: #ffedd5;
}

.runtime-pill.unreachable[b-qg2qn5cj74] {
    color: #991b1b;
    background: #fee2e2;
}

.card-title-row[b-qg2qn5cj74] {
    margin-top: 1rem;
    align-items: flex-start;
}

.card-title-row h4[b-qg2qn5cj74] {
    margin: 0;
    color: #071827;
    font-size: 1.35rem;
    font-weight: 800;
}

.host-line[b-qg2qn5cj74] {
    color: #64748b;
    font-size: 0.88rem;
}

.power-indicator[b-qg2qn5cj74] {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    margin-top: 0.35rem;
    box-shadow: 0 0 0 5px rgba(148, 163, 184, 0.16);
}

.power-indicator.enabled[b-qg2qn5cj74] {
    background: #22c55e;
    box-shadow: 0 0 0 5px rgba(34, 197, 94, 0.16);
}

.power-indicator.disabled[b-qg2qn5cj74] {
    background: #94a3b8;
}

.health-panel[b-qg2qn5cj74] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.7rem;
    margin: 1rem 0;
}

.health-item[b-qg2qn5cj74] {
    padding: 0.8rem;
    border-radius: 1rem;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.health-item.ok[b-qg2qn5cj74] {
    background: #f0fdf4;
    border-color: #bbf7d0;
}

.health-item.warn[b-qg2qn5cj74] {
    background: #fff7ed;
    border-color: #fed7aa;
}

.health-item.muted[b-qg2qn5cj74] {
    background: #f8fafc;
}

.health-value[b-qg2qn5cj74],
.health-label[b-qg2qn5cj74] {
    display: block;
}

.health-value[b-qg2qn5cj74] {
    font-weight: 800;
    color: #0f172a;
}

.health-label[b-qg2qn5cj74] {
    margin-top: 0.15rem;
    color: #64748b;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.meta-grid[b-qg2qn5cj74] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
}

.meta-item[b-qg2qn5cj74] {
    min-width: 0;
}

.meta-label[b-qg2qn5cj74] {
    display: block;
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.meta-value[b-qg2qn5cj74] {
    display: block;
    overflow: hidden;
    color: #0f172a;
    font-weight: 650;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.meta-value.mono[b-qg2qn5cj74] {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.82rem;
}

.last-message[b-qg2qn5cj74] {
    min-height: 3.75rem;
    margin: 1rem 0;
    padding: 0.75rem;
    border-radius: 0.9rem;
    color: #475569;
    background: rgba(241, 245, 249, 0.72);
    font-size: 0.86rem;
    line-height: 1.35;
}

.card-footer-row[b-qg2qn5cj74] {
    margin-top: auto;
}

.timestamp span[b-qg2qn5cj74],
.timestamp strong[b-qg2qn5cj74] {
    display: block;
}

.timestamp span[b-qg2qn5cj74] {
    color: #64748b;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.timestamp strong[b-qg2qn5cj74] {
    color: #0f172a;
    font-size: 0.9rem;
}

.empty-state[b-qg2qn5cj74] {
    padding: 3rem 1rem;
    border: 1px dashed rgba(148, 163, 184, 0.7);
    border-radius: 1.5rem;
    text-align: center;
    background: #f8fafc;
}

.empty-icon[b-qg2qn5cj74] {
    color: #f47a20;
    font-size: 3rem;
    line-height: 1;
}

.empty-state h4[b-qg2qn5cj74] {
    margin: 0.5rem 0 0.25rem;
    color: #071827;
}

.empty-state p[b-qg2qn5cj74] {
    margin: 0;
    color: #64748b;
}

@media (max-width: 760px) {
    .honeypot-hero[b-qg2qn5cj74] {
        flex-direction: column;
    }

    .hero-stats[b-qg2qn5cj74] {
        flex-wrap: wrap;
    }

    .honeypot-grid[b-qg2qn5cj74] {
        grid-template-columns: 1fr;
    }
}
/* /Editors/HTDeviceCardList.razor.rz.scp.css */
/* Rimuovi tutte le altre regole per .card, .dxbl-card, etc. e usa solo questa */

[b-d45d1tcv8u] .device-card-shadow .card {
    --bs-card-spacer-y: 0.1rem;
    --bs-card-spacer-x: 0.1rem;
    --bs-card-cap-padding-y: 0.4rem;
    --bs-card-cap-padding-x: 0.2rem;
    border-radius: 1rem; /* Arrotonda gli angoli della card stessa */
    overflow: hidden; /* Necessario per far rispettare il border-radius ai figli */
}

/* ----- layout grid ----- */
.devices-grid[b-d45d1tcv8u] {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
}

/* contenitore flessibile che avvolge le card */
.devices-wrap[b-d45d1tcv8u] {
    display: flex;
    flex-wrap: wrap; /* manda a capo quando serve */
    gap: 1rem; /* spazio orizzontale + verticale fra le card */
    justify-content: flex-start; /* allinea a sinistra, niente stretch */
    padding-top: 6px;
}

/* wrapper della card: larghezza fissa 340px */
.device-card[b-d45d1tcv8u] {
    border-radius: 1rem;
    width: 360px; /* cambia qui la larghezza desiderata */
    flex: 0 0 auto; /* non si allunga n� si restringe */
}

.device-card-shadow[b-d45d1tcv8u] {
    width: 360px;
    height: fit-content;
    border-radius: 1rem;
    box-shadow: 0 6px 10px var(--dxbl-shadow-color, rgba(0,0,0,.12)); background-color: var(--dxbl-surface-bg, var(--bs-body-bg, #fff));
    transition: transform .15s ease, box-shadow .15s ease;
}

.device-card-shadow:hover[b-d45d1tcv8u] {
    transform: translateY(-6px);
    box-shadow: 0 8px 18px var(--dxbl-shadow-color, rgba(0,0,0,.18));
    border-color: var(--dxbl-btn-primary-bg, var(--bs-primary)); /* bordo si colora con il primario        */
}

/* ----- header ----- */
[b-d45d1tcv8u] .device-card-shadow .device-card-header {
    /* Questo stile si applica al div interno che hai creato tu */
    padding: .6rem;
    text-align: center;
    border-radius: 1rem 1rem 0 0;
    background-color: var(--dxbl-grid-header-bg, var(--dxbl-surface-alt-bg, var(--bs-secondary-bg, #f8f9fa))); border-bottom: 1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6));
}

.header-flex[b-d45d1tcv8u] {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.dev-title[b-d45d1tcv8u] {
    font-weight: 600;
    font-size: 1.05rem;
    color: inherit; /* Eredita il colore dal tema */
}

/* ----- body ----- */
[b-d45d1tcv8u] .device-card-shadow .device-card-body {
    padding: .75rem 1rem 1rem;
    display: flex;
    gap: .5rem;
}

[b-d45d1tcv8u] .device-card-shadow .device-card-body dl {
    margin: 0;
}

[b-d45d1tcv8u] .device-card-shadow .device-card-body dt {
    font-weight: 600;
    font-size: .8rem;
    color: var(--dxbl-color-primary-dark);
    margin-bottom: .15rem;
}

[b-d45d1tcv8u] .device-card-shadow .device-card-body dd {
    margin: 0 0 .5rem 0;
    word-break: break-all;
}

/* ----- footer ----- */
[b-d45d1tcv8u] .device-card-shadow .device-card-footer {
    padding: .8rem .8rem ;
    display: flex;
    gap: .5rem;
}

[b-d45d1tcv8u] .badge {
    padding-top: 1.2em;
    padding-bottom: 0.1em;
}

.info-with-alert[b-d45d1tcv8u] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    gap: 16px; /* Aggiunge spazio tra i dettagli e il pulsante */
}

.info-details[b-d45d1tcv8u] {
    flex-grow: 1;
}

.alert-button-container[b-d45d1tcv8u] {
    flex-shrink: 0; /* Impedisce al pulsante di restringersi */
}


/* Stili per il bottone alert con effetto pulsante - usando ::deep per sovrascrivere DevExpress */
[b-d45d1tcv8u] .score-alert-btn {
    background-color: #e74c3c !important;
    color: white !important;
    border: none !important;
    padding: 8px 16px !important;
    text-align: center !important;
    text-decoration: none !important;
    display: inline-block !important;
    font-size: 14px !important;
    margin: 4px 2px !important;
    cursor: pointer !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1) !important;
    animation: pulsa-b-d45d1tcv8u 1.5s infinite !important;
    min-width: auto !important;
    min-height: auto !important;
}

    [b-d45d1tcv8u] .score-alert-btn:hover {
        background-color: #c0392b !important;
    }

    [b-d45d1tcv8u] .score-alert-btn .dxbl-btn-caption {
        color: white !important;
        font-weight: 600 !important;
    }

@keyframes pulsa-b-d45d1tcv8u {
    0% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(231, 76, 60, 0.7);
    }

    50% {
        transform: scale(1.05); /* Lieve ingrandimento */
    }

    70% {
        box-shadow: 0 0 0 10px rgba(231, 76, 60, 0);
    }

    100% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(231, 76, 60, 0);
    }
}

.info-with-alert[b-d45d1tcv8u] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    gap: 16px; /* Spazio tra dettagli e pulsante */
}

.info-details[b-d45d1tcv8u] {
    flex-grow: 1;
}

.alert-button-container[b-d45d1tcv8u] {
    flex-shrink: 0; /* Impedisce al pulsante di rimpicciolirsi */
}

/* Forza la rimozione di background dal tema per l'indicator */
.device-card-shadow .dxbl-progress-bar-indicator[b-d45d1tcv8u] {
    background-image: none !important;
    transition: none !important; /* Disabilita animazioni che potrebbero interferire */
}

/* Assicura che l'indicator sia sempre visibile */
.device-card-shadow .dxbl-progress-bar-indicator[b-d45d1tcv8u] {
    min-width: 3px !important; /* Minimo visibile anche a 0% */
    opacity: 1 !important;
}

/* Rimuovi eventuali gradienti o effetti dal tema */
.device-card-shadow .dxbl-progress-bar-track[b-d45d1tcv8u] {
    background-image: none !important;
}

/* Il resto del CSS rimane uguale */
.device-card-footer .btn-group[b-d45d1tcv8u] {
    display: inline-flex;
    vertical-align: middle;
}

    .device-card-footer .btn-group .dx-btn[b-d45d1tcv8u] {
        margin-left: 2px;
    }

.device-card-header .badge[b-d45d1tcv8u] {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

/*     .score-alert-btn {
        padding: 4px 12px;
        font-size: 1rem;
        min-width: 32px;
        min-height: 32px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
 */
.traffic-sparkline-container[b-d45d1tcv8u] {
    margin-top: 8px;
}

    .traffic-sparkline-container canvas[b-d45d1tcv8u] {
        width: 100%;
        height: 60px;
        display: block;
    }

.traffic-last[b-d45d1tcv8u] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 6px;
    margin-bottom: 6px;
    align-items: stretch;
    width: 100%;
}

.pill[b-d45d1tcv8u] {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 10px;
    font-size: 0.85rem;
    font-weight: 600;
    line-height: 1;
    min-width: 0;
    width: 100%;
}

    .pill strong[b-d45d1tcv8u] {
        margin-left: auto;
        white-space: nowrap;
    }

.pill-out[b-d45d1tcv8u] {
    background: rgba(214, 51, 132, 0.1);
    color: #d63384;
}

.pill-in[b-d45d1tcv8u] {
    background: rgba(13, 110, 253, 0.1);
    color: #0d6efd;
}

.traffic-summary[b-d45d1tcv8u] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 6px;
    margin-top: 6px;
    align-items: stretch;
    width: 100%;
}

.pill-total[b-d45d1tcv8u] {
    width: 100%;
}

    .pill-total strong[b-d45d1tcv8u] {
        margin-left: auto;
        white-space: nowrap;
    }

.badge-total[b-d45d1tcv8u] {
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    border-radius: 9px;
    background: rgba(0,0,0,0.08);
    color: #6c757d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

    .badge-total[b-d45d1tcv8u]::before {
        content: "?";
        font-size: 0.7rem;
        line-height: 1;
    }
/* === ALERT COUNTERS COLUMN (3 levels, vertical, thin) - Card Version === */
.alert-counters-column-card[b-d45d1tcv8u] {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 8px;
}

.alert-counter-card[b-d45d1tcv8u] {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    border-radius: 6px;
    transition: all 0.2s ease;
    border: 1px solid transparent;
    min-height: 36px;
}

.alert-counter-card:hover[b-d45d1tcv8u] {
    transform: translateX(2px);
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

.counter-icon-card[b-d45d1tcv8u] {
    font-size: 1.2rem;
    flex-shrink: 0;
}

.counter-content-card[b-d45d1tcv8u] {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
}

.counter-value-card[b-d45d1tcv8u] {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
    min-width: 24px;
}

.counter-label-card[b-d45d1tcv8u] {
    font-size: 0.7rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.3px;
    opacity: 0.85;
}

/* Info Counter (0-50) - Usa colori del tema */
.info-counter-card[b-d45d1tcv8u] {
    background: linear-gradient(90deg, #e7f3ff 0%, #d0e7ff 100%);
    border-color: #b3d9ff;
}

.info-counter-card .counter-value-card[b-d45d1tcv8u] {
    color: #004080;
}

.info-counter-card .counter-label-card[b-d45d1tcv8u] {
    color: #0066cc;
}

/* Warning Counter (51-75) - Orange - Usa colori del tema */
.warning-counter-card[b-d45d1tcv8u] {
    background: linear-gradient(90deg, #fff3e0 0%, #ffe0b2 100%);
    border-color: #ffb74d;
}

.warning-counter-card .counter-value-card[b-d45d1tcv8u] {
    color: #e65100;
}

.warning-counter-card .counter-label-card[b-d45d1tcv8u] {
    color: #f57c00;
}

/* Danger Counter (76-100) - Red - Usa colori del tema */
.danger-counter-card[b-d45d1tcv8u] {
    background: linear-gradient(90deg, #ffe4e4 0%, #ffcccc 100%);
    border-color: #ffb3b3;
}

.danger-counter-card .counter-value-card[b-d45d1tcv8u] {
    color: #a71e2a;
}

.danger-counter-card .counter-label-card[b-d45d1tcv8u] {
    color: #dc3545;
}

/* === PULSE ANIMATION FOR NEW ALERTS === */
@keyframes alert-pulse-b-d45d1tcv8u {
    0% {
        box-shadow: 0 0 0 0 rgba(220, 53, 69, 0.7);
        transform: scale(1);
    }
    50% {
        box-shadow: 0 0 0 10px rgba(220, 53, 69, 0);
        transform: scale(1.02);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(220, 53, 69, 0);
        transform: scale(1);
    }
}

.pulse-alert[b-d45d1tcv8u] {
    animation: alert-pulse-b-d45d1tcv8u 1s ease-in-out 3;
}

.pulse-alert .alert-counter-card[b-d45d1tcv8u] {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* === DEVICE INFO COMPACT LAYOUT === */
.device-info-compact[b-d45d1tcv8u] {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 12px;
}

.info-row[b-d45d1tcv8u] {
    display: flex;
    align-items: baseline;
    gap: 6px;
}

.info-row dt[b-d45d1tcv8u] {
    font-weight: 600;
    font-size: 0.75rem;
    color: var(--dxbl-color-primary-dark);
    margin: 0;
    white-space: nowrap;
}

.info-row dd[b-d45d1tcv8u] {
    margin: 0;
    font-size: 0.8rem;
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* === ALERT BUTTON FULL WIDTH === */
.alert-button-full[b-d45d1tcv8u] {
    width: 100%;
    margin-bottom: 12px;
}

.alert-button-full .score-alert-btn[b-d45d1tcv8u] {
    width: 100% !important;
    display: block !important;
}
/* /Pages/AIAnalysisPage.razor.rz.scp.css */
.ai-analysis-fullpage-container[b-vfz32yu39p] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    padding: 20px;
}

.ai-analysis-fullpage-card[b-vfz32yu39p] {
    background: white;
    border-radius: 20px;
    box-shadow: 0 25px 70px rgba(0, 0, 0, 0.3);
    max-width: 1400px;
    width: 100%;
    height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    animation: slideIn-b-vfz32yu39p 0.3s ease-out;
}

@keyframes slideIn-b-vfz32yu39p {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ai-analysis-fullpage-header[b-vfz32yu39p] {
    padding: 25px 30px;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
    border-bottom: 1px solid #e2e8f0;
}

.header-content[b-vfz32yu39p] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.btn-back[b-vfz32yu39p] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    color: #4a5568;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-back:hover[b-vfz32yu39p] {
    background: #667eea;
    color: white;
    border-color: #667eea;
    transform: translateX(-2px);
}

.header-center[b-vfz32yu39p] {
    display: flex;
    align-items: center;
    gap: 20px;
}

.ai-header-icon[b-vfz32yu39p] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 70px;
    height: 70px;
    background: white;
    border-radius: 50%;
    color: #667eea;
    box-shadow: 0 8px 20px rgba(102, 126, 234, 0.25);
}

.header-text[b-vfz32yu39p] {
    text-align: left;
}

.ai-analysis-title[b-vfz32yu39p] {
    margin: 0 0 5px;
    color: #2d3748;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -0.5px;
}

.ai-analysis-subtitle[b-vfz32yu39p] {
    margin: 0;
    color: #718096;
    font-size: 14px;
}

.header-info[b-vfz32yu39p] {
    display: flex;
    gap: 15px;
}

.info-badge[b-vfz32yu39p] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: white;
    border-radius: 20px;
    font-size: 13px;
    color: #4a5568;
    font-weight: 500;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.ai-analysis-badges[b-vfz32yu39p] {
    display: flex;
    justify-content: center;
    gap: 12px;
    padding: 20px;
    background: #f7fafc;
    border-bottom: 1px solid #e2e8f0;
}

.ai-feature-badge[b-vfz32yu39p] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    font-size: 13px;
    color: #4a5568;
    font-weight: 500;
    transition: all 0.2s ease;
}

.ai-feature-badge:hover[b-vfz32yu39p] {
    border-color: #667eea;
    color: #667eea;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}

.ai-analysis-body[b-vfz32yu39p] {
    flex: 1;
    overflow: hidden;
    background: #fafbfc;
}

.loading-fullpage[b-vfz32yu39p] {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
}

.loading-content[b-vfz32yu39p] {
    text-align: center;
    padding: 40px;
    background: white;
    border-radius: 20px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
}

.spinner-wrapper[b-vfz32yu39p] {
    margin-bottom: 20px;
}

.spinner-border[b-vfz32yu39p] {
    width: 4rem;
    height: 4rem;
}

.loading-text[b-vfz32yu39p] {
    color: #718096;
    font-size: 16px;
    margin: 0;
}

@media (max-width: 768px) {
    .ai-analysis-fullpage-card[b-vfz32yu39p] {
        border-radius: 0;
        height: 100vh;
        max-width: 100%;
    }

    .ai-analysis-fullpage-container[b-vfz32yu39p] {
        padding: 0;
    }

    .header-content[b-vfz32yu39p] {
        flex-direction: column;
        gap: 15px;
    }

    .header-info[b-vfz32yu39p] {
        flex-direction: column;
        width: 100%;
    }

    .ai-analysis-badges[b-vfz32yu39p] {
        flex-wrap: wrap;
    }
}
/* /Pages/AlertDetailPage.razor.rz.scp.css */
/* Alert Detail Page Styles */

.alert-detail-fullpage-container[b-1gouazet2w] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    padding: 20px;
    overflow: visible; /* Rimuove la scrollbar */
    height: auto; /* Permette all'elemento di espandersi */
}

.alert-detail-fullpage-card[b-1gouazet2w] {
    background: white;
    border-radius: 20px;
    box-shadow: 0 25px 70px rgba(0, 0, 0, 0.3);
    max-width: 1600px;
    width: 100%;
    height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: visible; /* Rimuove la scrollbar */
    height: auto;
    min-height: 100vh; /* Mantiene almeno l'altezza della viewport */
    max-height: none;
    animation: slideIn-b-1gouazet2w 0.3s ease-out;
}

@keyframes slideIn-b-1gouazet2w {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Header */
.alert-detail-header[b-1gouazet2w] {
    padding: 25px 30px;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
    border-bottom: 1px solid #e2e8f0;
}

.header-content[b-1gouazet2w] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.btn-back[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    color: #4a5568;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-back:hover[b-1gouazet2w] {
    background: #667eea;
    color: white;
    border-color: #667eea;
    transform: translateX(-2px);
}

.header-center[b-1gouazet2w] {
    display: flex;
    align-items: center;
    gap: 20px;
}

.risk-indicator[b-1gouazet2w] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 70px;
    height: 70px;
    background: white;
    border-radius: 50%;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.risk-indicator.risk-critical[b-1gouazet2w] {
    color: #dc2626;
    box-shadow: 0 8px 20px rgba(220, 38, 38, 0.25);
}

.risk-indicator.risk-high[b-1gouazet2w] {
    color: #ea580c;
    box-shadow: 0 8px 20px rgba(234, 88, 12, 0.25);
}

.risk-indicator.risk-medium[b-1gouazet2w] {
    color: #f59e0b;
    box-shadow: 0 8px 20px rgba(245, 158, 11, 0.25);
}

.risk-indicator.risk-low[b-1gouazet2w] {
    color: #3b82f6;
    box-shadow: 0 8px 20px rgba(59, 130, 246, 0.25);
}

.risk-indicator.risk-info[b-1gouazet2w] {
    color: #6b7280;
    box-shadow: 0 8px 20px rgba(107, 114, 128, 0.25);
}

.header-text[b-1gouazet2w] {
    text-align: left;
}

.alert-title[b-1gouazet2w] {
    margin: 0 0 5px;
    color: #2d3748;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.5px;
    max-width: 600px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alert-subtitle[b-1gouazet2w] {
    margin: 0;
    color: #718096;
    font-size: 14px;
}

.header-info[b-1gouazet2w] {
    display: flex;
    gap: 15px;
}

.severity-badge[b-1gouazet2w], .score-badge[b-1gouazet2w], .ai-score-badge[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    background: white;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.severity-badge.severity-1[b-1gouazet2w] {
    background: #fee2e2;
    color: #dc2626;
}

.severity-badge.severity-2[b-1gouazet2w] {
    background: #fed7aa;
    color: #ea580c;
}

.severity-badge.severity-3[b-1gouazet2w] {
    background: #fef3c7;
    color: #f59e0b;
}

.score-badge[b-1gouazet2w] {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

.ai-score-badge[b-1gouazet2w] {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: white;
}

/* Feature Badges */
.alert-badges[b-1gouazet2w] {
    display: flex;
    justify-content: center;
    gap: 12px;
    padding: 20px;
    background: #f7fafc;
    border-bottom: 1px solid #e2e8f0;
}

.feature-badge[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    font-size: 13px;
    color: #4a5568;
    font-weight: 500;
    transition: all 0.2s ease;
}

.feature-badge:hover[b-1gouazet2w] {
    border-color: #667eea;
    color: #667eea;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}

/* Body */
.alert-body[b-1gouazet2w] {
    flex: 1;
    overflow: visible; /* Rimuove la scrollbar */
    height: auto; /* Permette all'elemento di espandersi */
    max-height: none; /* Rimuove eventuali limiti di altezza */
    padding: 20px;
    background: #fafbfc;
}

.info-section[b-1gouazet2w] {
    background: white;
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.section-title[b-1gouazet2w] {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 20px;
    color: #2d3748;
    font-size: 18px;
    font-weight: 600;
    padding-bottom: 12px;
    border-bottom: 2px solid #e2e8f0;
}

.info-grid[b-1gouazet2w] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
}

.info-item[b-1gouazet2w] {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.info-item.full-width[b-1gouazet2w] {
    grid-column: 1 / -1;
}

.info-label[b-1gouazet2w] {
    font-size: 12px;
    font-weight: 600;
    color: #718096;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.info-value[b-1gouazet2w] {
    font-size: 14px;
    color: #2d3748;
    word-break: break-all;
}

.info-value.ip-address[b-1gouazet2w] {
    font-family: 'Monaco', 'Courier New', monospace;
    background: #f7fafc;
    padding: 4px 8px;
    border-radius: 4px;
    display: inline-block;
    width: fit-content;
}

.info-value.url[b-1gouazet2w] {
    color: #3b82f6;
    text-decoration: underline;
}

.info-value.hash[b-1gouazet2w] {
    font-family: 'Monaco', 'Courier New', monospace;
    font-size: 12px;
    background: #f7fafc;
    padding: 4px 8px;
    border-radius: 4px;
    word-break: break-all;
}

.info-value.method-get[b-1gouazet2w] { color: #10b981; }
.info-value.method-post[b-1gouazet2w] { color: #3b82f6; }
.info-value.method-put[b-1gouazet2w] { color: #f59e0b; }
.info-value.method-delete[b-1gouazet2w] { color: #ef4444; }

.info-value.status-success[b-1gouazet2w] { color: #10b981; }
.info-value.status-redirect[b-1gouazet2w] { color: #3b82f6; }
.info-value.status-client-error[b-1gouazet2w] { color: #f59e0b; }
.info-value.status-server-error[b-1gouazet2w] { color: #ef4444; }

/* Community ID */
.community-id-item[b-1gouazet2w] {
    grid-column: span 2;
}

.info-value.community-id[b-1gouazet2w] {
    font-family: 'Monaco', 'Consolas', 'Courier New', monospace;
    font-size: 13px;
    font-weight: 600;
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    border: 1px solid #f59e0b;
    padding: 8px 12px;
    border-radius: 8px;
    color: #92400e;
    display: inline-block;
    word-break: break-all;
}

/* Stats */
.stats-grid[b-1gouazet2w] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
}

.stat-card[b-1gouazet2w] {
    background: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
    border-radius: 10px;
    padding: 20px;
    text-align: center;
}

.stat-label[b-1gouazet2w] {
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
    text-transform: uppercase;
    margin-bottom: 8px;
}

.stat-value[b-1gouazet2w] {
    font-size: 24px;
    font-weight: 700;
    color: #2d3748;
    margin-bottom: 4px;
}

.stat-sub[b-1gouazet2w] {
    font-size: 14px;
    color: #6b7280;
}

/* AI Analysis Section */
.ai-analysis-section[b-1gouazet2w] {
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
    border: 1px solid #86efac;
}

.ai-analysis-content[b-1gouazet2w] {
    background: white;
    border-radius: 8px;
    padding: 20px;
    margin-top: 15px;
}

.ai-score-display[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: white;
    padding: 10px 20px;
    border-radius: 20px;
    margin-bottom: 15px;
}

.ai-score-label[b-1gouazet2w] {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
}

.ai-score-value[b-1gouazet2w] {
    font-size: 20px;
    font-weight: 700;
}

.ai-analysis-text[b-1gouazet2w] {
    color: #374151;
    line-height: 1.6;
    margin-bottom: 10px;
}

.ai-analysis-date[b-1gouazet2w] {
    font-size: 12px;
    color: #6b7280;
    font-style: italic;
}

/* Risk Section */
.risk-section[b-1gouazet2w] {
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
    border: 1px solid #fca5a5;
}

.risk-content[b-1gouazet2w] {
    background: white;
    border-radius: 8px;
    padding: 20px;
    margin-top: 15px;
}

.risk-level-display[b-1gouazet2w] {
    display: inline-block;
    padding: 15px 30px;
    border-radius: 10px;
    text-align: center;
    margin-bottom: 15px;
}

.risk-level-display.risk-critical[b-1gouazet2w] {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
    color: white;
}

.risk-level-display.risk-high[b-1gouazet2w] {
    background: linear-gradient(135deg, #ea580c 0%, #c2410c 100%);
    color: white;
}

.risk-level-display.risk-medium[b-1gouazet2w] {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    color: white;
}

.risk-level-display.risk-low[b-1gouazet2w] {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    color: white;
}

.risk-level-display.risk-info[b-1gouazet2w] {
    background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%);
    color: white;
}

.risk-level-label[b-1gouazet2w] {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 5px;
}

.risk-level-value[b-1gouazet2w] {
    font-size: 24px;
    font-weight: 700;
}

.risk-reason[b-1gouazet2w] {
    background: #f9fafb;
    padding: 15px;
    border-radius: 8px;
    color: #374151;
    line-height: 1.5;
}

/* Metadata Section */
.metadata-section[b-1gouazet2w] {
    background: #f9fafb;
}

/* Loading */
.loading-fullpage[b-1gouazet2w] {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
}

.loading-content[b-1gouazet2w] {
    text-align: center;
    padding: 40px;
    background: white;
    border-radius: 20px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
}

.spinner-wrapper[b-1gouazet2w] {
    margin-bottom: 20px;
}

.spinner-border[b-1gouazet2w] {
    width: 4rem;
    height: 4rem;
}

.loading-text[b-1gouazet2w] {
    color: #718096;
    font-size: 16px;
    margin: 0;
}

/* Responsive */
@media (max-width: 768px) {
    .alert-detail-fullpage-card[b-1gouazet2w] {
        border-radius: 0;
        height: 100vh;
        max-width: 100%;
    }

    .alert-detail-fullpage-container[b-1gouazet2w] {
        padding: 0;
    }

    .header-content[b-1gouazet2w] {
        flex-direction: column;
        gap: 15px;
    }

    .header-info[b-1gouazet2w] {
        flex-direction: column;
        width: 100%;
    }

    .alert-badges[b-1gouazet2w] {
        flex-wrap: wrap;
    }

    .info-grid[b-1gouazet2w] {
        grid-template-columns: 1fr;
    }
}

/* Scrollbar */
.alert-body[b-1gouazet2w]::-webkit-scrollbar {
    width: 10px;
}

.alert-body[b-1gouazet2w]::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

.alert-body[b-1gouazet2w]::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 10px;
}

.alert-body[b-1gouazet2w]::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, #764ba2 0%, #667eea 100%);
}



.alert-actions-bar[b-1gouazet2w] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    background: #f8f9fa;
    border-top: 1px solid #e0e0e0;
}

.rule-indicators[b-1gouazet2w] {
    display: flex;
    gap: 12px;
}

.rule-indicator[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
}

    .rule-indicator.whitelist-active[b-1gouazet2w] {
        background: #d4edda;
        color: #155724;
        border: 1px solid #c3e6cb;
    }

    .rule-indicator.blocking-active[b-1gouazet2w] {
        background: #f8d7da;
        color: #721c24;
        border: 1px solid #f5c6cb;
    }

.alert-action-buttons[b-1gouazet2w] {
    display: flex;
    gap: 8px;
}

.btn-action[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

    .btn-action:disabled[b-1gouazet2w] {
        opacity: 0.5;
        cursor: not-allowed;
    }

    .btn-action.btn-block[b-1gouazet2w] {
        background: #dc3545;
        color: white;
    }

        .btn-action.btn-block:hover:not(:disabled)[b-1gouazet2w] {
            background: #c82333;
        }

    .btn-action.btn-whitelist[b-1gouazet2w] {
        background: #28a745;
        color: white;
    }

        .btn-action.btn-whitelist:hover:not(:disabled)[b-1gouazet2w] {
            background: #218838;
        }

    .btn-action.btn-ai[b-1gouazet2w] {
        background: #6f42c1;
        color: white;
    }

        .btn-action.btn-ai:hover:not(:disabled)[b-1gouazet2w] {
            background: #5a32a3;
        }

    .btn-action.btn-virustotal[b-1gouazet2w] {
        background: #394eed;
        color: white;
    }

        .btn-action.btn-virustotal:hover:not(:disabled)[b-1gouazet2w] {
            background: #2d3fb8;
            transform: translateY(-1px);
            box-shadow: 0 4px 12px rgba(57, 78, 237, 0.3);
        }

    .btn-action.btn-clear[b-1gouazet2w] {
        background: #6c757d;
        color: white;
    }

        .btn-action.btn-clear:hover:not(:disabled)[b-1gouazet2w] {
            background: #5a6268;
        }

/* Modal Overlay */
.modal-overlay[b-1gouazet2w] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    animation: fadeIn-b-1gouazet2w 0.2s ease-out;
}

@keyframes fadeIn-b-1gouazet2w {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* Modal Content */
.modal-content[b-1gouazet2w] {
    background: white;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    max-width: 600px;
    width: 90%;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    animation: slideUp-b-1gouazet2w 0.3s ease-out;
    overflow: hidden;
}

.modal-content.modal-large[b-1gouazet2w] {
    max-width: 900px;
}

@keyframes slideUp-b-1gouazet2w {
    from {
        opacity: 0;
        transform: translateY(50px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.modal-content h3[b-1gouazet2w] {
    margin: 0;
    padding: 24px 28px;
    font-size: 22px;
    font-weight: 700;
    color: #2d3748;
    background: linear-gradient(135deg, #f5f7fa 0%, #e2e8f0 100%);
    border-bottom: 2px solid #e2e8f0;
}

/* Modal Body */
.modal-body[b-1gouazet2w] {
    padding: 28px;
    overflow-y: auto;
    flex: 1;
}

.modal-body[b-1gouazet2w]::-webkit-scrollbar {
    width: 8px;
}

.modal-body[b-1gouazet2w]::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.modal-body[b-1gouazet2w]::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 4px;
}

.modal-body[b-1gouazet2w]::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, #764ba2 0%, #667eea 100%);
}

/* Modal Footer */
.modal-footer[b-1gouazet2w] {
    padding: 20px 28px;
    background: #f8f9fa;
    border-top: 1px solid #e2e8f0;
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

/* Form Elements in Modal */
.form-group[b-1gouazet2w] {
    margin-bottom: 20px;
}

.form-group label[b-1gouazet2w] {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #4a5568;
    margin-bottom: 8px;
}

.form-control[b-1gouazet2w] {
    width: 100%;
    padding: 10px 14px;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    font-size: 14px;
    transition: all 0.2s;
}

.form-control:focus[b-1gouazet2w] {
    outline: none;
    border-color: #667eea;
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* Modal Buttons */
.btn[b-1gouazet2w] {
    padding: 10px 24px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-primary[b-1gouazet2w] {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

.btn-primary:hover[b-1gouazet2w] {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(102, 126, 234, 0.4);
}

.btn-secondary[b-1gouazet2w] {
    background: #e2e8f0;
    color: #4a5568;
}

.btn-secondary:hover[b-1gouazet2w] {
    background: #cbd5e0;
}

.btn-danger[b-1gouazet2w] {
    background: #dc3545;
    color: white;
}

.btn-danger:hover[b-1gouazet2w] {
    background: #c82333;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(220, 53, 69, 0.4);
}

.btn-success[b-1gouazet2w] {
    background: #28a745;
    color: white;
}

.btn-success:hover[b-1gouazet2w] {
    background: #218838;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(40, 167, 69, 0.4);
}

/* AI Response Modal Specific Styles */
.ai-risk-score[b-1gouazet2w] {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: white;
    padding: 12px 24px;
    border-radius: 30px;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 20px;
}

.ai-risk-score .score[b-1gouazet2w] {
    font-size: 24px;
    font-weight: 700;
}

.ai-response[b-1gouazet2w] {
    background: #f8f9fa;
    padding: 20px;
    border-radius: 12px;
    line-height: 1.7;
    color: #374151;
}

.ai-response h2[b-1gouazet2w], .ai-response h3[b-1gouazet2w], .ai-response h4[b-1gouazet2w] {
    color: #2d3748;
    margin-top: 20px;
    margin-bottom: 12px;
    font-weight: 600;
}

.ai-response h2[b-1gouazet2w] {
    font-size: 20px;
}

.ai-response h3[b-1gouazet2w] {
    font-size: 18px;
}

.ai-response h4[b-1gouazet2w] {
    font-size: 16px;
}

.ai-response strong[b-1gouazet2w] {
    color: #1a202c;
    font-weight: 700;
}

.ai-response li[b-1gouazet2w] {
    margin-bottom: 8px;
    padding-left: 4px;
}

.ai-response p[b-1gouazet2w] {
    margin-bottom: 12px;
}

/* Loading State in Modal */
.text-center[b-1gouazet2w] {
    text-align: center;
}

.text-center .spinner-border[b-1gouazet2w] {
    width: 3rem;
    height: 3rem;
    border-width: 0.3em;
    color: #667eea;
    margin-bottom: 16px;
}

.text-center p[b-1gouazet2w] {
    color: #6b7280;
    font-size: 16px;
    margin-top: 12px;
}

/* Alert in Modal */
.alert[b-1gouazet2w] {
    padding: 16px;
    border-radius: 8px;
    margin-bottom: 16px;
}

.alert-danger[b-1gouazet2w] {
    background: #fee2e2;
    color: #dc2626;
    border: 1px solid #fca5a5;
}

.alert-success[b-1gouazet2w] {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #86efac;
}

/* Responsive Modal */
@media (max-width: 768px) {
    .modal-content[b-1gouazet2w] {
        width: 95%;
        max-height: 90vh;
        border-radius: 12px;
    }

    .modal-content.modal-large[b-1gouazet2w] {
        max-width: 95%;
    }

    .modal-content h3[b-1gouazet2w] {
        font-size: 18px;
        padding: 20px;
    }

    .modal-body[b-1gouazet2w] {
        padding: 20px;
    }

    .modal-footer[b-1gouazet2w] {
        padding: 16px 20px;
        flex-direction: column;
    }

    .modal-footer .btn[b-1gouazet2w] {
        width: 100%;
    }

    .ai-risk-score[b-1gouazet2w] {
        font-size: 14px;
        padding: 10px 18px;
    }

    .ai-risk-score .score[b-1gouazet2w] {
        font-size: 20px;
    }
}

/* /Views/AIAssistantView.razor.rz.scp.css */
.ai-assistant-container[b-qwvwwb936p] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    padding: 20px;
}

.ai-assistant-card[b-qwvwwb936p] {
    background: white;
    border-radius: 20px;
    box-shadow: 0 25px 70px rgba(0, 0, 0, 0.3);
    max-width: 1200px;
    width: 100%;
    height: 85vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    animation: slideIn-b-qwvwwb936p 0.3s ease-out;
}

@keyframes slideIn-b-qwvwwb936p {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ai-assistant-header[b-qwvwwb936p] {
    text-align: center;
    padding: 35px 30px 25px;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
    border-bottom: 1px solid #e2e8f0;
}

.ai-assistant-icon[b-qwvwwb936p] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 90px;
    height: 90px;
    background: white;
    border-radius: 50%;
    margin-bottom: 20px;
    color: #667eea;
    box-shadow: 0 12px 30px rgba(102, 126, 234, 0.25);
    position: relative;
    animation: pulse-b-qwvwwb936p 2s infinite;
}

@keyframes pulse-b-qwvwwb936p {
    0% {
        box-shadow: 0 12px 30px rgba(102, 126, 234, 0.25);
    }

    50% {
        box-shadow: 0 12px 40px rgba(102, 126, 234, 0.35);
    }

    100% {
        box-shadow: 0 12px 30px rgba(102, 126, 234, 0.25);
    }
}

.ai-assistant-title[b-qwvwwb936p] {
    margin: 0 0 10px;
    color: #2d3748;
    font-size: 28px;
    font-weight: 700;
    letter-spacing: -0.5px;
}

.ai-assistant-subtitle[b-qwvwwb936p] {
    margin: 0;
    color: #718096;
    font-size: 15px;
    line-height: 1.5;
}

.ai-assistant-badges[b-qwvwwb936p] {
    display: flex;
    justify-content: center;
    gap: 12px;
    padding: 20px;
    background: #f7fafc;
    border-bottom: 1px solid #e2e8f0;
}

.ai-badge[b-qwvwwb936p] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    font-size: 13px;
    color: #4a5568;
    font-weight: 500;
    transition: all 0.2s ease;
}

.ai-badge:hover[b-qwvwwb936p] {
    border-color: #667eea;
    color: #667eea;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}

.ai-assistant-body[b-qwvwwb936p] {
    flex: 1;
    overflow: hidden;
    padding: 0;
}

.ai-chat-component[b-qwvwwb936p] {
    height: 100% !important;
    border: none !important;
    background: #fafbfc !important;
}

/* Stili per le aree interne del componente DxAIChat */
.ai-chat-component[b-qwvwwb936p]  .dx-empty-message-area {
    padding: 30px !important;
    background: #fafbfc !important;
}

.ai-chat-component[b-qwvwwb936p]  .dx-message-area {
    background: #fafbfc !important;
    padding: 20px !important;
}

.ai-chat-component[b-qwvwwb936p]  .dx-send-area {
    border-top: 1px solid #e2e8f0 !important;
    background: white !important;
    padding: 20px !important;
}

.chat-welcome[b-qwvwwb936p] {
    max-width: 900px;
    margin: 0 auto;
    padding: 20px;
    animation: fadeIn-b-qwvwwb936p 0.5s ease-out;
}

@keyframes fadeIn-b-qwvwwb936p {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.welcome-grid[b-qwvwwb936p] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 40px;
}

.welcome-card[b-qwvwwb936p] {
    background: white;
    padding: 25px;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    text-align: center;
    transition: all 0.3s ease;
}

.welcome-card:hover[b-qwvwwb936p] {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    border-color: #667eea;
}

.welcome-icon[b-qwvwwb936p] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    border-radius: 12px;
    margin-bottom: 15px;
}

.welcome-card h5[b-qwvwwb936p] {
    margin: 0 0 10px;
    color: #2d3748;
    font-size: 16px;
    font-weight: 600;
}

.welcome-card p[b-qwvwwb936p] {
    margin: 0;
    color: #718096;
    font-size: 13px;
    line-height: 1.5;
}

.welcome-suggestions[b-qwvwwb936p] {
    background: white;
    padding: 25px;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
}

.suggestions-title[b-qwvwwb936p] {
    margin: 0 0 15px;
    color: #4a5568;
    font-size: 14px;
    font-weight: 500;
}

.suggestion-chips[b-qwvwwb936p] {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.suggestion-chip[b-qwvwwb936p] {
    padding: 10px 18px;
    background: linear-gradient(135deg, #f7fafc 0%, #edf2f7 100%);
    border: 1px solid #cbd5e0;
    border-radius: 20px;
    color: #4a5568;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-weight: 500;
}

.suggestion-chip:hover[b-qwvwwb936p] {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    border-color: transparent;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(102, 126, 234, 0.3);
}

.ai-assistant-footer[b-qwvwwb936p] {
    padding: 18px 30px;
    background: #f7fafc;
    border-top: 1px solid #e2e8f0;
    text-align: center;
}

.footer-text[b-qwvwwb936p] {
    margin: 0;
    font-size: 13px;
    color: #718096;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

@media (max-width: 768px) {
    .ai-assistant-card[b-qwvwwb936p] {
        border-radius: 0;
        height: 100vh;
        max-width: 100%;
    }

    .ai-assistant-container[b-qwvwwb936p] {
        padding: 0;
    }

    .welcome-grid[b-qwvwwb936p] {
        grid-template-columns: 1fr;
    }

    .suggestion-chips[b-qwvwwb936p] {
        flex-direction: column;
    }

    .suggestion-chip[b-qwvwwb936p] {
        width: 100%;
        text-align: center;
    }
}
/* /Views/ConversationsListView.razor.rz.scp.css */
/* Nuovo wrapper con gradiente - stile AIAnalysisPage */
.chat-fullpage-container[b-gcmbynxv2a] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    padding: 20px;
}

.chat-fullpage-card[b-gcmbynxv2a] {
    background: white;
    border-radius: 20px;
    box-shadow: 0 25px 70px rgba(0, 0, 0, 0.3);
    max-width: 1400px;
    width: 100%;
    height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    animation: slideIn-b-gcmbynxv2a 0.3s ease-out;
}

@keyframes slideIn-b-gcmbynxv2a {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Container originale - ora dentro la card */
.chat-container[b-gcmbynxv2a] {
    display: flex;
    height: 100%;
    background: transparent;
}

.chat-sidebar[b-gcmbynxv2a] {
    width: 350px;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
    border-right: 1px solid #e2e8f0;
    display: flex;
    flex-direction: column;
    border-radius: 20px 0 0 20px;
}

.sidebar-header[b-gcmbynxv2a] {
    padding: 25px 20px;
    border-bottom: 1px solid #e2e8f0;
}

.header-content[b-gcmbynxv2a] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 15px;
}

/* NUOVO: Stile per il tasto Back nella sidebar */
.btn-back-sidebar[b-gcmbynxv2a] {
    background: white;
    color: #4a5568;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    width: 36px;
    height: 36px;
    flex-shrink: 0;
}

.btn-back-sidebar:hover[b-gcmbynxv2a] {
    background: #667eea;
    color: white;
    border-color: #667eea;
    transform: translateX(-2px);
}

.sidebar-title[b-gcmbynxv2a] {
    margin: 0;
    font-size: 20px; /* Ridotto leggermente per far spazio al tasto */
    color: #2d3748;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
}

.new-chat-btn[b-gcmbynxv2a] {
    background: #667eea;
    color: white;
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
}

    .new-chat-btn:hover[b-gcmbynxv2a] {
        background: #5a67d8;
        transform: scale(1.05);
        box-shadow: 0 6px 16px rgba(102, 126, 234, 0.4);
    }

.search-container[b-gcmbynxv2a] {
    padding: 15px;
    border-bottom: 1px solid #e2e8f0;
    background: rgba(255, 255, 255, 0.5);
}

.search-box[b-gcmbynxv2a] {
    width: 100%;
}

.conversations-list[b-gcmbynxv2a] {
    flex: 1;
    overflow-y: auto;
    background: white;
}

.conversation-item[b-gcmbynxv2a] {
    display: flex;
    padding: 15px 20px;
    cursor: pointer;
    transition: all 0.2s;
    border-bottom: 1px solid #f0f2f5;
    position: relative;
    border-left: 4px solid transparent; /* Bordo trasparente per coerenza */
}

    .conversation-item:hover[b-gcmbynxv2a] {
        background: #f8f9fa;
    }

    .conversation-item.active[b-gcmbynxv2a] {
        background-color: #eef2ff; /* Sfondo pi� deciso per l'elemento attivo */
        border-left-color: #667eea;
        animation: pulse-b-gcmbynxv2a 1.5s infinite;
    }

@keyframes pulse-b-gcmbynxv2a {
    0% {
        box-shadow: 0 0 0 0 rgba(102, 126, 234, 0.4);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(102, 126, 234, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(102, 126, 234, 0);
    }
}

.conversation-avatar[b-gcmbynxv2a] {
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    margin-right: 15px;
    flex-shrink: 0;
    box-shadow: 0 4px 10px rgba(102, 126, 234, 0.25);
}

.conversation-info[b-gcmbynxv2a] {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.conversation-header[b-gcmbynxv2a] {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
}

.conversation-name[b-gcmbynxv2a] {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #2d3748;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-grow: 1;
}

.conversation-time[b-gcmbynxv2a] {
    font-size: 12px;
    color: #718096;
    flex-shrink: 0;
}

.conversation-footer[b-gcmbynxv2a] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 4px;
}

.conversation-preview[b-gcmbynxv2a] {
    margin: 0;
    font-size: 14px;
    color: #718096;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-grow: 1;
}

.unread-badge[b-gcmbynxv2a] {
    background: #667eea;
    color: white;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 600;
    box-shadow: 0 2px 6px rgba(102, 126, 234, 0.3);
    flex-shrink: 0;
}

.chat-main[b-gcmbynxv2a] {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #fafbfc;
    border-radius: 0 20px 20px 0;
    overflow: hidden;
    height: 100%; /* AGGIUNTO */
}

.no-selection[b-gcmbynxv2a] {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fafbfc;
}

.no-selection-content[b-gcmbynxv2a] {
    text-align: center;
    color: #718096;
}

    .no-selection-content svg[b-gcmbynxv2a] {
        color: #c1c7cd;
        margin-bottom: 20px;
    }

    .no-selection-content h3[b-gcmbynxv2a] {
        margin: 0 0 10px;
        font-size: 24px;
        font-weight: 700;
        color: #2d3748;
    }

    .no-selection-content p[b-gcmbynxv2a] {
        margin: 0;
        font-size: 16px;
        color: #718096;
    }

.empty-state[b-gcmbynxv2a] {
    text-align: center;
    padding: 60px 20px;
    color: #718096;
}

    .empty-state svg[b-gcmbynxv2a] {
        color: #c1c7cd;
        margin-bottom: 20px;
    }

    .empty-state p[b-gcmbynxv2a] {
        margin: 5px 0;
    }

.loading-spinner[b-gcmbynxv2a] {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 40px;
}

/* Dialog styles */
.new-chat-dialog[b-gcmbynxv2a] {
    padding: 20px;
}

.chat-type-selector[b-gcmbynxv2a] {
    margin-bottom: 20px;
}

    .chat-type-selector label[b-gcmbynxv2a] {
        display: block;
        font-weight: 600;
        margin-bottom: 10px;
        color: #2d3748;
    }

.radio-group[b-gcmbynxv2a] {
    display: flex;
    gap: 20px;
}

.radio-option[b-gcmbynxv2a] {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-weight: normal;
    color: #4a5568;
}

    .radio-option input[type="radio"][b-gcmbynxv2a] {
        margin-right: 8px;
        cursor: pointer;
    }

.form-group[b-gcmbynxv2a] {
    margin-bottom: 20px;
}

    .form-group label[b-gcmbynxv2a] {
        display: block;
        font-weight: 600;
        margin-bottom: 8px;
        color: #2d3748;
    }

.popup-footer[b-gcmbynxv2a] {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 15px;
}

@media (max-width: 768px) {
    .chat-fullpage-container[b-gcmbynxv2a] {
        padding: 0;
    }

    .chat-fullpage-card[b-gcmbynxv2a] {
        border-radius: 0;
        height: 100vh;
        max-width: 100%;
    }

    .chat-sidebar[b-gcmbynxv2a] {
        width: 100%;
        border-radius: 0;
    }

    .chat-main[b-gcmbynxv2a] {
        display: none;
        border-radius: 0;
    }
}
/* /Views/ConversationView.razor.rz.scp.css */
.conversation-wrapper[b-dxqsmfjk1l] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    padding: 20px;
}

.conversation-container[b-dxqsmfjk1l] {
    /* MODIFICATO: Usa height invece di max-height */
    display: flex;
    flex-direction: column;
    height: 100%; /* Occupa tutta l'altezza disponibile */
    width: 100%;
    background: white;
    overflow: hidden;
    border-radius: 20px;
    box-shadow: 0 25px 70px rgba(0, 0, 0, 0.3);
    animation: slideIn-b-dxqsmfjk1l 0.3s ease-out;
}

@keyframes slideIn-b-dxqsmfjk1l {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.conversation-header[b-dxqsmfjk1l] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
    border-bottom: 1px solid #e2e8f0;
    border-radius: 20px 20px 0 0;
}

.header-left[b-dxqsmfjk1l] {
    display: flex;
    align-items: center;
    gap: 15px;
}

.header-avatar[b-dxqsmfjk1l] {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}

.header-info[b-dxqsmfjk1l] {
    display: flex;
    flex-direction: column;
}

.conversation-title[b-dxqsmfjk1l] {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #050505;
}

.typing-indicator[b-dxqsmfjk1l] {
    font-size: 14px;
    color: #667eea;
    font-style: italic;
}

.participants-count[b-dxqsmfjk1l] {
    font-size: 14px;
    color: #65676b;
}

.header-actions[b-dxqsmfjk1l] {
    display: flex;
    gap: 10px;
}

.action-button[b-dxqsmfjk1l] {
    background: none;
    border: none;
    color: #65676b;
    cursor: pointer;
    padding: 8px;
    border-radius: 50%;
    transition: background 0.2s;
}

    .action-button:hover[b-dxqsmfjk1l] {
        background: #f0f2f5;
    }

.messages-container[b-dxqsmfjk1l] {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    background: #fafbfc;
    display: flex;
    flex-direction: column;
    gap: 10px;
    /* RIMOSSO: height fixed */
}

.loading-messages[b-dxqsmfjk1l], .no-messages[b-dxqsmfjk1l] {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #65676b;
}

    .no-messages svg[b-dxqsmfjk1l] {
        color: #c1c7cd;
        margin-bottom: 20px;
    }

.date-separator[b-dxqsmfjk1l] {
    text-align: center;
    margin: 20px 0;
    position: relative;
}

    .date-separator span[b-dxqsmfjk1l] {
        background: #f0f2f5;
        padding: 0 15px;
        color: #65676b;
        font-size: 13px;
        position: relative;
        z-index: 1;
    }

    .date-separator[b-dxqsmfjk1l]::before {
        content: '';
        position: absolute;
        top: 50%;
        left: 0;
        right: 0;
        height: 1px;
        background: #e4e6eb;
    }

.message-wrapper[b-dxqsmfjk1l] {
    display: flex;
    margin-bottom: 5px;
}

    .message-wrapper.sent[b-dxqsmfjk1l] {
        justify-content: flex-end;
    }

    .message-wrapper.received[b-dxqsmfjk1l] {
        justify-content: flex-start;
    }

.message[b-dxqsmfjk1l] {
    max-width: 70%;
    word-wrap: break-word;
}

.message-sender[b-dxqsmfjk1l] {
    font-size: 13px;
    color: #667eea;
    margin-bottom: 3px;
    font-weight: 600;
}

.message-content[b-dxqsmfjk1l] {
    padding: 10px 15px;
    border-radius: 18px;
    font-size: 15px;
    line-height: 1.4;
}

.sent .message-content[b-dxqsmfjk1l] {
    background: #667eea;
    color: white;
}

.received .message-content[b-dxqsmfjk1l] {
    background: white;
    color: #050505;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.edited-label[b-dxqsmfjk1l] {
    font-size: 12px;
    opacity: 0.7;
    font-style: italic;
}

.message-time[b-dxqsmfjk1l] {
    font-size: 12px;
    color: #65676b;
    margin-top: 3px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.sent .message-time[b-dxqsmfjk1l] {
    text-align: right;
    justify-content: flex-end;
}

.input-container[b-dxqsmfjk1l] {
    padding: 15px;
    border-top: 1px solid #e2e8f0;
    background: white;
    border-radius: 0 0 20px 20px;
}

.input-wrapper[b-dxqsmfjk1l] {
    display: flex;
    align-items: flex-end;
    gap: 10px;
}

.message-input[b-dxqsmfjk1l] {
    flex: 1;
    min-height: 40px;
    max-height: 120px;
    resize: none;
    border: 1px solid #e4e6eb;
    border-radius: 20px;
    padding: 10px 15px;
}

.send-button[b-dxqsmfjk1l] {
    background: #667eea;
    color: white;
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
}

    .send-button:hover:not(:disabled)[b-dxqsmfjk1l] {
        background: #5a67d8;
        transform: scale(1.05);
    }

    .send-button:disabled[b-dxqsmfjk1l] {
        opacity: 0.5;
        cursor: not-allowed;
    }

@media (max-width: 768px) {
    .conversation-wrapper[b-dxqsmfjk1l] {
        padding: 0;
    }

    .conversation-container[b-dxqsmfjk1l] {
        border-radius: 0;
        height: 100vh;
        max-width: 100%;
    }

    .conversation-header[b-dxqsmfjk1l] {
        border-radius: 0;
    }

    .input-container[b-dxqsmfjk1l] {
        border-radius: 0;
    }

    .message[b-dxqsmfjk1l] {
        max-width: 85%;
    }
}
/* /Views/HTDeviceMapView.razor.rz.scp.css */
/* === LAYOUT === */
.device-map-layout[b-4foe73g9mg]{display:flex;flex-direction:row;width:100%;height:100%;background:var(--dx-content-bg-color);overflow:hidden;gap:16px;padding:16px}
.left-sidebar[b-4foe73g9mg],.right-sidebar[b-4foe73g9mg]{overflow-y:auto;background:var(--dxbl-surface-bg, var(--dx-bg-color));padding:20px;box-shadow:0 4px 12px var(--dxbl-shadow-color, rgba(0,0,0,.12));z-index:1000;border-radius:16px;border:1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6))}
.left-sidebar[b-4foe73g9mg]{flex:0 0 325px}
.left-sidebar h5[b-4foe73g9mg]{margin:0 0 12px 0;font-size:1rem;color:var(--dx-text-color);font-weight:600}
.left-sidebar h5.mt-4[b-4foe73g9mg]{margin-top:1.5rem !important}
.right-sidebar[b-4foe73g9mg]{flex:0 0 350px;display:flex;flex-direction:column;max-height:100%}
.map-center[b-4foe73g9mg]{flex:1;position:relative;background:var(--dxbl-surface-bg, var(--dx-bg-color));overflow:hidden;min-width:0;border-radius:16px;box-shadow:0 4px 12px var(--dxbl-shadow-color, rgba(0,0,0,.12));border:1px solid var(--dxbl-border-color, var(--bs-border-color, #dee2e6))}
.map-center > div[b-4foe73g9mg]{border-radius:16px;overflow:hidden}

/* === INFO SECTION === */
.info-section[b-4foe73g9mg]{padding:12px;background:transparent;border-radius:8px;border:1px solid var(--dxbl-border-color, #e9ecef);margin-bottom:12px}
.info-section p[b-4foe73g9mg]{margin:8px 0;font-size:14px;color:var(--dx-text-color)}
.info-section p strong[b-4foe73g9mg]{color:var(--dx-text-color);font-weight:600}

/* === ICON BUTTONS === */
.icon-buttons-grid[b-4foe73g9mg]{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:10px;margin-top:12px}
.icon-button[b-4foe73g9mg]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 5px;border:none;border-radius:12px;background:#f0f4f8;cursor:pointer;transition:.3s;min-height:85px;position:relative;overflow:hidden}
.icon-button:hover[b-4foe73g9mg]{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}
.icon-button:active[b-4foe73g9mg]{transform:translateY(0);box-shadow:0 2px 4px rgba(0,0,0,.1)}
.icon-button__icon[b-4foe73g9mg]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.icon-button__icon svg[b-4foe73g9mg]{width:100%;height:100%}
.icon-button__text[b-4foe73g9mg]{font-size:10px;line-height:1.2;text-align:center;font-weight:500;color:#495057;letter-spacing:-.02em}
.icon-button--info[b-4foe73g9mg]{background:#e7f3ff}
.icon-button--info:hover[b-4foe73g9mg]{background:#d0e7ff}
.icon-button--info .icon-button__icon[b-4foe73g9mg]{color:#0066cc}
.icon-button--info .icon-button__text[b-4foe73g9mg]{color:#004080}
.icon-button--danger[b-4foe73g9mg]{background:#ffe4e4}
.icon-button--danger:hover[b-4foe73g9mg]{background:#ffcccc}
.icon-button--danger .icon-button__icon[b-4foe73g9mg]{color:#dc3545}
.icon-button--danger .icon-button__text[b-4foe73g9mg]{color:#a71e2a}
.icon-button--success[b-4foe73g9mg]{background:#d4f4dd}
.icon-button--success:hover[b-4foe73g9mg]{background:#b8ecc8}
.icon-button--success .icon-button__icon[b-4foe73g9mg]{color:#28a745}
.icon-button--success .icon-button__text[b-4foe73g9mg]{color:#186429}
.icon-button--ai[b-4foe73g9mg]{background:#e6f0ff}
.icon-button--ai:hover[b-4foe73g9mg]{background:#cce0ff}
.icon-button--ai .icon-button__icon[b-4foe73g9mg]{color:#2c6cf6}
.icon-button--ai .icon-button__text[b-4foe73g9mg]{color:#1a4099}
.icon-button[b-4foe73g9mg]::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.5);transform:translate(-50%,-50%);transition:width .6s,height .6s}
.icon-button:active[b-4foe73g9mg]::after{width:100px;height:100px}

@media (max-width:480px){.icon-buttons-grid[b-4foe73g9mg]{grid-template-columns:repeat(2,1fr)}}

/* === ALERT INFO === */
.warning-section[b-4foe73g9mg]{padding:10px;background:var(--dxbl-surface-alt-bg, #f8f9fa);border-radius:6px}
.alert-info[b-4foe73g9mg]{padding:12px;background:var(--dxbl-surface-bg, #fff);border:1px solid var(--dxbl-border-color, #e0e0e0);border-radius:6px;margin-top:8px;position:relative}

/* === ALERT BACKGROUND COLORS BY RISK LEVEL === */
.alert-info.alert-bg-green[b-4foe73g9mg] {
    background: linear-gradient(135deg, #e3f2e3 0%, #d4ead4 100%);
    border: 2px solid #228b22;
    box-shadow: 0 2px 8px rgba(34, 139, 34, 0.15);
}

.alert-info.alert-bg-lime[b-4foe73g9mg] {
    background: linear-gradient(135deg, #e6ffe6 0%, #d4f0d4 100%);
    border: 2px solid #00c800;
    box-shadow: 0 2px 8px rgba(0, 200, 0, 0.15);
}

.alert-info.alert-bg-orange[b-4foe73g9mg] {
    background: linear-gradient(135deg, #fff1dc 0%, #ffe5c7 100%);
    border: 2px solid #ffa500;
    box-shadow: 0 2px 8px rgba(255, 165, 0, 0.2);
}

.alert-info.alert-bg-red[b-4foe73g9mg] {
    background: linear-gradient(135deg, #ffb3b3 0%, #ff8080 100%);
    border: 2px solid #b30000;
    box-shadow: 0 2px 10px rgba(179, 0, 0, 0.4);
    animation: alert-red-pulse-b-4foe73g9mg 2s ease-in-out infinite;
}

@keyframes alert-red-pulse-b-4foe73g9mg {
    0%, 100% {
        box-shadow: 0 2px 10px rgba(179, 0, 0, 0.4);
        transform: scale(1);
    }
    50% {
        box-shadow: 0 4px 20px rgba(179, 0, 0, 0.6);
        transform: scale(1.01);
    }
}

.alert-close-btn[b-4foe73g9mg]{position:absolute;top:8px;right:8px;background:transparent;border:none;font-size:1.2rem;line-height:1;color:var(--dx-text-color-secondary, #6c757d);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:.2s}
.alert-close-btn:hover[b-4foe73g9mg]{background:var(--dxbl-hover-bg, rgba(0,0,0,.1));color:var(--dx-text-color)}
.alert-close-btn:active[b-4foe73g9mg]{transform:scale(.95)}
.alert-details[b-4foe73g9mg]{background:var(--dxbl-surface-alt-bg, #f8f9fa);padding:6px 8px;border-radius:4px;margin-top:4px}
.alert-details small[b-4foe73g9mg]{font-size:.8rem;color:var(--dx-text-color-secondary, #495057)}
.alert-actions[b-4foe73g9mg]{border-top:1px solid var(--dxbl-border-color, #e9ecef);padding-top:12px}

/* === TRAFFIC SECTION === */
.traffic-section[b-4foe73g9mg]{margin-top:10px}
.traffic-section canvas[b-4foe73g9mg]{width:100% !important;max-width:100%;height:60px;display:block;margin:6px 0;box-sizing:border-box}
.traffic-last[b-4foe73g9mg]{display:grid;grid-template-columns:1fr 1fr;column-gap:6px;margin-bottom:6px;align-items:stretch;width:100%}
.traffic-summary[b-4foe73g9mg]{display:grid;grid-template-columns:1fr 1fr;column-gap:6px;margin-top:6px;align-items:stretch;width:100%}
.pill[b-4foe73g9mg]{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:10px;font-size:.75rem;font-weight:600;line-height:1;min-width:0;width:100%}
.pill strong[b-4foe73g9mg]{margin-left:auto;white-space:nowrap}
.pill-out[b-4foe73g9mg]{background:#f8d7eb;color:#d63384}
.pill-in[b-4foe73g9mg]{background:#dbeafe;color:#0d6efd}
.pill-total[b-4foe73g9mg]{display:flex;align-items:center;gap:6px}
.badge-total[b-4foe73g9mg]{flex:0 0 16px;width:16px;height:16px;border-radius:8px;background:rgba(0,0,0,.08);color:#6c757d;display:inline-flex;align-items:center;justify-content:center;font-weight:700}
.badge-total[b-4foe73g9mg]::before{content:"?";font-size:.65rem;line-height:1}
.traffic-label[b-4foe73g9mg]{font-size:.65rem;opacity:.8}

/* === TOGGLE BUTTONS === */
.traffic-toggle[b-4foe73g9mg]{display:flex;gap:4px;background:var(--dxbl-surface-alt-bg, #f0f2f5);padding:2px;border-radius:6px;align-self:flex-start;margin-top:12px}
.toggle-btn[b-4foe73g9mg]{padding:6px 14px;border:none;background:transparent;color:var(--dx-text-color-secondary, #6c757d);font-size:.75rem;font-weight:500;border-radius:4px;cursor:pointer;transition:.2s;white-space:nowrap}
.toggle-btn.active[b-4foe73g9mg]{background:var(--dxbl-surface-bg, #fff);color:var(--dx-link-color);box-shadow:0 1px 3px var(--dxbl-shadow-color, rgba(0,0,0,.1));font-weight:600}
.toggle-btn:hover:not(.active)[b-4foe73g9mg]{background:var(--dxbl-hover-bg, rgba(255,255,255,.5))}

/* === COLLAPSE BUTTON === */
.collapse-toggle-btn[b-4foe73g9mg]{background:rgba(0,123,255,0.1);border:2px solid var(--dx-link-color);color:var(--dx-link-color);cursor:pointer;padding:6px 10px;border-radius:8px;transition:all 0.3s ease;font-size:1.1rem;display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px;flex-shrink:0}
.collapse-toggle-btn:hover[b-4foe73g9mg]{background:var(--dx-link-color);color:white;border-color:var(--dx-link-color);transform:scale(1.1);box-shadow:0 4px 12px rgba(0,123,255,0.3)}
.collapse-toggle-btn:active[b-4foe73g9mg]{transform:scale(0.95)}
.collapse-toggle-btn span[b-4foe73g9mg]{font-size:1.2rem;font-weight:bold;line-height:1}

/* === ALERT COUNTERS (Right Sidebar) === */
.alert-counters-section[b-4foe73g9mg]{padding:16px;background:transparent;border-radius:8px;border:1px solid var(--dxbl-border-color, #e9ecef);margin-bottom:12px}
.alert-counters-section .section-title[b-4foe73g9mg]{margin:0 0 12px 0;font-size:1rem;color:var(--dx-text-color);font-weight:600}
.alert-counters-column[b-4foe73g9mg]{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.alert-counter[b-4foe73g9mg]{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;transition:all 0.2s ease;border:1px solid transparent;min-height:44px;cursor:pointer}
.alert-counter:hover[b-4foe73g9mg]{transform:translateX(2px);box-shadow:0 2px 6px rgba(0,0,0,0.1)}
.counter-icon[b-4foe73g9mg]{font-size:1.3rem;flex-shrink:0}
.counter-content[b-4foe73g9mg]{display:flex;align-items:center;gap:8px;flex:1}
.counter-value[b-4foe73g9mg]{font-size:1.1rem;font-weight:700;line-height:1;min-width:32px}
.counter-label[b-4foe73g9mg]{font-size:0.75rem;text-transform:uppercase;font-weight:600;letter-spacing:0.5px;opacity:0.85}

/* Info Counter - Colori fissi blu */
.info-counter[b-4foe73g9mg]{background:linear-gradient(90deg,#e7f3ff 0%,#d0e7ff 100%);border-color:#b3d9ff}
.info-counter .counter-value[b-4foe73g9mg]{color:#004080}
.info-counter .counter-label[b-4foe73g9mg]{color:#0066cc}

/* Warning Counter - Colori fissi arancione */
.warning-counter[b-4foe73g9mg]{background:linear-gradient(90deg,#fff3e0 0%,#ffe0b2 100%);border-color:#ffb74d}
.warning-counter .counter-value[b-4foe73g9mg]{color:#e65100}
.warning-counter .counter-label[b-4foe73g9mg]{color:#f57c00}

/* Danger Counter - Colori fissi rosso */
.danger-counter[b-4foe73g9mg]{background:linear-gradient(90deg,#ffe4e4 0%,#ffcccc 100%);border-color:#ffb3b3}
.danger-counter .counter-value[b-4foe73g9mg]{color:#a71e2a}
.danger-counter .counter-label[b-4foe73g9mg]{color:#dc3545}

@keyframes alert-pulse-b-4foe73g9mg{0%{box-shadow:0 0 0 0 rgba(220,53,69,0.7);transform:scale(1)}50%{box-shadow:0 0 0 10px rgba(220,53,69,0);transform:scale(1.02)}100%{box-shadow:0 0 0 0 rgba(220,53,69,0);transform:scale(1)}}
.pulse-alert[b-4foe73g9mg]{animation:alert-pulse-b-4foe73g9mg 1s ease-in-out 3}
.pulse-alert .alert-counter[b-4foe73g9mg]{transition:transform 0.3s ease,box-shadow 0.3s ease}

/* === RULES COMPACT (Left Sidebar Bottom) === */
.rules-compact[b-4foe73g9mg]{display:flex;flex-direction:column;gap:8px}
.rule-compact-item[b-4foe73g9mg]{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--dxbl-surface-alt-bg, linear-gradient(90deg,#f8f9fa 0%,#e9ecef 100%));border-radius:6px;cursor:pointer;transition:all 0.2s ease;border:1px solid var(--dxbl-border-color, #dee2e6)}
.rule-compact-item:hover[b-4foe73g9mg]{background:var(--dxbl-hover-bg, linear-gradient(90deg,#e9ecef 0%,#dee2e6 100%));border-color:var(--dx-link-color);transform:translateX(2px);box-shadow:0 2px 6px var(--dxbl-shadow-color, rgba(0,0,0,0.1))}
.rule-compact-item .rule-icon[b-4foe73g9mg]{font-size:1.2rem;flex-shrink:0}
.rule-compact-item .rule-label[b-4foe73g9mg]{flex:1;font-size:0.85rem;font-weight:500;color:var(--dx-text-color-secondary, #495057)}
.rule-compact-item .rule-value[b-4foe73g9mg]{font-size:1rem;font-weight:700;color:var(--dx-link-color);min-width:32px;text-align:right}
.rule-compact-item:first-child[b-4foe73g9mg]{border-left:3px solid #28a745}
.rule-compact-item:first-child:hover[b-4foe73g9mg]{border-left-color:#1e7e34}
.rule-compact-item:last-child[b-4foe73g9mg]{border-left:3px solid #ffc107}
.rule-compact-item:last-child:hover[b-4foe73g9mg]{border-left-color:#e0a800}

/* === TOP COUNTRIES (Right Sidebar) === */
.sidebar-header[b-4foe73g9mg]{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;flex-shrink:0}
.sidebar-header h5[b-4foe73g9mg]{margin:0;font-size:1rem;color:var(--dx-text-color);font-weight:600}
.country-list[b-4foe73g9mg]{flex:1;overflow-y:auto;overflow-x:hidden;padding-right:5px;min-height:0}
.country-list.animated .country-item[b-4foe73g9mg]{opacity:0;animation:slideInRight-b-4foe73g9mg .3s ease forwards;cursor:pointer;padding:12px;margin-bottom:10px;background:var(--dxbl-surface-bg, var(--dx-component-bg));border-radius:8px;border:1px solid var(--dxbl-border-color, #e9ecef);transition:.2s;display:flex;flex-direction:column;gap:8px}
.country-item:hover[b-4foe73g9mg]{border-color:var(--dx-link-color);transform:translateX(-4px);box-shadow:0 2px 8px var(--dxbl-shadow-color, rgba(0,0,0,.1));background:var(--dxbl-hover-bg, #f8f9fa)}
.country-header[b-4foe73g9mg]{display:flex;align-items:center;gap:8px}
.country-name[b-4foe73g9mg]{flex:1;font-weight:500;font-size:.85rem;color:var(--dx-text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.country-flag-img[b-4foe73g9mg]{width:24px;height:18px;object-fit:contain;border-radius:2px;box-shadow:0 1px 3px rgba(0,0,0,.12);flex-shrink:0}
.traffic-bar-container[b-4foe73g9mg]{width:100%;height:6px;background:var(--dxbl-surface-alt-bg, #e9ecef);border-radius:3px;overflow:hidden;position:relative}
.traffic-bar[b-4foe73g9mg]{height:100%;border-radius:3px;position:relative;overflow:hidden;transition:width .5s cubic-bezier(.4,0,.2,1)}
.traffic-bar[b-4foe73g9mg]::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer-b-4foe73g9mg 2s infinite}
.traffic-bar.high-traffic[b-4foe73g9mg]{background:linear-gradient(90deg,#ff6b6b,#ff8787)}
.traffic-bar.medium-traffic[b-4foe73g9mg]{background:linear-gradient(90deg,#ffd93d,#ffed4e)}
.traffic-bar.low-traffic[b-4foe73g9mg]{background:linear-gradient(90deg,#6bcf7f,#8de4a6)}

@keyframes shimmer-b-4foe73g9mg{to{left:100%}}
@keyframes slideInRight-b-4foe73g9mg{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

.country-stats[b-4foe73g9mg]{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.traffic-amount[b-4foe73g9mg]{font-weight:600;color:var(--dx-link-color);font-size:.9rem}
.traffic-direction[b-4foe73g9mg]{display:flex;gap:8px}
.mini-stat[b-4foe73g9mg]{font-size:.65rem;padding:3px 8px;border-radius:4px;font-weight:500;display:inline-flex;align-items:center;gap:2px}
.mini-stat.out[b-4foe73g9mg]{background:rgba(214,51,132,.1);color:#d63384}
.mini-stat.in[b-4foe73g9mg]{background:rgba(13,110,253,.1);color:#0d6efd}
.risk-indicator[b-4foe73g9mg]{display:flex;gap:4px;align-items:center}
.risk-dot[b-4foe73g9mg]{width:8px;height:8px;background:#ff6b6b;border-radius:50%;box-shadow:0 0 4px rgba(255,107,107,.4);animation:riskPulse-b-4foe73g9mg 2s infinite}

@keyframes riskPulse-b-4foe73g9mg{0%,100%{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}

.empty-state[b-4foe73g9mg]{text-align:center;padding:60px 20px;color:var(--dx-text-color-secondary, #6c757d)}
.empty-icon[b-4foe73g9mg]{font-size:3rem;display:block;margin-bottom:16px;opacity:.3}
.show-more[b-4foe73g9mg]{padding:12px;border-top:1px solid var(--dxbl-border-color, #e9ecef);margin-top:auto;flex-shrink:0}
.show-more-btn[b-4foe73g9mg]{width:100%;padding:10px;border:2px dashed var(--dx-link-color);background:transparent;color:var(--dx-link-color);border-radius:6px;cursor:pointer;transition:.2s;font-size:.85rem;font-weight:500}
.show-more-btn:hover[b-4foe73g9mg]{background:var(--dx-link-color);color:#fff;border-style:solid;transform:translateY(-1px);box-shadow:0 2px 4px var(--dxbl-shadow-color, rgba(0,0,0,.1))}

/* === ACQUISITION STATUS === */
.acquisition-status-indicator[b-4foe73g9mg]{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;margin-bottom:16px;transition:.3s;animation:status-change-b-4foe73g9mg .5s ease-out}
.acquisition-status-indicator.inactive[b-4foe73g9mg]{background:var(--dxbl-surface-alt-bg, #f8f9fa);border:1px solid var(--dxbl-border-color, #dee2e6)}

@keyframes status-change-b-4foe73g9mg{0%{transform:translateX(-10px);opacity:0}100%{transform:translateX(0);opacity:1}}

.acquisition-status-indicator.active[b-4foe73g9mg]{position:relative;background:rgba(34,139,34,.05);border:1px solid rgba(34,139,34,.3);overflow:hidden}
.acquisition-progress-fill[b-4foe73g9mg]{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,rgba(34,139,34,.15) 0%,rgba(34,139,34,.2) 100%);transition:width .5s ease;z-index:1;pointer-events:none}
.acquisition-progress-fill[b-4foe73g9mg]::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.05) 10px,rgba(255,255,255,.05) 20px);animation:progress-stripes-b-4foe73g9mg 1s linear infinite}

@keyframes progress-stripes-b-4foe73g9mg{from{transform:translateX(0)}to{transform:translateX(20px)}}

.progress-percentage[b-4foe73g9mg]{color:#228b22;font-weight:600}
.status-content[b-4foe73g9mg]{position:relative;z-index:2;display:flex;align-items:center;gap:12px}
.status-icon-wrapper[b-4foe73g9mg]{position:relative;width:32px;height:32px;flex-shrink:0}
.status-icon[b-4foe73g9mg]{position:absolute;width:12px;height:12px;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);transition:.3s}
.active .status-icon[b-4foe73g9mg]{background:#228b22;box-shadow:0 0 10px rgba(34,139,34,.5)}
.inactive .status-icon[b-4foe73g9mg]{background:#6c757d}
.status-info[b-4foe73g9mg]{display:flex;flex-direction:column;gap:2px}
.status-info strong[b-4foe73g9mg]{font-size:.9rem;color:var(--dx-text-color)}
.active .status-info strong[b-4foe73g9mg]{color:#228b22}
.inactive .status-info strong[b-4foe73g9mg]{color:var(--dx-text-color-secondary, #6c757d)}
.status-info small[b-4foe73g9mg]{font-size:.75rem;color:var(--dx-text-color-secondary, #6c757d)}
.status-info .duration[b-4foe73g9mg]{color:var(--dx-text-color-secondary, #495057);font-weight:500}
.status-pulse[b-4foe73g9mg]{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid #228b22;opacity:0;top:0;left:0;animation:pulse-ring-b-4foe73g9mg 2s infinite}

@keyframes pulse-ring-b-4foe73g9mg{0%{transform:scale(.5);opacity:.8}100%{transform:scale(1.5);opacity:0}}

.acquisition-status-indicator.active[style*="width: 9"] .acquisition-progress-fill[b-4foe73g9mg],
.acquisition-status-indicator.active[style*="width: 10"] .acquisition-progress-fill[b-4foe73g9mg]{background:linear-gradient(90deg,rgba(255,165,0,.2) 0%,rgba(255,140,0,.25) 100%)}
.acquisition-status-indicator.active[style*="width: 9"][b-4foe73g9mg],
.acquisition-status-indicator.active[style*="width: 10"][b-4foe73g9mg]{border-color:rgba(255,165,0,.5)}
.acquisition-status-indicator.active[style*="width: 9"] .progress-percentage[b-4foe73g9mg],
.acquisition-status-indicator.active[style*="width: 10"] .progress-percentage[b-4foe73g9mg]{color:#ff8c00}

/* === AI RESPONSE === */
.ai-response-content[b-4foe73g9mg]{max-height:350px;overflow-y:auto;padding:15px;background:var(--dxbl-surface-alt-bg, #f8f9fa);border-radius:8px;border:1px solid var(--dxbl-border-color, #dee2e6)}
.ai-formatted-response[b-4foe73g9mg]{font-size:14px;line-height:1.6;color:var(--dx-text-color, #333)}
.ai-formatted-response h2[b-4foe73g9mg]{color:#0d6efd;font-size:18px;margin:15px 0 10px;border-bottom:2px solid #0d6efd;padding-bottom:5px}
.ai-formatted-response h3[b-4foe73g9mg]{color:var(--dx-text-color-secondary, #495057);font-size:16px;margin:12px 0 8px;font-weight:600}
.ai-formatted-response h4[b-4foe73g9mg]{color:var(--dx-text-color-secondary, #6c757d);font-size:14px;margin:10px 0 6px;font-weight:600}
.ai-formatted-response strong[b-4foe73g9mg]{color:var(--dx-text-color, #212529);font-weight:600}
.ai-formatted-response li[b-4foe73g9mg]{margin-left:20px;margin-bottom:5px}
.ai-formatted-response p[b-4foe73g9mg]{margin-bottom:10px}
.ai-response-content[b-4foe73g9mg]::-webkit-scrollbar{width:6px}
.ai-response-content[b-4foe73g9mg]::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}
.ai-response-content[b-4foe73g9mg]::-webkit-scrollbar-thumb{background:#888;border-radius:3px}
.ai-response-content[b-4foe73g9mg]::-webkit-scrollbar-thumb:hover{background:#555}

/* === MISC === */
.rule-name-link-btn[b-4foe73g9mg]{background:transparent;border:none;color:var(--dx-text-color-secondary, #495057);cursor:pointer;transition:.2s;font-size:.85rem;padding:4px 8px;border-radius:4px;line-height:1;display:inline-flex;align-items:center;gap:6px;flex:1;min-width:0;text-align:left;overflow:hidden}
.rule-name-link-btn:hover[b-4foe73g9mg]{background:rgba(255,165,0,.1);color:#ff8c00}
.rule-name-link-btn:hover .alert-icon[b-4foe73g9mg]{color:#ff8c00;transform:scale(1.1)}
.rule-name-link-btn:focus[b-4foe73g9mg]{outline:2px solid rgba(255,165,0,.3);outline-offset:1px}
.rule-name-link-btn:active[b-4foe73g9mg]{transform:scale(.98)}
.rule-name-link-btn .alert-icon[b-4foe73g9mg]{color:#ffa500;font-size:.9rem;flex-shrink:0}
.rule-name-link-btn .rule-name-text[b-4foe73g9mg]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
