* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --bg-primary: #12141a;
  --bg-secondary: #181b22;
  --bg-tertiary: #20242c;
  --bg-sidebar: #16191f;
  --bg-input: #1e2229;
  --bg-card: #181b22;
  --text-primary: #e4e7eb;
  --text-secondary: #a3adb8;
  --text-light: #7a8490;
  --text-inverse: #ffffff;
  --border-color: #262b33;
  --accent-color: #3984c6;
  --accent-hover: #4d93cf;
  --accent-light: rgba(57,132,198,0.15);
  --hover-color: #232830;
  --error-color: #ff5f5f;
  --success-color: #3aa864;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 2px 6px rgba(0,0,0,0.45);
  --shadow-lg: 0 4px 14px rgba(0,0,0,0.5);
}

body {
  font-family: -apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  min-height: 100vh;
  line-height: 1.5;
}

/* CIDR Section */
.cidrs-wrapper {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.cidrs-header h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 4px;
}

.cidrs-header .subtitle {
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin: 0;
}

.cidr-form {
  display: block;
}

.cidr-shared-source {
  margin-bottom: 18px;
}
.cidr-shared-source .cidr-hint {
  margin-top: 6px;
}

.cidr-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}

@media (max-width: 1100px) {
  .cidr-grid {
    grid-template-columns: 1fr;
  }
}

.label-main {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 10px;
}

.cidr-textarea {
  width: 100%;
  resize: vertical;
  min-height: 200px;
  background: var(--bg-input);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 14px 16px;
  font-family: monospace;
  font-size: 0.85rem;
  line-height: 1.4;
  outline: none;
  transition: border-color .2s, background-color .2s;
}
.cidr-textarea:focus { border-color: var(--accent-color); background: var(--bg-tertiary); }

.cidr-source-input {
  width: 100%;
  background: var(--bg-input);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 12px 14px;
  font-size: 0.85rem;
  outline: none;
  transition: border-color .2s, background-color .2s;
}
.cidr-source-input:focus { border-color: var(--accent-color); background: var(--bg-tertiary); }

.cidr-hint {
  margin-top: 8px;
  font-size: 0.7rem;
  color: var(--text-light);
}

.actions {
  display: flex;
  flex-direction: row;
  gap: 10px;
  margin-top: 18px;
}

.cidr-create-btn { width: 100%; }
.cidr-grid-right .actions { justify-content: flex-start; }
.cidr-grid-left .actions { justify-content: flex-start; }
.cidr-grid .actions .btn { width: auto; padding: 10px 16px; }

.cidr-error {
  margin-top: 10px;
  font-size: 0.75rem;
  color: var(--text-secondary);
  padding: 0;
  min-height: 0;
}
.cidr-error:empty { display: none; }

.cidr-success {
  margin-top: 6px;
  font-size: 0.75rem;
  color: var(--success-color);
  background: rgba(58,168,100,0.08);
  border: 1px solid rgba(58,168,100,0.4);
  border-radius: 6px;
  padding: 6px 10px;
  display: none;
}

.cidr-success.visible { display: block; }

.cidr-table-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cidr-table-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.cidr-count {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 4px 10px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color);
  border-radius: 4px;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
}

.cidr-table-container {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  overflow: hidden;
}

.cidr-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}

.cidr-table thead {
  background: var(--bg-tertiary);
}

.cidr-table th, .cidr-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border-color);
  vertical-align: top;
}

.cidr-table th {
  font-weight: 600;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
}

.cidr-table tbody tr:last-child td { border-bottom: none; }

.cidr-table tbody tr:hover {
  background: var(--hover-color);
}

/* WSNI Section */
.wsni-wrapper {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.wsni-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.wsni-count {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 6px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.wsni-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.wsni-textarea {
  width: 100%;
  resize: vertical;
  min-height: 220px;
  background: var(--bg-input);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 14px 16px;
  font-family: monospace;
  font-size: 0.9rem;
  line-height: 1.45;
  outline: none;
  transition: border-color .2s, background-color .2s;
}
.wsni-textarea:focus { border-color: var(--accent-color); background: var(--bg-tertiary); }

.wsni-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.wsni-status {
  font-size: 0.85rem;
  color: var(--text-secondary);
  min-height: 20px;
}
.wsni-status.success { color: var(--success-color); }
.wsni-status.error { color: var(--error-color); }

.wsni-table-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.wsni-table-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.wsni-table-container {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  overflow: hidden;
}

.wsni-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.wsni-table thead {
  background: var(--bg-tertiary);
}

.wsni-table th, .wsni-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border-color);
  vertical-align: top;
}

.wsni-table th {
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
}

.wsni-table tbody tr:last-child td { border-bottom: none; }
.wsni-table tbody tr:hover { background: var(--hover-color); }

.ip-sni-note { color: var(--text-secondary); font-size: 0.9rem; }

.wsni-empty {
  padding: 18px;
  text-align: center;
  color: var(--text-light);
  font-size: 0.9rem;
}

.cidr-table td:nth-child(1) {
  font-family: monospace;
  font-size: 0.74rem;
}

.cidr-table-empty {
  text-align: center;
  padding: 24px 10px;
  font-size: 0.75rem;
  color: var(--text-light);
}

.loading-inline {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-color);
  box-shadow: 12px 0 0 var(--accent-color), -12px 0 0 var(--accent-color);
  animation: bounceDots 0.8s infinite ease-in-out;
}

@keyframes bounceDots {
  0%, 80%, 100% { transform: scale(0); }
  40% { transform: scale(1); }
}

/* Login Page */
.login-page {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background: var(--bg-primary);
  position: relative;
}

.login-page::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(102, 126, 234, 0.1) 0%, transparent 70%);
  animation: float 20s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

@keyframes float {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  50% { transform: translate(-30px, -30px) rotate(180deg); }
}

.login-container {
  background: var(--bg-secondary);
  padding: 32px 28px;
  border-radius: 10px;
  box-shadow: var(--shadow-md);
  width: 100%;
  max-width: 380px;
  border: 1px solid var(--border-color);
  position: relative;
  z-index: 1;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.login-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--gradient-primary);
  border-radius: 16px 16px 0 0;
}

.login-container h1 {
  text-align: center;
  margin-bottom: 24px;
  font-weight: 600;
  font-size: 1.45rem;
  color: var(--text-primary);
}

.form-group {
  margin-bottom: 24px;
}

.form-group label {
  display: block;
  margin-bottom: 10px;
  font-weight: 500;
  color: var(--text-secondary);
  font-size: 0.9rem;
  letter-spacing: 0.01em;
}

.form-group input {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  font-size: 0.95rem;
  background-color: var(--bg-input);
  color: var(--text-primary);
  transition: border-color .2s, background-color .2s;
}

.form-group input:focus {
  outline: none;
  border-color: var(--accent-color);
  background-color: var(--bg-tertiary);
}

.form-group input::placeholder {
  color: var(--text-light);
}

.error-message {
  color: var(--text-secondary);
  font-size: 0.875rem;
  margin-bottom: 12px;
  min-height: 0;
  padding: 6px 0;
}
.error-message:empty { display: none; }

.btn {
  position: relative;
  padding: 12px 20px;
  border: none;
  border-radius: 6px;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background-color .2s, transform .1s, box-shadow .2s;
  font-weight: 500;
  overflow: hidden; /* ensure internal effects do not bleed */
}

/* Subtle hover highlight instead of giant circle */
.btn-primary:hover, .btn-secondary:hover {
  filter: brightness(1.08);
}

.btn-primary {
  width: 100%;
  background: var(--accent-color);
  color: var(--text-inverse);
}
.btn-primary:hover { background: var(--accent-hover); }

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-glow);
}

.btn-primary:active {
  transform: translateY(0);
}

.btn-secondary {
  width: 100%;
  background-color: var(--bg-tertiary);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
}
.btn-secondary:hover { background-color: var(--hover-color); }

.btn-secondary:hover {
  background-color: var(--hover-color);
  border-color: var(--accent-color);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

.btn-small {
  padding: 8px 14px;
  font-size: 0.8rem;
}

/* Admin Panel Layout */
.admin-panel {
  display: flex;
  min-height: 100vh;
  background: var(--bg-primary);
}

.sidebar {
  width: 240px;
  background: var(--bg-sidebar);
  color: var(--text-inverse);
  display: flex;
  flex-direction: column;
  position: fixed;
  height: 100vh;
  left: 0;
  top: 0;
  box-shadow: var(--shadow-sm);
  z-index: 100;
  border-right: 1px solid var(--border-color);
}

.sidebar-header {
  padding: 20px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.sidebar-header h2 {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0;
}

.sidebar-nav {
  flex: 1;
  padding: 20px 10px;
  overflow-y: auto;
}

.sidebar-nav::-webkit-scrollbar {
  width: 6px;
}

.sidebar-nav::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar-nav::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
}

.sidebar-nav::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.2);
}

.nav-item {
  display: flex;
  align-items: center;
  padding: 10px 16px;
  margin: 2px 0;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  transition: background-color .15s,color .15s;
  font-size: 0.9rem;
  font-weight: 500;
  border-radius: 6px;
  border-left: 3px solid transparent;
}
.nav-item:hover { background-color: rgba(255,255,255,0.06); color: var(--text-inverse); }
.nav-item.active { background-color: rgba(255,255,255,0.08); color: var(--text-inverse); border-left-color: var(--accent-color); }

.nav-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 0;
  background: var(--gradient-primary);
  border-radius: 0 4px 4px 0;
  transition: height 0.3s ease;
}

.nav-item:hover {
  background-color: rgba(255, 255, 255, 0.08);
  color: var(--text-inverse);
  transform: translateX(4px);
}

.nav-item:hover::before {
  height: 60%;
}

.nav-item.active {
  background: var(--accent-light);
  color: var(--text-inverse);
  box-shadow: var(--shadow-sm);
}

.nav-item.active::before {
  height: 80%;
  background: var(--gradient-accent);
}

.nav-icon {
  margin-right: 10px;
  font-size: 1.1rem;
}

.sidebar-footer {
  padding: 25px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

/* Main Content */
.main-content {
  flex: 1;
  margin-left: 240px;
  display: flex;
  flex-direction: column;
  background: var(--bg-primary);
}

.main-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  background: transparent;
  border-bottom: none;
  position: sticky;
  top: 0;
  z-index: 50;
}

.main-header h1 {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0;
}

.user-info {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-secondary);
  font-size: 0.8rem;
  font-weight: 500;
  padding: 6px 12px;
  background: var(--bg-tertiary);
  border-radius: 8px;
  border: 1px solid var(--border-color);
}

.user-info::before {
  content: '👤';
  font-size: 1.1rem;
}

.content-area {
  flex: 1;
  padding: 24px 28px;
  background: var(--bg-primary);
}

.content-section {
  display: none;
  animation: fadeIn 0.4s ease-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.content-section.active {
  display: block;
}

.content-section p {
  color: var(--text-secondary);
  font-size: 0.95rem;
  line-height: 1.55;
  padding: 16px 18px;
  background: var(--bg-secondary);
  border-radius: 8px;
  border: 1px solid var(--border-color);
}

/* Page utility */
.page {
  display: block;
}

/* Responsive */
@media (max-width: 768px) {
  .sidebar {
    width: 100%;
    height: auto;
    position: relative;
    box-shadow: none;
    border-right: none;
    border-bottom: 1px solid var(--border-color);
  }

  .main-content {
    margin-left: 0;
  }

  .admin-panel {
    flex-direction: column;
  }

  .login-container {
    margin: 20px;
    padding: 35px 30px;
  }

  .main-header {
    padding: 20px 25px;
  }

  .main-header h1 {
    font-size: 1.4rem;
  }

  .content-area {
    padding: 25px 20px;
  }
}

/* Additional UI Enhancements */
.card {
  background: var(--bg-card);
  border-radius: 12px;
  padding: 24px;
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-md);
  transition: all 0.3s ease;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(102, 126, 234, 0.3);
}

.hidden {
  display: none !important;
}

/* ===== TLS Single UX improvements ===== */
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 20px;
}

.inline-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: var(--text-secondary);
  margin: 6px 0 4px;
}

.form-input.disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.form-grid .span-2 { grid-column: span 2; }
.form-grid .align-end { align-self: end; }
.full-width { width: 100%; }

@media (max-width: 900px) {
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .span-2 { grid-column: span 1; }
}

.results-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.results-toolbar.sticky {
  position: sticky;
  top: 74px; /* below main header */
  background: var(--bg-card);
  padding: 10px 12px;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  z-index: 10;
}

.results-toolbar .toolbar-left { display: flex; align-items: center; gap: 12px; }
.results-toolbar .toolbar-right { display: flex; align-items: center; gap: 10px; }
.results-toolbar label.inline {
  font-size: 0.78rem;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.results-toolbar input[type="text"] {
  width: 260px;
  background: var(--bg-input);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 0.85rem;
}

.results-toolbar .form-select,
.results-toolbar .form-input {
  width: auto;
  min-width: 120px;
  padding: 8px 12px;
  font-size: 0.85rem;
}

.results-toolbar .form-input[type="number"] {
  width: 120px;
}

.probe-results-table-wrapper.compact table,
.probe-results-table.compact {
  font-size: 0.75rem;
}

.probe-results-table.compact th,
.probe-results-table.compact td,
.probe-results-table-wrapper.compact th,
.probe-results-table-wrapper.compact td {
  padding: 8px 10px;
}

.tls-single-body-view {
  margin-top: 14px;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  background: var(--bg-secondary);
  overflow: hidden;
}
.tls-single-body-view > summary {
  padding: 10px 12px;
  cursor: pointer;
  color: var(--text-secondary);
}
.tls-single-body-view pre {
  padding: 14px 16px;
  margin: 0;
  font-family: monospace;
  font-size: 0.78rem;
  white-space: pre-wrap;
}

.badge {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.badge-primary {
  background: var(--accent-light);
  color: var(--accent-color);
  border: 1px solid var(--accent-color);
}

.badge-success {
  background: rgba(76, 175, 80, 0.1);
  color: var(--success-color);
  border: 1px solid var(--success-color);
}

.badge-error {
  background: rgba(255, 107, 107, 0.1);
  color: var(--error-color);
  border: 1px solid var(--error-color);
}

/* Info Section */
.info-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.info-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.info-header h2 {
  font-size: 1.2rem;
  font-weight: 600;
}

.info-header .subtitle {
  font-size: 0.82rem;
  color: var(--text-secondary);
  margin-top: 6px;
}

.info-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.info-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.info-count {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.info-table-wrapper {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  overflow: hidden;
}

.info-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}

.info-table thead {
  background: var(--bg-tertiary);
}

.info-table th,
.info-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-color);
  text-align: left;
  vertical-align: top;
}

.info-table th {
  font-weight: 600;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
}

.info-table tbody tr:hover {
  background: var(--hover-color);
}

.info-table td.monospaced {
  font-family: monospace;
  font-size: 0.74rem;
}

.info-empty {
  text-align: center;
  padding: 22px 12px;
  font-size: 0.8rem;
  color: var(--text-light);
  border: 1px dashed var(--border-color);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
}

.info-status {
  font-size: 0.8rem;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid transparent;
  color: var(--text-secondary);
}

.info-status.success {
  color: var(--success-color);
  background: rgba(58, 168, 100, 0.08);
  border-color: rgba(58, 168, 100, 0.4);
}

.info-status.error {
  color: var(--error-color);
  background: rgba(255, 95, 95, 0.08);
  border-color: rgba(255, 95, 95, 0.4);
}

.info-status.info {
  color: var(--text-secondary);
  background: rgba(57, 132, 198, 0.08);
  border-color: rgba(57, 132, 198, 0.4);
}

.info-delete-btn {
  padding: 6px 10px;
  font-size: 0.72rem;
  border-radius: 6px;
  border: 1px solid rgba(255, 95, 95, 0.3);
  background: rgba(255, 95, 95, 0.12);
  color: var(--error-color);
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.info-delete-btn:hover {
  background: rgba(255, 95, 95, 0.22);
  color: #ff8a8a;
}

.info-delete-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* HAR Analysis */
.har-wrapper {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.har-upload-card {
  max-width: 820px;
}

.har-upload-header .subtitle {
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin-top: 6px;
}

.har-upload-form {
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.har-file-control {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.har-file-input {
  background: var(--bg-input);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 12px 14px;
  font-size: 0.85rem;
}

.har-file-input::file-selector-button {
  background: var(--accent-color);
  border: none;
  border-radius: 4px;
  color: var(--text-inverse);
  padding: 8px 12px;
  margin-right: 14px;
  cursor: pointer;
}

.har-file-input:hover {
  border-color: var(--accent-color);
}

.har-file-hint {
  font-size: 0.7rem;
  color: var(--text-light);
}

.har-upload-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.har-upload-error {
  color: var(--error-color);
  font-size: 0.8rem;
}

.har-content-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 24px;
  align-items: start;
}

@media (max-width: 1100px) {
  .har-content-grid {
    grid-template-columns: 1fr;
  }
}

.har-summary-header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}

.har-summary-subtitle {
  color: var(--text-secondary);
  font-size: 0.8rem;
  margin-top: 4px;
}

.har-summary-meta {
  font-size: 0.75rem;
  color: var(--text-light);
}

.har-summary-empty {
  margin-top: 12px;
  padding: 26px;
  border: 1px dashed var(--border-color);
  border-radius: 10px;
  font-size: 0.85rem;
  color: var(--text-secondary);
  text-align: center;
}

.har-summary-content {
  display: flex;
  flex-direction: column;
  gap: 22px;
  margin-top: 18px;
}

.har-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

@media (max-width: 900px) {
  .har-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.har-summary-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-light);
}

.har-summary-value {
  display: block;
  margin-top: 6px;
  font-size: 0.9rem;
  font-weight: 600;
}

.har-stat-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

@media (max-width: 900px) {
  .har-stat-row {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}

.har-stat {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
}

.har-stat-number {
  font-size: 1.4rem;
  font-weight: 600;
}

.har-stat-label {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.har-results-section {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.har-results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.har-result-count {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color);
}

.har-results-empty {
  display: none;
  padding: 20px;
  text-align: center;
  font-size: 0.8rem;
  color: var(--text-secondary);
  border: 1px dashed var(--border-color);
  border-radius: 10px;
}

.har-results-table-wrapper {
  overflow: auto;
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
}

.har-results-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}

.har-results-table th,
.har-results-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-color);
  text-align: left;
  vertical-align: top;
}

.har-results-table th {
  font-weight: 600;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  background: var(--bg-tertiary);
}

.har-results-table tbody tr:last-child td {
  border-bottom: none;
}

.har-results-table td:first-child,
.har-results-table td:nth-child(3) {
  font-family: monospace;
}

.har-status-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 0.7rem;
  border: 1px solid var(--border-color);
}

.har-status-chip.new {
  color: var(--accent-color);
  border-color: rgba(57,132,198,0.5);
  background: rgba(57,132,198,0.12);
}

.har-status-chip.existing {
  color: var(--text-secondary);
  background: rgba(255,255,255,0.06);
}

.har-history-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.har-history-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.har-history-subtitle {
  font-size: 0.75rem;
  color: var(--text-secondary);
  margin-top: 8px;
}

.har-history-empty {
  margin-top: 18px;
  font-size: 0.8rem;
  color: var(--text-secondary);
  text-align: center;
}

.har-history-status {
  margin-top: 12px;
  font-size: 0.75rem;
  border-radius: 8px;
  padding: 10px 12px;
  border: 1px solid transparent;
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
}

.har-history-status.success {
  color: var(--success-color);
  border-color: rgba(58,168,100,0.5);
  background: rgba(58,168,100,0.08);
}

.har-history-status.error {
  color: var(--error-color);
  border-color: rgba(255, 95, 95, 0.5);
  background: rgba(255, 95, 95, 0.08);
}

.har-history-status.info {
  color: var(--text-secondary);
  border-color: rgba(255,255,255,0.12);
}

.har-history-list {
  list-style: none;
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 420px;
  overflow-y: auto;
  padding-right: 4px;
}

.har-history-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px;
  border-radius: 10px;
  border: 1px solid var(--border-color);
  background: var(--bg-secondary);
  cursor: pointer;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.har-history-item:hover {
  border-color: var(--accent-color);
  background: rgba(57,132,198,0.12);
}

.har-history-item.active {
  border-color: var(--accent-color);
  background: var(--accent-light);
}

.har-history-item.skeleton {
  border-style: dashed;
  animation: pulse 1.8s ease-in-out infinite;
  cursor: default;
}

.har-history-item.skeleton .skeleton-line {
  display: block;
  height: 10px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08);
}

.har-history-item.skeleton .skeleton-line.short {
  width: 90px;
}

.har-history-item.skeleton .har-history-title {
  height: 14px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08);
}

.har-history-item.skeleton .har-history-meta,
.har-history-item.skeleton .har-history-counts {
  display: flex;
  gap: 12px;
}

.har-history-title {
  font-size: 0.85rem;
  font-weight: 600;
}

.har-history-meta {
  font-size: 0.7rem;
  color: var(--text-light);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.har-history-counts {
  font-size: 0.7rem;
  color: var(--text-secondary);
  display: flex;
  gap: 10px;
}

/* Loading animation */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.loading {
  animation: pulse 2s ease-in-out infinite;
}

/* Shodan Section */
.shodan-wrapper {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.shodan-header h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 4px;
}

.shodan-header .subtitle {
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin: 0;
}

.shodan-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 18px;
}

.shodan-input-row {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 18px;
}

@media (max-width: 768px) {
  .shodan-input-row {
    grid-template-columns: 1fr;
  }
}

.shodan-input-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.shodan-text-input {
  width: 100%;
  background: var(--bg-input);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 12px 14px;
  font-size: 0.85rem;
  outline: none;
  transition: border-color .2s, background-color .2s;
}

.shodan-text-input:focus {
  border-color: var(--accent-color);
  background: var(--bg-tertiary);
}

.shodan-actions {
  display: flex;
  gap: 12px;
}

.shodan-actions .btn {
  width: auto;
  padding: 10px 20px;
}

.shodan-error {
  font-size: 0.8rem;
  color: var(--error-color);
  min-height: 0;
}

.shodan-error:empty {
  display: none;
}

.shodan-success {
  margin-top: 6px;
  font-size: 0.8rem;
  color: var(--success-color);
  background: rgba(58,168,100,0.08);
  border: 1px solid rgba(58,168,100,0.4);
  border-radius: 6px;
  padding: 8px 12px;
  display: none;
}

.shodan-success.visible {
  display: block;
}

.shodan-results-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.shodan-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.shodan-results-header h3 {
  font-size: 1rem;
  font-weight: 600;
}

.shodan-results-actions {
  display: flex;
  gap: 10px;
}

.shodan-count {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.shodan-empty {
  text-align: center;
  padding: 24px 12px;
  font-size: 0.85rem;
  color: var(--text-light);
  border: 1px dashed var(--border-color);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
}

.shodan-ip-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.shodan-ip-card {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.shodan-ip-card:hover {
  border-color: var(--accent-color);
}

.shodan-ip-card.expanded {
  border-color: var(--accent-color);
}

.shodan-ip-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  cursor: pointer;
  background: var(--bg-tertiary);
  transition: background-color 0.2s ease;
}

.shodan-ip-header:hover {
  background: var(--hover-color);
}

.shodan-ip-address {
  font-family: monospace;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  flex: 1;
}

.shodan-ip-count {
  font-size: 0.75rem;
  color: var(--text-secondary);
  padding: 4px 8px;
  background: var(--bg-primary);
  border-radius: 4px;
}

.shodan-ip-toggle {
  font-size: 0.75rem;
  color: var(--text-light);
}

.shodan-ip-details {
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 1px solid var(--border-color);
}

.shodan-port-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 8px 12px;
  background: var(--bg-primary);
  border-radius: 6px;
  font-size: 0.8rem;
}

.shodan-port {
  font-family: monospace;
  font-weight: 600;
  color: var(--accent-color);
  min-width: 60px;
}

.shodan-domains {
  color: var(--text-secondary);
  word-break: break-word;
}

/* Shodan CIDR List */
.shodan-cidr-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.shodan-cidr-card {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  cursor: pointer;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.shodan-cidr-card:hover {
  border-color: var(--accent-color);
  background: var(--bg-tertiary);
}

.shodan-cidr-value {
  font-family: monospace;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
}

.shodan-cidr-source {
  font-size: 0.75rem;
  color: var(--text-secondary);
  padding: 4px 8px;
  background: var(--bg-primary);
  border-radius: 4px;
}

.shodan-cidr-date {
  font-size: 0.72rem;
  color: var(--text-light);
}

.shodan-cidr-arrow {
  font-size: 1rem;
  color: var(--accent-color);
}

/* Shodan Port List (Detail View) */
.shodan-port-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.shodan-port-card {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.shodan-port-card:hover {
  border-color: var(--accent-color);
}

.shodan-port-card.expanded {
  border-color: var(--accent-color);
}

.shodan-port-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  cursor: pointer;
  background: var(--bg-tertiary);
  transition: background-color 0.2s ease;
}

.shodan-port-header:hover {
  background: var(--hover-color);
}

.shodan-port-number {
  font-family: monospace;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--accent-color);
  min-width: 70px;
}

.shodan-port-stats {
  flex: 1;
  font-size: 0.8rem;
  color: var(--text-secondary);
}

.shodan-port-toggle {
  font-size: 0.75rem;
  color: var(--text-light);
}

.shodan-port-details {
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 1px solid var(--border-color);
}

.shodan-domain-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 14px;
  background: var(--bg-primary);
  border-radius: 6px;
}

.shodan-domain-name {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  word-break: break-all;
}

.shodan-domain-ips {
  font-family: monospace;
  font-size: 0.75rem;
  color: var(--text-light);
  word-break: break-all;
}

.shodan-loading {
  text-align: center;
  padding: 24px;
  color: var(--text-secondary);
  font-size: 0.9rem;
}

.shodan-error-message {
  text-align: center;
  padding: 24px;
  color: var(--error-color);
  font-size: 0.9rem;
}

.shodan-results-header .btn {
  white-space: nowrap;
}

/* TLS Probe Styles */
.tls-probe-wrapper {
  width: 100%;
  max-width: 1680px;
  margin: 0 auto;
  padding: 0 12px;
}

.tls-probe-header {
  padding: 32px;
  border-bottom: 1px solid var(--border-color);
}

.tls-probe-header h2 {
  margin: 0 0 8px 0;
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--text-primary);
}

.operators-section,
.probe-config-section,
.probe-results-section {
  padding: 32px;
  border-bottom: 1px solid var(--border-color);
}

.operators-section:last-child,
.probe-config-section:last-child,
.probe-results-section:last-child {
  border-bottom: none;
}

.operators-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
}

.operators-header h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
}

.operators-list {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}

.operator-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  background: var(--bg-secondary);
}

.operator-info {
  flex: 1;
}

.operator-name {
  font-weight: 600;
  font-size: 1rem;
  margin-bottom: 4px;
  color: var(--text-primary);
}

.operator-queue {
  font-size: 0.875rem;
  color: var(--text-secondary);
  font-family: 'Courier New', monospace;
}

.operator-actions {
  display: flex;
  gap: 8px;
}

.btn-icon {
  width: 32px;
  height: 32px;
  border: none;
  background: var(--error-color);
  color: white;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.btn-icon:hover {
  background: #c82333;
}

.operators-empty,
.operators-empty-msg {
  padding: 16px;
  text-align: center;
  color: var(--text-secondary);
  font-style: italic;
}

.operator-form-section {
  margin-top: 16px;
  padding: 20px;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  background: var(--bg-secondary);
}

.operator-form-section.hidden {
  display: none;
}

.operator-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

.form-group {
  display: flex;
  flex-direction: column;
}

.form-group label {
  margin-bottom: 8px;
  font-weight: 500;
  color: var(--text-primary);
}

.form-input,
.form-select {
  padding: 10px 12px;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  font-size: 0.95rem;
  background: var(--bg-input);
  color: var(--text-primary);
  transition: border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.form-input::placeholder,
.form-select::placeholder {
  color: var(--text-light);
}

.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--accent-color);
  background: var(--bg-tertiary);
  box-shadow: 0 0 0 2px rgba(57,132,198,0.25);
}

.form-actions {
  display: flex;
  gap: 12px;
}

.probe-config-section h3,
.probe-results-section h3 {
  margin: 0 0 24px 0;
  font-size: 1.25rem;
  font-weight: 600;
}

/* Layout for runs/results split */
.probe-split {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 20px;
  align-items: start;
}

@media (max-width: 1100px) {
  .probe-split { grid-template-columns: 1fr; }
}

.probe-runs-section {
  position: relative;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  padding: 12px;
  box-sizing: border-box;
}
.probe-runs-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }

.probe-runs-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 420px;
  overflow-y: auto;
  padding-right: 4px;
}

.probe-runs-list li { width: 100%; box-sizing: border-box; }

.probe-run-item {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-secondary);
  cursor: pointer;
  transition: border-color .2s ease, background-color .2s ease, transform .1s ease;
}

.probe-run-item:hover { border-color: var(--accent-color); background: var(--hover-color); }
.probe-run-item.active { border-color: var(--accent-color); background: var(--accent-light); }

.run-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; }
.run-left { display: flex; flex-direction: column; gap: 4px; }
.run-title { font-weight: 600; color: var(--text-primary); }
.run-sub { font-size: 0.8rem; color: var(--text-secondary); }
.run-right { display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.run-progress { font-weight: 600; color: var(--accent-color); }
.run-counters { font-size: 0.8rem; color: var(--text-secondary); }
.run-delete-btn {
  align-self: flex-end;
  border: 1px solid var(--border-color);
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border-radius: 6px;
  width: 28px;
  height: 28px;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
  padding: 0;
  transition: all 0.15s ease;
}
.run-delete-btn:hover {
  border-color: var(--error-color);
  color: var(--error-color);
  background: #fff6f6;
}

.tls-probe-form .form-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}

.operators-checkboxes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  background: var(--bg-secondary);
}

/* Operator selection chips/grid */
.operators-checkboxes {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: stretch;
}

@media (max-width: 1100px) {
  .operators-checkboxes { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .operators-checkboxes { grid-template-columns: 1fr; }
}

.operator-checkbox-label {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--border-color);
  background: var(--bg-secondary);
  border-radius: 10px;
  cursor: pointer;
  user-select: none;
  transition: border-color .2s ease, background-color .2s ease, transform .1s ease;
}
.operator-checkbox-label:hover { border-color: var(--accent-color); background: var(--hover-color); }

.operator-checkbox-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--accent-color);
}

.operator-checkbox-label span {
  font-weight: 600;
  color: var(--text-primary);
}

/* Active (checked) visual state */
.operator-checkbox-label:has(input[type="checkbox"]:checked) {
  border-color: var(--accent-color);
  background: var(--accent-light);
  transform: translateY(-1px);
}

/* Compact variant inside grid */
.operators-checkboxes .operator-checkbox-label {
  padding: 12px 14px;
}

.tls-probe-error {
  color: var(--error-color);
  margin-top: 12px;
  font-size: 0.9rem;
}

/* Neutral variant for info messages reused in bulk IP/SNI form */
.tls-probe-error.info {
  color: var(--text-secondary);
}

.tls-probe-success {
  color: var(--success-color);
  margin-top: 12px;
  font-size: 0.9rem;
  opacity: 0;
  transition: opacity 0.3s;
}

.tls-probe-success.visible {
  opacity: 1;
}

.probe-results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
}

.results-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  margin-bottom: 16px;
}

.results-toolbar.sticky {
  position: sticky;
  top: 0;
  z-index: 10;
}

.results-toolbar .toolbar-left {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.results-toolbar .toolbar-left label.inline {
  font-weight: 600;
  color: var(--text-secondary);
  font-size: 0.85rem;
}

#probe-filter-status {
  min-height: 70px;
}

.probe-stats {
  margin-bottom: 24px;
  padding: 16px;
  background: var(--bg-secondary);
  border-radius: 8px;
}

.stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
}

.stat-item {
  display: flex;
  gap: 8px;
  align-items: center;
}

.stat-label {
  font-weight: 500;
  color: var(--text-secondary);
}

.stat-value {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 1.1rem;
}

.probe-results-table-wrapper {
  overflow-x: auto;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  background: var(--bg-secondary);
  max-width: 100%;
}

.probe-results-table-wrapper.compact {
  border-radius: 10px;
}

.probe-results-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.probe-results-table th {
  background: var(--bg-secondary);
  padding: 12px;
  text-align: left;
  font-weight: 600;
  border-bottom: 2px solid var(--border-color);
  white-space: nowrap;
}

.probe-results-table td {
  padding: 12px;
  border-bottom: 1px solid var(--border-color);
}

.probe-results-table tbody tr:hover {
  background: rgba(0, 123, 255, 0.02);
}

.status-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
}

.status-badge.status-pass {
  background: #d4edda;
  color: #155724;
}

.status-badge.status-pending {
  background: #fff3cd;
  color: #856404;
}

.status-badge.status-blocked_tcp,
.status-badge.status-blocked_tls,
.status-badge.status-blocked {
  background: #f8d7da;
  color: #721c24;
}

.status-badge.status-http_error {
  background: #d4edda;
  color: #155724;
}

.status-badge.status-error {
  background: #f8d7da;
  color: #721c24;
}

.probe-results-empty {
  padding: 48px;
  text-align: center;
  color: var(--text-secondary);
  font-style: italic;
}

.probe-results-table-wrapper.hidden {
  display: none;
}

.probe-progress {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 16px;
}

.probe-progress.hidden { display: none; }

.progress-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.progress-label {
  font-weight: 600;
  color: var(--text-primary);
}

.progress-value {
  font-weight: 700;
  color: var(--accent-color);
}

.progress-bar {
  position: relative;
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: var(--bg-tertiary);
  overflow: hidden;
}

.progress-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: linear-gradient(90deg, var(--accent-color), #5ab3ff);
  transition: width 0.25s ease;
}

.progress-meta {
  margin-top: 8px;
  color: var(--text-secondary);
  font-size: 0.9rem;
}

.probe-views {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Tabs */
.probe-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  border-bottom: 2px solid var(--border-color);
  padding-bottom: 8px;
}

.probe-tab {
  background: transparent;
  border: none;
  padding: 10px 20px;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: 8px 8px 0 0;
  transition: all 0.15s ease;
}

.probe-tab:hover {
  color: var(--text-primary);
  background: var(--bg-tertiary);
}

.probe-tab.active {
  color: var(--accent-color);
  background: var(--bg-secondary);
  border-bottom: 3px solid var(--accent-color);
  margin-bottom: -10px;
}

.probe-stats-inline {
  margin-left: auto;
  display: flex;
  gap: 16px;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.probe-stats-inline .stat-item {
  display: inline-flex;
  gap: 6px;
}

.probe-stats-inline .stat-value {
  font-weight: 700;
  color: var(--text-primary);
}

.probe-tab-content {
  display: none;
}

.probe-tab-content.active {
  display: block;
}

.probe-matrix-section,
.probe-details-section {
  /* unused now – tabs replace these sections */
}

.section-header {
  display: none; /* replaced by tabs header */
}

.section-header h4 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
}

.section-meta {
  color: var(--text-secondary);
  font-size: 0.9rem;
  margin-bottom: 12px;
}

.probe-matrix-wrapper {
  overflow-x: auto;
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-primary);
}

.probe-matrix-wrapper.hidden { display: none; }

.probe-matrix-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.probe-matrix-table th,
.probe-matrix-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-color);
  border-right: 1px solid var(--border-color);
  vertical-align: middle;
}

.probe-matrix-table th:last-child,
.probe-matrix-table td:last-child { border-right: none; }
.probe-matrix-table tr:last-child td { border-bottom: none; }

.probe-matrix-table th {
  background: var(--bg-secondary);
  font-weight: 700;
  white-space: nowrap;
}

.matrix-host {
  font-weight: 700;
  color: var(--text-primary);
}

.matrix-sub {
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin-top: 4px;
}

.matrix-cell {
  text-align: center;
  min-width: 120px;
}

.matrix-cell.matrix-empty {
  color: var(--text-light);
}

.status-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 86px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
}

.status-chip.status-pass { background: #d4edda; color: #155724; border-color: #c3e6cb; }
.status-chip.status-pending { background: #fff3cd; color: #856404; border-color: #ffeeba; }
.status-chip.status-blocked_tcp,
.status-chip.status-blocked_tls,
.status-chip.status-blocked,
.status-chip.status-error { background: #f8d7da; color: #721c24; border-color: #f5c6cb; }

.status-chip.status-http_error { background: #d4edda; color: #155724; border-color: #c3e6cb; }

.probe-results-empty {
  margin: 0;
}
