/* ==========================================================================
   Domain Health Checker — Tool Page Styles
   ========================================================================== */

.tool-page {
  padding-bottom: 0;
}

.tool-hero {
  position: relative;
  padding: 32px 0 40px;
  overflow: hidden;
}

.tool-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--hero-gradient);
  pointer-events: none;
}

.tool-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 36px;
  align-items: center;
}

.tool-hero-copy {
  min-width: 0;
}

.tool-hero .hero-badge {
  margin-bottom: 10px;
}

.tool-hero h1 {
  font-size: clamp(1.875rem, 3.8vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.12;
  color: var(--color-text);
  margin-bottom: 10px;
  text-align: left;
}

.tool-hero-subtitle {
  font-size: 1rem;
  color: var(--color-muted);
  line-height: 1.55;
  margin-bottom: 16px;
  max-width: 520px;
  text-align: left;
}

.tool-search {
  max-width: 100%;
  margin: 0 0 12px;
}

.tool-search .hero-search-inner,
.tool-search .tool-search-inner {
  padding: 7px;
  border-width: 2px;
  box-shadow:
    0 2px 6px rgba(7, 26, 51, 0.04),
    0 6px 18px rgba(7, 26, 51, 0.05);
}

[data-theme="dark"] .tool-search .hero-search-inner,
[data-theme="dark"] .tool-search .tool-search-inner {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28);
}

.tool-search .hero-input,
.tool-search .tool-input {
  padding: 14px 18px;
  font-size: 1rem;
}

.tool-search .hero-submit,
.tool-search .tool-submit {
  padding: 14px 24px;
  font-size: 0.9375rem;
  font-weight: 700;
  min-width: 148px;
}

.tool-hero-trust {
  margin: 0;
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.5;
  letter-spacing: 0.01em;
}

/* Hero preview card */
.tool-hero-preview {
  min-width: 0;
}

.tool-preview-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow:
    0 2px 4px rgba(7, 26, 51, 0.04),
    0 10px 28px rgba(7, 26, 51, 0.08),
    0 20px 44px rgba(7, 26, 51, 0.06);
}

[data-theme="dark"] .tool-preview-card {
  border-color: rgba(148, 163, 184, 0.14);
  box-shadow:
    0 8px 24px rgba(0, 0, 0, 0.28),
    0 24px 56px rgba(0, 0, 0, 0.42);
}

.tool-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.tool-preview-label {
  display: inline-flex;
  align-items: center;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-accent-dark);
  background: rgba(22, 199, 132, 0.1);
  border: 1px solid rgba(22, 199, 132, 0.22);
  padding: 4px 9px;
  border-radius: 100px;
}

[data-theme="dark"] .tool-preview-label {
  color: #34D399;
  background: rgba(52, 211, 153, 0.1);
  border-color: rgba(52, 211, 153, 0.22);
}

.tool-preview-domain {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.tool-preview-score {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--color-border-soft);
}

.tool-preview-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--color-border-soft);
  font-size: 0.6875rem;
  color: var(--color-muted);
}

.tool-preview-stats strong {
  color: var(--color-text);
  font-weight: 700;
}

.tool-preview-ring {
  flex-shrink: 0;
  width: 76px;
  height: 76px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: conic-gradient(var(--color-accent) 0deg 306deg, var(--color-border-soft) 306deg 360deg);
  position: relative;
}

.tool-preview-ring::before {
  content: "";
  position: absolute;
  inset: 5px;
  border-radius: 50%;
  background: var(--color-card);
}

.tool-preview-value,
.tool-preview-max {
  position: relative;
  z-index: 1;
  line-height: 1;
}

.tool-preview-value {
  font-size: 1.3125rem;
  font-weight: 800;
  color: var(--color-text);
}

.tool-preview-max {
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--color-muted);
  margin-top: 2px;
}

.tool-preview-meta {
  min-width: 0;
}

.tool-preview-status {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.12);
  border: 1px solid rgba(22, 199, 132, 0.22);
  padding: 3px 8px;
  border-radius: 100px;
  margin-bottom: 4px;
}

.tool-preview-meta p {
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.4;
  margin: 0;
}

.tool-preview-checks {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tool-preview-check {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 0.75rem;
  padding: 7px 10px;
  border-radius: 8px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-soft);
}

.tool-preview-check span:first-child {
  color: var(--color-text);
  font-weight: 500;
}

.tool-preview-check span:last-child {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}

.tool-preview-check--ok span:last-child {
  color: var(--color-success);
}

.tool-preview-check--warn span:last-child {
  color: var(--color-warning);
}

.tool-preview-check--neutral span:last-child {
  color: var(--color-muted);
}

/* What's checked */
.tool-checks-section {
  padding: 48px 0 40px;
  background: var(--color-bg-soft);
}

.section-header--compact {
  margin-bottom: 28px;
}

.section-header--compact h2 {
  font-size: clamp(1.375rem, 2.5vw, 1.625rem);
}

.section-header--compact .section-subtitle {
  margin-top: 8px;
}

.tool-checks-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.tool-checks-group {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 18px 18px 16px;
  border-top: 3px solid var(--color-accent);
}

.tool-checks-group-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border-soft);
}

.tool-checks-group-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  flex-shrink: 0;
}

.tool-checks-group-icon--dns {
  background: rgba(59, 130, 246, 0.1);
  color: #3B82F6;
}

.tool-checks-group-icon--domain {
  background: rgba(6, 182, 212, 0.1);
  color: #0891B2;
}

.tool-checks-group-icon--email {
  background: rgba(245, 158, 11, 0.1);
  color: #D97706;
}

.tool-checks-group-icon--ssl,
.tool-checks-group-icon--score {
  background: rgba(22, 199, 132, 0.1);
  color: var(--color-accent-dark);
}

.tool-checks-group-icon--web {
  background: rgba(22, 199, 132, 0.1);
  color: var(--color-accent-dark);
}

.tool-checks-group-icon--rep {
  background: rgba(139, 92, 246, 0.1);
  color: #7C3AED;
}

.tool-checks-group-title {
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-text);
  margin: 0;
}

.tool-checks-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.tool-checks-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.8125rem;
  color: var(--color-text);
  line-height: 1.45;
}

.tool-checks-item-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(22, 199, 132, 0.12);
  color: var(--color-success);
  flex-shrink: 0;
  margin-top: 1px;
}

/* Common issues */
.tool-common-issues {
  padding: 0 0 44px;
}

.tool-common-issues-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.tool-common-issue {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 15px 16px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-card);
  line-height: 1.45;
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

.tool-common-issue:hover {
  border-color: rgba(22, 199, 132, 0.28);
  background: var(--color-bg-soft);
  box-shadow: 0 4px 14px rgba(7, 26, 51, 0.05);
}

[data-theme="dark"] .tool-common-issue:hover {
  border-color: rgba(34, 197, 94, 0.22);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
}

.tool-common-issue-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.tool-common-issue-cat {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
}

.tool-common-issue-text {
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.45;
}

.tool-common-issue-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 9px;
  flex-shrink: 0;
  border: 1px solid transparent;
}

.tool-common-issue-icon--warn {
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.18);
  color: #B45309;
}

.tool-common-issue-icon--info {
  background: rgba(59, 130, 246, 0.1);
  border-color: rgba(59, 130, 246, 0.16);
  color: #2563EB;
}

.tool-common-issue-icon--critical {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.14);
  color: #DC2626;
}

.tool-common-issue-icon--neutral {
  background: var(--color-bg-soft);
  border-color: var(--color-border-soft);
  color: var(--color-muted);
}

[data-theme="dark"] .tool-common-issue-icon--warn {
  color: #FBBF24;
}

[data-theme="dark"] .tool-common-issue-icon--info {
  color: #60A5FA;
}

[data-theme="dark"] .tool-common-issue-icon--critical {
  color: #F87171;
}

.tool-score-note {
  font-style: italic;
}

/* How it works */
.tool-how-section {
  padding: 44px 0;
}

.tool-how-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.tool-how-step {
  padding: 22px 20px;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: var(--color-card);
}

.tool-how-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(22, 199, 132, 0.12);
  color: var(--color-accent-dark);
  font-size: 0.8125rem;
  font-weight: 800;
  margin-bottom: 12px;
}

.tool-how-step h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--color-text);
}

.tool-how-step p {
  font-size: 0.875rem;
  color: var(--color-muted);
  line-height: 1.55;
  margin: 0;
}

/* Score guide */
.tool-score-section {
  padding: 0 0 48px;
}

.tool-score-bands {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.tool-score-band {
  padding: 16px 16px 14px;
  border-radius: 12px;
  border: 1px solid var(--color-border);
  background: var(--color-card);
  border-top-width: 3px;
}

.tool-score-band--excellent { border-top-color: #22C55E; }
.tool-score-band--good { border-top-color: #16C784; }
.tool-score-band--attention { border-top-color: #F59E0B; }
.tool-score-band--issues { border-top-color: #EF4444; }

.tool-score-range {
  display: block;
  font-size: 1.125rem;
  font-weight: 800;
  color: var(--color-text);
  margin-bottom: 2px;
}

.tool-score-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  margin-bottom: 8px;
}

.tool-score-band p {
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.45;
  margin: 0;
}

/* Landing help CTA (pre-result, smaller than report CTA) */
.tool-landing-help {
  padding: 0 0 48px;
}

.tool-landing-help-card {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 22px 32px;
  padding: 26px 30px;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: var(--color-bg-soft);
}

[data-theme="dark"] .tool-landing-help-card {
  background: rgba(148, 163, 184, 0.04);
  border-color: rgba(148, 163, 184, 0.12);
}

.tool-landing-help-brand {
  margin-bottom: 10px;
}

.tool-landing-help-logo {
  display: block;
  height: 26px;
  width: auto;
  max-width: 112px;
  object-fit: contain;
  object-position: left center;
}

.tool-landing-help-logo--dark {
  display: none;
}

[data-theme="dark"] .tool-landing-help-logo--light {
  display: none;
}

[data-theme="dark"] .tool-landing-help-logo--dark {
  display: block;
}

.tool-landing-help-copy {
  flex: 1;
  min-width: 240px;
}

.tool-landing-help-copy h2 {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 6px;
  line-height: 1.35;
}

.tool-landing-help-copy p {
  font-size: 0.875rem;
  color: var(--color-muted);
  line-height: 1.55;
  margin: 0;
  max-width: 640px;
}

.tool-landing-help-btn {
  flex-shrink: 0;
  padding: 11px 20px;
  font-size: 0.875rem;
  font-weight: 600;
  border-color: rgba(22, 199, 132, 0.45);
  color: var(--color-accent-dark);
  background: rgba(22, 199, 132, 0.07);
}

.tool-landing-help-btn:hover {
  background: rgba(22, 199, 132, 0.14);
  border-color: var(--color-accent);
  color: var(--color-accent-dark);
}

[data-theme="dark"] .tool-landing-help-btn {
  color: #34D399;
  border-color: rgba(52, 211, 153, 0.35);
  background: rgba(52, 211, 153, 0.08);
}

[data-theme="dark"] .tool-landing-help-btn:hover {
  background: rgba(52, 211, 153, 0.14);
  border-color: rgba(52, 211, 153, 0.5);
}

/* Collapse marketing sections when checking or showing results */
.tool-page--checking .tool-checks-section,
.tool-page--checking .tool-report-section,
.tool-page--checking .tool-common-issues,
.tool-page--checking .tool-use-section,
.tool-page--checking .tool-audience-section,
.tool-page--checking .tool-how-section,
.tool-page--checking .tool-score-section,
.tool-page--checking .tool-faq,
.tool-page--checking .tool-related,
.tool-page--checking .tool-landing-help,
.tool-page--has-results .tool-checks-section,
.tool-page--has-results .tool-report-section,
.tool-page--has-results .tool-common-issues,
.tool-page--has-results .tool-use-section,
.tool-page--has-results .tool-audience-section,
.tool-page--has-results .tool-how-section,
.tool-page--has-results .tool-score-section,
.tool-page--has-results .tool-faq,
.tool-page--has-results .tool-related,
.tool-page--has-results .tool-landing-help {
  display: none;
}

.tool-page--checking .tool-hero-preview,
.tool-page--has-results .tool-hero-preview {
  display: none;
}

.tool-page--checking .tool-hero-grid,
.tool-page--has-results .tool-hero-grid {
  grid-template-columns: 1fr;
  max-width: 720px;
  margin: 0 auto;
}

.tool-page--checking .tool-hero h1,
.tool-page--has-results .tool-hero h1,
.tool-page--checking .tool-hero-subtitle,
.tool-page--has-results .tool-hero-subtitle {
  text-align: center;
}

.tool-page--checking .tool-hero-subtitle,
.tool-page--has-results .tool-hero-subtitle {
  margin-left: auto;
  margin-right: auto;
}

.tool-page--checking .tool-hero-trust,
.tool-page--has-results .tool-hero-trust,
.tool-page--checking .tool-hero-helper,
.tool-page--has-results .tool-hero-helper {
  text-align: center;
}

.tool-page.tool-page--checking .tool-search,
.tool-page.tool-page--has-results .tool-search {
  margin-left: auto;
  margin-right: auto;
  max-width: 600px;
  margin-top: 0;
  margin-bottom: clamp(48px, 5vw, 64px);
}

/* Compact hero rhythm — shared across all tool result & loading states */
.tool-page.tool-page--checking .tool-hero,
.tool-page.tool-page--has-results .tool-hero {
  padding-top: clamp(36px, 5vw, 48px);
  padding-bottom: 0;
  border-bottom: none;
}

.tool-page.tool-page--checking .tool-hero h1,
.tool-page.tool-page--checking #tool-heading {
  margin-bottom: clamp(12px, 1.5vw, 16px);
}

.tool-page.tool-page--has-results .tool-hero h1,
.tool-page.tool-page--has-results #tool-heading {
  margin-bottom: clamp(20px, 2.5vw, 24px);
}

.tool-page.tool-page--checking .tool-hero-subtitle,
.tool-page.tool-page--has-results .tool-hero-subtitle {
  margin-bottom: clamp(22px, 3vw, 28px);
}

/* Domain Health Checker keeps subtitle visible on results */
body.tool-page.tool-page--has-results:not([class*="-checker-page"]):not([class*="-lookup-page"]) .tool-hero h1,
body.tool-page.tool-page--has-results:not([class*="-checker-page"]):not([class*="-lookup-page"]) #tool-heading {
  margin-bottom: clamp(12px, 1.5vw, 16px);
}

.tool-input-error {
  margin-top: 10px;
  font-size: 0.875rem;
  color: var(--color-error);
  text-align: left;
  padding-left: 4px;
}

/* --- Results area --- */
.tool-results {
  display: none;
  padding: 0 0 0;
}

.tool-results .container {
  max-width: 1240px;
}

.report-audit {
  padding-bottom: 32px;
  padding-top: 8px;
}

.tool-results.is-visible {
  display: block;
  padding: 0;
  margin-top: 0;
  scroll-margin-top: 88px;
}

.demo-banner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 18px;
  margin-bottom: 24px;
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.35);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.5;
}

.demo-banner svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-warning);
}

/* --- Loading --- */
.tool-loading {
  display: none;
  padding: 48px 0 80px;
}

.tool-loading.is-visible {
  display: block;
  scroll-margin-top: 88px;
}

.loading-card {
  max-width: 520px;
  margin: 0 auto;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 32px 28px;
  box-shadow: var(--shadow-soft);
}

.loading-domain {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-muted);
  text-align: center;
  margin-bottom: 24px;
}

.loading-steps {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.loading-step {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.875rem;
  color: var(--color-muted);
  transition: color var(--transition);
}

.loading-step.is-active {
  color: var(--color-text);
  font-weight: 600;
}

.loading-step.is-done {
  color: var(--color-success);
}

.loading-step-icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.loading-spinner {
  width: 18px;
  height: 18px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

.loading-step.is-done .loading-spinner {
  display: none;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.loading-skeleton {
  margin-top: 28px;
  display: grid;
  gap: 10px;
}

.skeleton-line {
  height: 12px;
  border-radius: 6px;
  background: linear-gradient(90deg, var(--color-border-soft) 25%, var(--color-bg-soft) 50%, var(--color-border-soft) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s ease infinite;
}

.skeleton-line:nth-child(1) { width: 100%; }
.skeleton-line:nth-child(2) { width: 85%; }
.skeleton-line:nth-child(3) { width: 70%; }

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* --- Health score card --- */
.health-score-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  box-shadow: var(--shadow-card);
  margin-bottom: 32px;
}

.health-score-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 28px 36px;
  align-items: center;
}

.health-score-ring-wrap {
  text-align: center;
}

.health-score-ring-wrap .score-ring {
  width: 140px;
  height: 140px;
  margin-bottom: 8px;
}

.health-score-ring-wrap .score-ring-fill {
  stroke: url(#toolScoreGradient);
}

.health-score-meta h2 {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: 6px;
  word-break: break-word;
}

.health-score-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9375rem;
  font-weight: 700;
  margin-bottom: 12px;
}

.health-score-status::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.status-excellent,
.status-good { color: var(--color-success); }
.status-attention { color: var(--color-warning); }
.status-issues { color: var(--color-error); }

.health-score-summary {
  font-size: 0.9375rem;
  color: var(--color-muted);
  line-height: 1.55;
  margin-bottom: 8px;
}

.health-score-time {
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin-bottom: 20px;
}

.health-score-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 18px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: background var(--transition), border-color var(--transition);
}

.btn-outline:hover {
  background: var(--color-bg-soft);
  border-color: var(--color-muted);
}

/* --- Report sections --- */
.report-section {
  margin-bottom: 40px;
}

.report-section-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}

.report-section-desc {
  font-size: 0.875rem;
  color: var(--color-muted);
  margin-bottom: 20px;
}

/* --- Checks grid --- */
.checks-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.check-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 20px;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.check-card:hover {
  border-color: rgba(22, 199, 132, 0.25);
  box-shadow: var(--shadow-soft);
}

.check-card-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.check-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  flex-shrink: 0;
  background: var(--color-bg-soft);
  color: var(--color-muted);
}

.check-card-title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.3;
}

.check-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 4px;
  padding: 3px 10px;
  border-radius: 100px;
  border: 1px solid transparent;
}

.check-status--passed {
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.12);
  border-color: rgba(22, 199, 132, 0.22);
}

.check-status--warning {
  color: #B45309;
  background: rgba(245, 158, 11, 0.14);
  border-color: rgba(245, 158, 11, 0.28);
}

.check-status--failed {
  color: var(--color-error);
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.22);
}

.check-status--info {
  color: #1D4ED8;
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.2);
}

.check-status--not_checked,
.check-status--not_connected {
  color: var(--color-muted);
  background: var(--color-bg-soft);
  border-color: var(--color-border-soft);
}

.check-status--not_connected {
  color: var(--color-blue);
  background: rgba(37, 99, 235, 0.12);
  border-color: rgba(37, 99, 235, 0.2);
}

[data-theme="dark"] .check-status--not_connected {
  color: var(--color-blue);
  background: rgba(56, 189, 248, 0.12);
}

/* ==========================================================================
   Premium Audit Dashboard
   ========================================================================== */

.audit-dashboard {
  background: linear-gradient(165deg, var(--color-card) 0%, rgba(22, 199, 132, 0.03) 50%, var(--color-card) 100%);
  border: 1px solid var(--color-border);
  border-radius: 24px;
  padding: 36px 40px 40px;
  box-shadow: 0 2px 4px rgba(7, 26, 51, 0.03), 0 8px 24px rgba(7, 26, 51, 0.06), 0 28px 56px rgba(7, 26, 51, 0.09);
  margin-bottom: 20px;
}

[data-theme="dark"] .audit-dashboard {
  background: linear-gradient(165deg, #0D1A2D 0%, #0A1424 45%, #07111F 100%);
  border-color: rgba(148, 163, 184, 0.14);
  box-shadow: 0 24px 56px rgba(0, 0, 0, 0.4);
}

.audit-dashboard-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.audit-report-id {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.audit-mode-banner {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin-bottom: 0;
}

.audit-mode-banner--demo {
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.35);
  color: var(--color-text);
}

.audit-mode-banner--live {
  background: rgba(22, 199, 132, 0.12);
  border: 1px solid rgba(22, 199, 132, 0.32);
  color: var(--color-success);
}

.audit-dashboard-grid {
  display: grid;
  grid-template-columns: 220px 1fr 240px;
  gap: 44px;
  align-items: start;
}

.audit-dashboard-score {
  text-align: center;
}

.score-ring--xl {
  width: 210px;
  height: 210px;
  margin: 0 auto 14px;
}

.score-ring--xl .score-value {
  font-size: 3.125rem;
}

.score-ring--xl .score-max {
  font-size: 0.9375rem;
}

.audit-score-progress {
  height: 5px;
  background: var(--color-bg-soft);
  border-radius: 100px;
  overflow: hidden;
  margin: 0 auto 10px;
  max-width: 180px;
}

.audit-score-progress-fill {
  display: block;
  height: 100%;
  border-radius: 100px;
  background: linear-gradient(90deg, var(--color-accent), var(--color-blue));
}

.audit-score-caption {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-muted);
}

.audit-report-kicker {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-accent-dark);
  margin-bottom: 8px;
}

.audit-dashboard-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.audit-domain-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  margin-bottom: 4px;
}

.audit-domain-name {
  font-size: 1.875rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--color-text);
  word-break: break-word;
  line-height: 1.15;
}

.audit-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 100px;
  font-size: 0.8125rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}

.audit-status-pill.status-excellent,
.audit-status-pill.status-good {
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.12);
  border: 1px solid rgba(22, 199, 132, 0.25);
}

.audit-status-pill.status-attention {
  color: var(--color-warning);
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.28);
}

.audit-status-pill.status-issues {
  color: var(--color-error);
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.25);
}

.audit-summary-text {
  font-size: 1.0625rem;
  color: var(--color-text);
  line-height: 1.65;
  margin-bottom: 10px;
  max-width: 52ch;
}

.audit-live-note,
.audit-demo-note {
  font-size: 0.8125rem;
  margin-bottom: 20px;
}

.audit-live-note {
  color: var(--color-success);
  font-weight: 600;
}

.audit-demo-note {
  color: var(--color-warning);
}

.audit-preview-title {
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  margin-bottom: 12px;
}

.audit-preview-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.audit-preview-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.5;
  padding: 10px 14px;
  background: var(--color-bg-soft);
  border-radius: 10px;
  border: 1px solid var(--color-border-soft);
}

.audit-preview-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  margin-top: 8px;
  flex-shrink: 0;
  background: var(--color-warning);
}

.audit-preview-item--critical .audit-preview-dot { background: var(--color-error); }
.audit-preview-item--warning .audit-preview-dot { background: var(--color-warning); }
.audit-preview-item--info .audit-preview-dot { background: var(--color-blue); }

.audit-preview-empty {
  font-size: 0.9375rem;
  color: var(--color-success);
  font-weight: 600;
}

.audit-actions-title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  margin-bottom: 14px;
}

.audit-actions-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.audit-actions-stack .btn,
.audit-actions-stack .btn-outline {
  width: 100%;
  justify-content: center;
  padding: 13px 20px;
  font-size: 0.9375rem;
}

.audit-actions-stack .btn-primary {
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(22, 199, 132, 0.25);
}

.audit-actions-stack .btn-outline {
  border-width: 1.5px;
  font-weight: 600;
  background: var(--color-card);
}

.audit-actions-stack .btn-outline:hover {
  border-color: var(--color-accent);
  background: rgba(22, 199, 132, 0.05);
}

.audit-help-btn {
  text-align: center;
}

/* --- Compact dashboard (combined header + stats) --- */
.audit-dashboard--compact {
  padding: 20px 22px 0;
  margin-top: 0;
  margin-bottom: 0;
  border-radius: 18px;
  border: 1px solid var(--color-border);
  box-shadow:
    0 1px 2px rgba(7, 26, 51, 0.04),
    0 4px 16px rgba(7, 26, 51, 0.06),
    0 12px 32px rgba(7, 26, 51, 0.05);
}

[data-theme="dark"] .audit-dashboard--compact {
  border-color: rgba(148, 163, 184, 0.16);
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.2),
    0 8px 24px rgba(0, 0, 0, 0.35);
}

.audit-dashboard--compact .audit-dashboard-top {
  margin-bottom: 14px;
}

.audit-dashboard-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}

.audit-meta-note {
  font-size: 0.6875rem;
  font-weight: 600;
}

.audit-meta-note--live {
  color: var(--color-success);
}

.audit-meta-note--demo {
  color: var(--color-warning);
}

.audit-dashboard-grid--compact {
  grid-template-columns: 132px minmax(0, 1fr) auto;
  gap: 20px 24px;
  align-items: start;
  padding-bottom: 16px;
}

.score-ring--md {
  width: 132px;
  height: 132px;
  margin: 0 auto;
}

.score-ring--md .score-value {
  font-size: 2.25rem;
}

.score-ring--md .score-max {
  font-size: 0.8125rem;
}

/* Score ring colors (tool report) */
.report-audit .score-ring-bg {
  stroke-width: 8;
}

.report-audit .score-ring-fill {
  stroke-width: 8;
  stroke-linecap: round;
  stroke-dasharray: 326.73;
  stroke-dashoffset: 326.73;
  transition: stroke-dashoffset 1.1s cubic-bezier(0.4, 0, 0.2, 1);
}

.report-audit .score-ring-fill.animated {
  stroke-dashoffset: calc(326.73 - (326.73 * var(--score, 0) / 100));
}

.score-ring--tier-excellent .score-ring-bg {
  stroke: rgba(34, 197, 94, 0.18);
}

.score-ring--tier-excellent .score-ring-fill {
  stroke: url(#scoreGradExcellent);
  filter: drop-shadow(0 0 6px rgba(34, 197, 94, 0.35));
}

.score-ring--tier-good .score-ring-bg {
  stroke: rgba(22, 199, 132, 0.16);
}

.score-ring--tier-good .score-ring-fill {
  stroke: url(#scoreGradGood);
  filter: drop-shadow(0 0 6px rgba(22, 199, 132, 0.32));
}

.score-ring--tier-attention .score-ring-bg {
  stroke: rgba(245, 158, 11, 0.18);
}

.score-ring--tier-attention .score-ring-fill {
  stroke: url(#scoreGradAttention);
  filter: drop-shadow(0 0 6px rgba(249, 115, 22, 0.28));
}

.score-ring--tier-issues .score-ring-bg {
  stroke: rgba(239, 68, 68, 0.16);
}

.score-ring--tier-issues .score-ring-fill {
  stroke: url(#scoreGradIssues);
  filter: drop-shadow(0 0 6px rgba(220, 38, 38, 0.28));
}

[data-theme="dark"] .score-ring--tier-excellent .score-ring-bg {
  stroke: rgba(34, 197, 94, 0.22);
}

[data-theme="dark"] .score-ring--tier-good .score-ring-bg {
  stroke: rgba(22, 199, 132, 0.2);
}

[data-theme="dark"] .score-ring--tier-attention .score-ring-bg {
  stroke: rgba(245, 158, 11, 0.22);
}

[data-theme="dark"] .score-ring--tier-issues .score-ring-bg {
  stroke: rgba(239, 68, 68, 0.2);
}

.audit-dashboard--compact .audit-dashboard-head {
  margin-bottom: 8px;
  align-items: center;
}

.audit-dashboard-head-text {
  min-width: 0;
}

.audit-dashboard--compact .audit-report-kicker {
  margin-bottom: 4px;
}

.audit-dashboard--compact .audit-domain-name {
  font-size: 1.375rem;
  line-height: 1.2;
}

.audit-dashboard--compact .audit-status-pill {
  padding: 6px 12px;
  font-size: 0.75rem;
}

.audit-dashboard--compact .audit-summary-text {
  font-size: 0.9375rem;
  line-height: 1.5;
  margin-bottom: 10px;
  max-width: none;
}

.audit-dashboard--compact .audit-preview-title {
  margin-bottom: 6px;
  font-size: 0.6875rem;
}

.audit-preview-list--compact {
  gap: 4px;
}

.audit-preview-list--compact .audit-preview-item {
  font-size: 0.8125rem;
  padding: 5px 10px;
  border-radius: 8px;
}

.audit-preview-list--compact .audit-preview-dot {
  width: 7px;
  height: 7px;
  margin-top: 6px;
}

.audit-dashboard-actions--compact {
  align-self: start;
}

.audit-actions-stack--compact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  min-width: 148px;
}

.audit-actions-stack--compact .btn,
.audit-actions-stack--compact .btn-outline {
  width: 100%;
  padding: 8px 10px;
  font-size: 0.75rem;
  font-weight: 600;
}

.audit-actions-stack--compact .btn-primary {
  grid-column: 1 / -1;
}

.audit-dashboard-stats {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
  padding: 12px 0 10px;
  border-top: 1px solid var(--color-border-soft);
}

[data-theme="dark"] .audit-dashboard-stats {
  border-top-color: rgba(148, 163, 184, 0.12);
}

.summary-bar-item--compact {
  padding: 6px 8px;
  gap: 8px;
  border-radius: 8px;
}

.summary-bar-item--compact .summary-bar-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
}

.summary-bar-item--compact .summary-bar-value {
  font-size: 0.9375rem;
  line-height: 1.2;
}

.summary-bar-item--compact .summary-bar-label {
  font-size: 0.625rem;
  margin-top: 1px;
}

/* --- Report summary bar (legacy standalone) --- */
.report-summary-bar {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  padding: 18px 22px;
  margin-bottom: 28px;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  box-shadow: var(--shadow-soft);
}

[data-theme="dark"] .report-summary-bar {
  background: #0B1628;
  border-color: rgba(148, 163, 184, 0.14);
}

.summary-bar-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  min-width: 0;
}

.summary-bar-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 11px;
  background: var(--color-bg-soft);
  color: var(--color-muted);
  flex-shrink: 0;
}

.summary-bar-icon svg {
  width: 18px;
  height: 18px;
}

.summary-bar-item--good .summary-bar-icon {
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.1);
}

.summary-bar-item--warn .summary-bar-icon {
  color: var(--color-warning);
  background: rgba(245, 158, 11, 0.1);
}

.summary-bar-item--info .summary-bar-value {
  color: #2563EB;
}

[data-theme="dark"] .summary-bar-item--info .summary-bar-value {
  color: #60A5FA;
}

.summary-bar-item--bad .summary-bar-icon {
  color: var(--color-error);
  background: rgba(239, 68, 68, 0.1);
}

.summary-bar-text {
  min-width: 0;
}

.summary-bar-value {
  display: block;
  font-size: 1.0625rem;
  font-weight: 800;
  color: var(--color-text);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.summary-bar-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 3px;
}

/* --- Sticky report nav --- */
.report-nav {
  position: sticky;
  top: 72px;
  z-index: 40;
  margin-top: -4px;
  margin-bottom: 36px;
  padding: 0;
}

.report-nav-inner {
  display: flex;
  gap: 4px;
  padding: 5px;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--color-border);
  border-radius: 100px;
  box-shadow: 0 4px 20px rgba(7, 26, 51, 0.06);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

[data-theme="dark"] .report-nav-inner {
  background: rgba(11, 22, 40, 0.9);
  border-color: rgba(148, 163, 184, 0.14);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.3);
}

.report-nav-inner::-webkit-scrollbar {
  display: none;
}

.report-nav-link {
  flex-shrink: 0;
  padding: 9px 18px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-muted);
  background: transparent;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: color var(--transition), background var(--transition), box-shadow var(--transition);
  white-space: nowrap;
}

.report-nav-link:hover {
  color: var(--color-text);
  background: var(--color-bg-soft);
}

.report-nav-link.is-active {
  color: var(--color-text);
  background: rgba(22, 199, 132, 0.14);
  box-shadow: inset 0 0 0 1px rgba(22, 199, 132, 0.28);
}

[data-theme="dark"] .report-nav-link.is-active {
  background: rgba(34, 197, 94, 0.16);
}

/* --- Report sections --- */
.report-section,
#report-overview,
#faq {
  scroll-margin-top: calc(72px + 64px + 28px);
  margin-bottom: 88px;
}

.report-section--issues {
  margin-bottom: 80px;
}

.report-section-head {
  margin-bottom: 28px;
}

.report-section-head--row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.report-section-head-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(22, 199, 132, 0.1);
  color: var(--color-accent-dark);
  flex-shrink: 0;
}

.report-section-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 20px;
  padding: 32px 32px 36px;
  box-shadow: var(--shadow-soft);
}

.report-section-card--dns {
  padding-top: 28px;
}

.report-section-title {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

/* --- Check categories --- */
.check-category {
  margin-bottom: 32px;
  padding: 22px 22px 24px;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 16px;
}

.check-category:last-child {
  margin-bottom: 0;
}

.check-category-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--color-border-soft);
}

.check-category-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: var(--color-bg-soft);
  color: var(--color-accent-dark);
  flex-shrink: 0;
  border: 1px solid var(--color-border-soft);
}

.check-category-icon--domain-dns {
  background: rgba(59, 130, 246, 0.1);
  color: #2563EB;
  border-color: rgba(59, 130, 246, 0.14);
}

.check-category-icon--email {
  background: rgba(245, 158, 11, 0.1);
  color: #D97706;
  border-color: rgba(245, 158, 11, 0.14);
}

.check-category-icon--web-security {
  background: rgba(22, 199, 132, 0.1);
  color: var(--color-accent-dark);
  border-color: rgba(22, 199, 132, 0.16);
}

.check-category-icon--reputation {
  background: rgba(139, 92, 246, 0.1);
  color: #7C3AED;
  border-color: rgba(139, 92, 246, 0.14);
}

[data-theme="dark"] .check-category-icon--domain-dns {
  color: #60A5FA;
}

[data-theme="dark"] .check-category-icon--email {
  color: #FBBF24;
}

[data-theme="dark"] .check-category-icon--reputation {
  color: #A78BFA;
}

.check-category-meta {
  flex: 1;
  min-width: 0;
}

.check-category-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.check-category-title {
  font-size: 1.1875rem;
  font-weight: 800;
  color: var(--color-text);
  letter-spacing: -0.02em;
}

.check-category-desc {
  font-size: 0.875rem;
  color: var(--color-muted);
  line-height: 1.55;
  max-width: 640px;
}

.check-group-status {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 5px 11px;
  border-radius: 100px;
  white-space: nowrap;
  border: 1px solid transparent;
}

.check-group-status--healthy {
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.12);
  border-color: rgba(22, 199, 132, 0.18);
}

.check-group-status--attention {
  color: var(--color-warning);
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.18);
}

.check-group-status--neutral {
  color: #2563EB;
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.14);
}

[data-theme="dark"] .check-group-status--neutral {
  color: #93C5FD;
  border-color: rgba(147, 197, 253, 0.16);
}

.report-section--checks {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.checks-grid--premium {
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

@media (max-width: 1200px) {
  .checks-grid--premium {
    grid-template-columns: repeat(3, 1fr);
  }
}

.check-card--passed { border-color: rgba(22, 199, 132, 0.18); }
.check-card--warning { border-color: rgba(245, 158, 11, 0.22); }
.check-card--failed { border-color: rgba(239, 68, 68, 0.22); }
.check-card--info { border-color: rgba(37, 99, 235, 0.18); }

.check-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
}

.check-card-detail-line {
  font-size: 0.75rem;
  color: var(--color-muted);
  margin-top: 8px;
  line-height: 1.45;
}

.check-card-head-text {
  min-width: 0;
}

/* --- Issues upgrade --- */
.issues-list--premium {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.issue-card {
  padding: 24px 28px;
  border-radius: 16px;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-border);
}

.issue-card--critical {
  border-left-color: var(--color-error);
  background: linear-gradient(90deg, rgba(239, 68, 68, 0.04) 0%, var(--color-card) 12%);
}

.issue-card--warning {
  border-left-color: var(--color-warning);
  background: linear-gradient(90deg, rgba(245, 158, 11, 0.05) 0%, var(--color-card) 12%);
}

.issue-card--info {
  border-left-color: var(--color-blue);
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.04) 0%, var(--color-card) 12%);
}

.issue-card--collapsed {
  display: none;
}

.issues-expand-wrap {
  display: flex;
  justify-content: center;
  margin-top: 4px;
}

.issues-show-more {
  min-width: 220px;
  font-weight: 600;
}

.issues-notes-block {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--color-border-soft);
}

.issues-notes-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 0;
}

.issues-notes-block.is-collapsed .issues-notes-head {
  margin-bottom: 0;
}

.issues-show-notes {
  flex-shrink: 0;
  font-weight: 600;
  color: var(--color-accent-dark);
}

.issues-notes-block:not(.is-collapsed) .issues-list--notes {
  margin-top: 16px;
}

.issue-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.issue-severity-badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 5px 12px;
  border-radius: 100px;
}

.issue-card--critical .issue-severity-badge {
  color: #DC2626;
  background: rgba(239, 68, 68, 0.14);
  border: 1px solid rgba(239, 68, 68, 0.28);
}

.issue-card--warning .issue-severity-badge {
  color: #B45309;
  background: rgba(245, 158, 11, 0.16);
  border: 1px solid rgba(245, 158, 11, 0.32);
}

.issue-card--info .issue-severity-badge {
  color: #1D4ED8;
  background: rgba(37, 99, 235, 0.12);
  border: 1px solid rgba(37, 99, 235, 0.24);
}

.issues-notes-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 6px;
}

.issues-notes-desc {
  color: var(--color-muted);
  font-size: 0.875rem;
  line-height: 1.5;
  margin: 0;
}

.issues-list--notes .issue-card {
  opacity: 0.95;
}

.issue-meta-chip {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text);
  padding: 5px 12px;
  border-radius: 100px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
}

.issue-meta-chip--time {
  color: var(--color-text);
}

.issue-title {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}

.issue-block {
  margin-bottom: 16px;
}

.issue-block-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-muted);
  margin-bottom: 6px;
}

.issue-technical-wrap {
  margin-bottom: 18px;
}

.issue-technical {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.875rem;
  line-height: 1.6;
  word-break: break-all;
  padding: 16px 18px;
  border-radius: 12px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.issue-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  padding-top: 8px;
}

.issue-actions .btn-outline.btn-sm {
  padding: 10px 18px;
  font-size: 0.875rem;
  font-weight: 600;
  border-width: 1.5px;
  background: var(--color-card);
}

.issue-actions .btn-outline.btn-sm:hover {
  border-color: var(--color-accent);
  background: rgba(22, 199, 132, 0.06);
}

.issue-help-note {
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin-left: auto;
}

.btn-copy-record.is-copied,
.btn-icon-copy.is-copied {
  color: var(--color-success);
  border-color: rgba(22, 199, 132, 0.4);
}

.audit-empty-state {
  padding: 40px;
  text-align: center;
  background: rgba(22, 199, 132, 0.06);
  border: 1px solid rgba(22, 199, 132, 0.18);
  border-radius: 16px;
  color: var(--color-success);
  font-weight: 600;
}

/* --- DNS tabs --- */
.dns-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}

.dns-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-muted);
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-soft);
  border-radius: 100px;
  cursor: pointer;
  transition: all var(--transition);
}

.dns-tab:hover {
  color: var(--color-text);
  border-color: var(--color-border);
}

.dns-tab.is-active {
  color: var(--color-text);
  background: rgba(22, 199, 132, 0.1);
  border-color: rgba(22, 199, 132, 0.28);
}

.dns-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  font-size: 0.6875rem;
  font-weight: 700;
  border-radius: 100px;
  background: var(--color-card);
  color: var(--color-muted);
}

.dns-tab.is-active .dns-tab-count {
  color: var(--color-accent-dark);
}

.dns-panel {
  display: none;
}

.dns-panel.is-active {
  display: block;
}

.records-empty-state {
  padding: 40px 24px;
  text-align: center;
  background: var(--color-bg-soft);
  border: 1px dashed var(--color-border);
  border-radius: 14px;
  color: var(--color-muted);
  font-size: 0.9375rem;
  line-height: 1.5;
}

.dns-value {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.8125rem;
  word-break: break-all;
  color: var(--color-text);
}

.records-table--premium tbody tr {
  transition: background var(--transition);
}

.records-table--premium tbody tr:hover {
  background: var(--color-bg-soft);
}

.records-table--dns th:last-child,
.records-table--dns td:last-child {
  width: 80px;
  text-align: center;
}

.records-table--ptr th:last-child,
.records-table--ptr td.records-status-cell {
  width: 1%;
  min-width: 120px;
  white-space: nowrap;
  text-align: left;
  word-break: normal;
}

.records-table--ptr .summary-badge {
  white-space: nowrap;
}

.btn-icon-copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 1.5px solid var(--color-border);
  border-radius: 9px;
  background: var(--color-card);
  color: var(--color-muted);
  cursor: pointer;
  transition: all var(--transition);
}

.btn-icon-copy:hover {
  color: var(--color-accent-dark);
  border-color: rgba(22, 199, 132, 0.45);
  background: rgba(22, 199, 132, 0.08);
}

.summary-badge--neutral {
  color: var(--color-muted);
  background: var(--color-bg-soft);
}

/* --- Email auth grid --- */
.email-auth-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.email-auth-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 22px;
  box-shadow: var(--shadow-soft);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.email-auth-card:hover {
  border-color: rgba(22, 199, 132, 0.22);
}

.email-auth-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.email-auth-card-head h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
}

.email-auth-record {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.8125rem;
  line-height: 1.55;
  word-break: break-all;
  color: var(--color-text);
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 10px;
}

.email-auth-note {
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.5;
}

.email-auth-meta {
  font-size: 0.875rem;
  color: var(--color-muted);
  margin-bottom: 8px;
}

.email-auth-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
}

.email-stat {
  font-size: 0.75rem;
  color: var(--color-muted);
  padding: 4px 10px;
  border-radius: 8px;
  background: var(--color-bg-soft);
}

.email-stat strong {
  color: var(--color-text);
}

.dmarc-policy-badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: lowercase;
  padding: 3px 10px;
  border-radius: 100px;
}

.dmarc-policy-badge--none {
  color: var(--color-warning);
  background: rgba(245, 158, 11, 0.12);
}

.dmarc-policy-badge--quarantine {
  color: var(--color-blue);
  background: rgba(37, 99, 235, 0.1);
}

.dmarc-policy-badge--reject {
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.12);
}

.email-tool-link {
  margin-top: 12px;
}

.blacklist-status-card {
  max-width: 420px;
  margin: 0 auto;
  padding: 20px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-soft);
  border-radius: 14px;
}

.audit-cta-context {
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, 0.85);
  margin: 12px 0 16px;
  line-height: 1.55;
}

.btn-text {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-accent);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  text-decoration: none;
}

.btn-text:hover {
  color: var(--color-accent-dark);
  text-decoration: underline;
}

.records-value-cell {
  max-width: 420px;
}

.email-auth-mechs li {
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 6px;
  background: var(--color-bg-soft);
  color: var(--color-text);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.email-mx-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.email-mx-list li {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 8px;
  align-items: center;
  font-size: 0.8125rem;
  padding: 8px 10px;
  background: var(--color-bg-soft);
  border-radius: 8px;
}

.email-mx-priority {
  font-weight: 700;
  color: var(--color-muted);
}

.email-mx-provider {
  font-size: 0.75rem;
  color: var(--color-muted);
}

/* --- SSL & Website --- */
.ssl-website-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.ssl-website-grid--3 {
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: 28px;
}

.security-headers-block {
  margin-top: 8px;
}

.security-headers-title {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 6px;
}

.security-headers-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 16px;
}

.security-header-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 18px 20px;
  box-shadow: var(--shadow-soft);
}

.security-header-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.security-header-card-head h4 {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text);
}

.security-header-value code {
  display: block;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.75rem;
  line-height: 1.55;
  word-break: break-all;
  padding: 10px 12px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-soft);
  border-radius: 8px;
  color: var(--color-text);
}

.security-header-note {
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.5;
}

.ssl-website-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 24px;
  box-shadow: var(--shadow-soft);
}

.ssl-website-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border-soft);
}

.ssl-website-note {
  margin-top: 12px;
  font-size: 0.8125rem;
  color: var(--color-error);
}

/* --- Blacklist empty state --- */
.blacklist-not-connected {
  text-align: center;
  padding: 24px 16px 8px;
}

.blacklist-not-connected-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: var(--color-bg-soft);
  color: var(--color-muted);
}

.blacklist-not-connected h3 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 8px;
}

.blacklist-not-connected > p {
  font-size: 0.9375rem;
  color: var(--color-muted);
  line-height: 1.55;
  max-width: 480px;
  margin: 0 auto 20px;
}

.blacklist-meta-grid {
  max-width: 360px;
  margin: 0 auto 16px;
  text-align: left;
}

.blacklist-future-note {
  font-size: 0.8125rem;
  color: var(--color-muted);
  font-style: italic;
}

.blacklist-hit-list ul {
  margin-top: 8px;
  font-size: 0.8125rem;
  color: var(--color-text);
}

.blacklist-hit-list li {
  padding: 6px 0;
  border-bottom: 1px solid var(--color-border-soft);
}

.reverse-dns-block {
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--color-border-soft);
}

.blacklist-empty-state .reverse-dns-block {
  margin-top: 8px;
  text-align: left;
}

.blacklist-empty-state .reverse-dns-block .report-section-desc {
  text-align: left;
}

/* --- CTA polish --- */
.audit-cta {
  margin-bottom: 64px;
}

/* --- Print --- */
@media print {
  .site-header,
  .tool-hero,
  .tool-loading,
  .report-nav,
  .tool-faq,
  .tool-related,
  .tool-common-issues,
  .tool-landing-help,
  .tool-checks-section,
  .tool-how-section,
  .tool-score-section,
  .site-footer,
  .audit-dashboard-actions,
  .btn-text,
  .btn-icon-copy,
  .issue-actions a {
    display: none !important;
  }

  .audit-dashboard-grid {
    grid-template-columns: 140px 1fr;
  }

  .report-section {
    break-inside: avoid;
    margin-bottom: 32px;
  }

  .tool-results {
    display: block !important;
  }
}


.check-card-summary {
  font-size: 0.9375rem;
  color: var(--color-text);
  line-height: 1.5;
  margin-bottom: 10px;
}

.check-card-details {
  border-top: 1px solid var(--color-border-soft);
  padding-top: 10px;
}

.check-card-details summary {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-accent);
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.check-card-details summary::-webkit-details-marker {
  display: none;
}

.check-card-details summary::after {
  content: " ▾";
  font-size: 0.65rem;
}

.check-card-details[open] summary::after {
  content: " ▴";
}

.check-card-details ul {
  margin-top: 8px;
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.5;
  word-break: break-word;
}

.check-card-details li {
  padding: 4px 0;
  border-bottom: 1px solid var(--color-border-soft);
}

.check-card-details li:last-child {
  border-bottom: none;
}

/* --- Issues (legacy base — extended in premium block above) --- */
.issues-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.issue-body {
  font-size: 0.9375rem;
  color: var(--color-muted);
  line-height: 1.6;
}

.issue-fix {
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.55;
}

.issue-fix strong {
  color: var(--color-text);
  font-weight: 600;
}

.issue-technical {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.75rem;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-soft);
  border-radius: 8px;
  padding: 10px 12px;
  color: var(--color-text);
  word-break: break-all;
  margin-bottom: 12px;
}

.issue-cta {
  font-size: 0.8125rem;
  font-weight: 600;
}

.issue-cta a {
  color: var(--color-accent);
}

.issue-cta a:hover {
  color: var(--color-accent-dark);
}

/* --- DNS tables --- */
.dns-record-groups {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.dns-record-group h3 {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 10px;
}

.records-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-card);
}

.records-table {
  width: 100%;
  min-width: 480px;
  border-collapse: collapse;
  font-size: 0.8125rem;
}

.records-table th,
.records-table td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid var(--color-border-soft);
}

.records-table th {
  font-weight: 700;
  color: var(--color-muted);
  background: var(--color-bg-soft);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.records-table td {
  color: var(--color-text);
  word-break: break-all;
  font-size: 0.875rem;
  vertical-align: middle;
}

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

.records-empty {
  padding: 20px 14px;
  font-size: 0.8125rem;
  color: var(--color-muted);
  font-style: italic;
}

/* --- Summary panels --- */
.summary-panels {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.summary-panel {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 22px;
}

.summary-panel h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border-soft);
}

.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 11px 0;
  font-size: 0.875rem;
  border-bottom: 1px solid var(--color-border-soft);
}

.summary-row:last-child {
  border-bottom: none;
}

.summary-row-label {
  color: var(--color-muted);
  flex-shrink: 0;
}

.summary-row-value {
  color: var(--color-text);
  font-weight: 500;
  text-align: right;
  word-break: break-word;
  max-width: 62%;
}

.summary-badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: 100px;
}

.summary-badge--good {
  color: var(--color-success);
  background: rgba(22, 199, 132, 0.12);
}

.summary-badge--attention {
  color: var(--color-warning);
  background: rgba(245, 158, 11, 0.12);
}

.summary-badge--missing,
.summary-badge--not_checked {
  color: var(--color-error);
  background: rgba(239, 68, 68, 0.1);
}

.summary-note {
  margin-top: 12px;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.5;
}

.summary-note a {
  color: var(--color-accent);
  font-weight: 600;
}

/* --- iHoster CTA --- */
.tool-help-cta {
  background: var(--funnel-bg);
  border-radius: var(--radius-lg);
  padding: 40px 44px;
  margin-bottom: 48px;
  position: relative;
  overflow: hidden;
}

.tool-help-cta::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent-gradient);
}

.tool-help-cta-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 28px;
  align-items: center;
}

.tool-help-cta h2 {
  font-size: 1.375rem;
  font-weight: 700;
  color: #FFFFFF;
  margin-bottom: 10px;
}

.tool-help-cta p {
  font-size: 0.9375rem;
  color: #CBD5E1;
  line-height: 1.55;
  margin-bottom: 16px;
}

.tool-help-bullets {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 20px;
}

.tool-help-bullets li {
  font-size: 0.875rem;
  color: #E2E8F0;
  padding-left: 16px;
  position: relative;
}

.tool-help-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-accent);
}

.tool-help-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 200px;
}

.btn-service-ihoster {
  background: #38BDF8;
  color: #0B2545;
  font-weight: 700;
  font-size: 0.9375rem;
  padding: 14px 24px;
  border-radius: var(--radius-sm);
  text-align: center;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  box-shadow: 0 4px 16px rgba(56, 189, 248, 0.35);
}

.btn-service-ihoster:hover {
  background: #7DD3FC;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(56, 189, 248, 0.45);
}

.btn-service-ihoster--bright {
  background: #4ADE80;
  color: #052E16;
  box-shadow: 0 4px 20px rgba(74, 222, 128, 0.4);
}

.btn-service-ihoster--bright:hover {
  background: #86EFAC;
  box-shadow: 0 6px 28px rgba(74, 222, 128, 0.5);
  transform: translateY(-1px);
}

.btn-outline-light {
  display: block;
  padding: 11px 20px;
  font-size: 0.875rem;
  font-weight: 600;
  color: #FFFFFF;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-sm);
  text-align: center;
  transition: background var(--transition), border-color var(--transition);
}

.btn-outline-light:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.45);
}

/* --- FAQ --- */
.tool-faq {
  padding: 48px 0 56px;
  background: var(--color-bg-soft);
}

.tool-faq .faq-list--grid {
  gap: 12px 16px;
}

.tool-faq .faq-item {
  margin-bottom: 0;
  border-radius: 12px;
}

.tool-faq .faq-question {
  padding: 20px 22px;
  font-size: 0.96875rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.45;
}

.tool-faq .faq-answer {
  padding: 0 22px 20px;
  font-size: 0.90625rem;
  color: #475569;
  line-height: 1.65;
}

[data-theme="dark"] .tool-faq .faq-answer {
  color: #94A3B8;
}

.faq-list {
  max-width: 720px;
  margin: 0 auto;
}

.faq-list--grid {
  max-width: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 14px;
  align-items: start;
}

.faq-item {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  margin-bottom: 10px;
  overflow: hidden;
}

.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-text);
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  transition: background var(--transition);
}

.faq-question:hover {
  background: var(--color-bg-soft);
}

.faq-icon {
  flex-shrink: 0;
  transition: transform var(--transition);
  color: var(--color-muted);
}

.faq-item.is-open .faq-icon {
  transform: rotate(180deg);
}

.faq-answer {
  display: none;
  padding: 0 20px 18px;
  font-size: 0.875rem;
  color: var(--color-muted);
  line-height: 1.6;
}

.faq-item.is-open .faq-answer {
  display: block;
}

/* --- Related tools --- */
.tool-related {
  padding: 0 0 64px;
}

.tool-related .tools-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.tool-related .tool-card {
  padding: 16px 18px;
  transition: transform 220ms ease, box-shadow var(--transition), border-color var(--transition);
}

.tool-related .tool-card:hover {
  transform: translateY(-3px);
}

.tool-related .tool-icon {
  width: 36px;
  height: 36px;
  margin-bottom: 10px;
}

.tool-related .tool-icon svg {
  width: 18px;
  height: 18px;
}

.tool-related .tool-title {
  font-size: 0.875rem;
  margin-bottom: 4px;
}

.tool-related .tool-desc {
  font-size: 0.75rem;
  line-height: 1.45;
}

/* --- Responsive --- */
@media (max-width: 1024px) {
  .audit-dashboard-grid--compact {
    grid-template-columns: 120px 1fr;
  }

  .audit-dashboard-actions--compact {
    grid-column: 1 / -1;
  }

  .audit-actions-stack--compact {
    grid-template-columns: repeat(4, 1fr);
    min-width: 0;
  }

  .audit-actions-stack--compact .btn-primary {
    grid-column: auto;
  }

  .audit-dashboard-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .audit-dashboard-grid {
    grid-template-columns: 180px 1fr;
  }

  .audit-dashboard-actions {
    grid-column: 1 / -1;
  }

  .report-summary-bar {
    grid-template-columns: repeat(3, 1fr);
  }

  .checks-grid,
  .checks-grid--premium {
    grid-template-columns: repeat(2, 1fr);
  }

  .ssl-website-grid--3 {
    grid-template-columns: 1fr;
  }

  .security-headers-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .audit-actions-stack {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .audit-actions-stack .btn,
  .audit-actions-stack .btn-outline {
    width: auto;
    flex: 1;
    min-width: 140px;
  }

  .tool-related .tools-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .tool-hero-grid {
    grid-template-columns: 1fr;
    gap: 24px;
    max-width: 600px;
    margin: 0 auto;
  }

  .tool-hero h1,
  .tool-hero-subtitle {
    text-align: center;
  }

  .tool-hero-subtitle {
    margin-left: auto;
    margin-right: auto;
  }

  .tool-hero-trust {
    text-align: center;
  }

  .tool-checks-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .tool-common-issues-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .tool-how-steps {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .tool-score-bands {
    grid-template-columns: repeat(2, 1fr);
  }

  .faq-list--grid {
    grid-template-columns: 1fr;
    max-width: 720px;
    margin: 0 auto;
  }

  .issue-help-note {
    margin-left: 0;
    width: 100%;
  }
}

@media (max-width: 768px) {
  .tool-hero {
    padding: 28px 0 32px;
  }

  .tool-hero-grid {
    gap: 20px;
  }

  .tool-hero-preview {
    max-width: 100%;
    margin: 0 auto;
    width: 100%;
  }

  .tool-preview-card {
    padding: 16px 16px 14px;
  }

  .tool-preview-ring {
    width: 72px;
    height: 72px;
  }

  .tool-hero-copy .hero-badge {
    display: flex;
    justify-content: center;
  }

  .tool-checks-section {
    padding: 36px 0 32px;
  }

  .tool-common-issues {
    padding: 0 0 36px;
  }

  .tool-common-issues-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .tool-common-issue {
    padding: 14px 15px;
  }

  .tool-checks-grid {
    grid-template-columns: 1fr;
  }

  .tool-how-section {
    padding: 32px 0;
  }

  .tool-score-section {
    padding-bottom: 36px;
  }

  .tool-score-bands {
    grid-template-columns: 1fr;
  }

  .tool-related {
    padding: 0 0 44px;
  }

  .tool-related .tools-grid {
    gap: 12px;
  }

  .tool-landing-help {
    padding: 0 0 40px;
  }

  .tool-faq {
    padding: 40px 0 48px;
  }

  .tool-faq .faq-list--grid {
    gap: 10px;
  }

  .tool-faq .faq-question {
    padding: 18px 18px;
    font-size: 0.9375rem;
  }

  .tool-faq .faq-answer {
    padding: 0 18px 18px;
    font-size: 0.875rem;
  }

  .tool-hero h1 {
    font-size: clamp(1.625rem, 5.5vw, 2rem);
  }

  .tool-hero-trust {
    font-size: 0.75rem;
    line-height: 1.6;
  }

  .tool-search {
    max-width: 100%;
  }

  .tool-landing-help-card {
    flex-direction: column;
    align-items: stretch;
    padding: 22px 20px;
  }

  .tool-landing-help-brand {
    margin-bottom: 8px;
  }

  .tool-landing-help-btn {
    width: 100%;
    text-align: center;
  }

  .tool-search .hero-search-inner {
    flex-direction: column;
    padding: 10px;
  }

  .tool-search .hero-input {
    padding: 14px 16px;
    font-size: 1rem;
    width: 100%;
  }

  .tool-search .hero-submit {
    width: 100%;
    padding: 14px 20px;
    min-width: 0;
  }

  .tool-page.tool-page--checking .tool-hero h1,
  .tool-page.tool-page--checking #tool-heading,
  .tool-page.tool-page--has-results .tool-hero h1,
  .tool-page.tool-page--has-results #tool-heading {
    margin-bottom: clamp(16px, 4vw, 20px);
  }

  body.tool-page.tool-page--has-results:not([class*="-checker-page"]):not([class*="-lookup-page"]) .tool-hero h1,
  body.tool-page.tool-page--has-results:not([class*="-checker-page"]):not([class*="-lookup-page"]) #tool-heading {
    margin-bottom: clamp(12px, 3vw, 16px);
  }

  .tool-page.tool-page--checking .tool-search,
  .tool-page.tool-page--has-results .tool-search {
    margin-bottom: clamp(32px, 8vw, 44px);
  }

  .tool-results.is-visible {
    padding: 0;
    scroll-margin-top: 72px;
  }

  .audit-dashboard--compact {
    padding: 16px 16px 0;
    border-radius: 16px;
  }

  .audit-dashboard-grid--compact {
    grid-template-columns: 1fr;
    gap: 14px;
    text-align: left;
  }

  .audit-dashboard--compact .audit-dashboard-head {
    flex-direction: row;
    align-items: flex-start;
  }

  .audit-dashboard-meta {
    align-items: flex-start;
  }

  .audit-dashboard-score {
    display: flex;
    justify-content: flex-start;
  }

  .score-ring--md {
    width: 108px;
    height: 108px;
    margin: 0;
  }

  .score-ring--md .score-value {
    font-size: 1.875rem;
  }

  .audit-actions-stack--compact {
    grid-template-columns: repeat(2, 1fr);
  }

  .audit-dashboard-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    padding: 10px 0 12px;
  }

  .audit-dashboard {
    padding: 24px 20px 28px;
    border-radius: 20px;
  }

  .audit-dashboard-grid {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 28px;
  }

  .audit-dashboard-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .audit-summary-text {
    max-width: none;
  }

  .audit-dashboard-head {
    flex-direction: column;
    align-items: center;
  }

  .audit-dashboard-score {
    order: -1;
  }

  .score-ring--xl {
    width: 176px;
    height: 176px;
  }

  .score-ring--xl .score-value {
    font-size: 2.75rem;
  }

  .audit-preview-item {
    font-size: 0.9375rem;
    padding: 9px 12px;
  }

  .audit-preview-list {
    text-align: left;
  }

  .audit-actions-stack {
    flex-direction: column;
  }

  .audit-actions-stack .btn,
  .audit-actions-stack .btn-outline {
    width: 100%;
  }

  .report-summary-bar {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 14px 16px;
  }

  .summary-bar-item {
    padding: 8px 10px;
  }

  .summary-bar-value {
    font-size: 1rem;
  }

  .issue-card {
    padding: 20px 18px;
  }

  .issues-show-more {
    width: 100%;
  }

  .issues-notes-head {
    flex-direction: column;
    align-items: stretch;
  }

  .issues-show-notes {
    align-self: flex-start;
  }

  .check-category {
    padding: 18px 16px 20px;
    margin-bottom: 20px;
  }

  .check-category-title-row {
    align-items: flex-start;
  }

  .issue-actions .btn-outline.btn-sm {
    width: 100%;
    justify-content: center;
  }

  .issue-help-note {
    margin-left: 0;
    width: 100%;
    text-align: center;
    padding-top: 4px;
  }

  .records-table-wrap {
    margin: 0 -4px;
  }

  .tool-help-cta {
    padding: 28px 24px;
  }

  .tool-help-actions {
    width: 100%;
    min-width: 0;
  }

  .btn-service-ihoster,
  .btn-service-ihoster--bright {
    width: 100%;
    padding: 14px 20px;
  }

  .btn-outline-light {
    width: 100%;
  }

  .report-nav {
    top: 64px;
    margin-top: -4px;
    margin-bottom: 32px;
  }

  .report-section,
  #report-overview,
  #faq {
    scroll-margin-top: calc(64px + 56px + 24px);
  }

  .report-section {
    margin-bottom: 56px;
  }

  .checks-grid,
  .checks-grid--premium {
    grid-template-columns: 1fr;
  }

  .check-category-head {
    flex-direction: row;
    align-items: flex-start;
  }

  .records-table {
    min-width: 520px;
    font-size: 0.75rem;
  }

  .records-table th,
  .records-table td {
    padding: 12px 14px;
  }

  .audit-dashboard--compact {
    padding: 16px 14px 0;
  }

  .audit-dashboard--compact .audit-domain-name {
    font-size: 1.25rem;
    word-break: break-word;
  }

  .issue-card {
    padding: 20px;
  }

  .issue-meta-row {
    gap: 6px;
  }

  .email-auth-grid,
  .ssl-website-grid,
  .ssl-website-grid--3,
  .security-headers-grid,
  .summary-panels {
    grid-template-columns: 1fr;
  }

  .tool-help-cta-grid {
    grid-template-columns: 1fr;
  }

  .tool-help-bullets {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .tool-related .tools-grid {
    grid-template-columns: 1fr;
  }

  .health-score-card {
    padding: 22px 18px;
  }

  .tool-help-cta {
    padding: 28px 22px;
  }
}

/* ==========================================================================
   Domain Health Checker — Flagship pre-result page polish
   Scoped to .domain-health-page (landing state only)
   ========================================================================== */

.domain-health-page .tool-hero {
  padding: 40px 0 52px;
}

.domain-health-page .tool-hero-grid {
  grid-template-columns: 1fr 380px;
  gap: 40px;
}

.domain-health-page .dhd-hero-badge {
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  padding: 5px 12px;
  border: 1px solid rgba(22, 199, 132, 0.28);
  background: rgba(22, 199, 132, 0.08);
}

.domain-health-page .tool-hero h1 {
  font-size: clamp(2rem, 4vw, 2.625rem);
  margin-bottom: 12px;
}

.domain-health-page .tool-hero-subtitle {
  font-size: 1.0625rem;
  max-width: 540px;
  margin-bottom: 20px;
}

.domain-health-page .tool-hero-helper {
  margin: 10px 0 0;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.5;
  max-width: 520px;
}

.domain-health-page .dhd-preview-card {
  padding: 16px 16px 14px;
  border-radius: 18px;
  box-shadow:
    0 2px 4px rgba(7, 26, 51, 0.04),
    0 10px 28px rgba(7, 26, 51, 0.08);
}

[data-theme="dark"] .domain-health-page .dhd-preview-card {
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.32);
}

.domain-health-page .tool-preview-score {
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.domain-health-page .tool-preview-ring {
  width: 68px;
  height: 68px;
}

.domain-health-page .dhd-preview-stats {
  gap: 6px 12px;
  margin-bottom: 10px;
  padding-bottom: 10px;
  font-size: 0.6875rem;
}

.domain-health-page .dhd-preview-checks {
  gap: 4px;
}

.domain-health-page .dhd-preview-checks .tool-preview-check {
  padding: 5px 8px;
  font-size: 0.6875rem;
}

.domain-health-page .tool-preview-foot {
  margin: 8px 0 0;
  padding-top: 8px;
}

.domain-health-page .tool-preview-score-kicker {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  margin-bottom: 4px;
}

.domain-health-page .tool-preview-foot {
  margin: 12px 0 0;
  padding-top: 12px;
  border-top: 1px dashed var(--color-border-soft);
  font-size: 0.6875rem;
  color: var(--color-muted);
  text-align: center;
  line-height: 1.45;
}

.domain-health-page .dhd-preview-stats {
  gap: 8px 16px;
  font-size: 0.6875rem;
}

.domain-health-page .dhd-preview-stats span {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}

.domain-health-page .dhd-preview-stats strong {
  font-size: 0.8125rem;
}

.domain-health-page .dhd-section {
  padding: 52px 0;
}

.domain-health-page .dhd-section--soft {
  background: var(--color-bg-soft);
}

.domain-health-page .dhd-section--related {
  padding: 48px 0;
}

.domain-health-page .section-header--compact {
  margin-bottom: 32px;
}

.domain-health-page .tool-checks-section {
  padding: 52px 0;
}

/* Report includes */
.domain-health-page .dhd-report-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  align-items: stretch;
}

.domain-health-page .dhd-report-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 18px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-card);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.domain-health-page .dhd-report-card:hover {
  border-color: rgba(22, 199, 132, 0.28);
  box-shadow: 0 4px 16px rgba(7, 26, 51, 0.05);
}

.domain-health-page .dhd-report-card-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}

.domain-health-page .dhd-report-card h3 {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.35;
  color: var(--color-text);
}

.domain-health-page .dhd-report-card p {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--color-muted);
}

/* When to use */
.domain-health-page .dhd-use-case-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.domain-health-page .dhd-use-case {
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-card);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.4;
}

.domain-health-page .dhd-use-case::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 8px;
  border-radius: 50%;
  background: var(--color-accent);
  vertical-align: middle;
  transform: translateY(-1px);
}

/* Audience */
.domain-health-page .dhd-audience-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.domain-health-page .dhd-audience-chip {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border: 1px solid var(--color-border);
  border-radius: 100px;
  background: var(--color-card);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}

/* Coverage — hero value section */
.domain-health-page .dhd-coverage-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  align-items: stretch;
}

.domain-health-page .dhd-coverage-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20px 20px 18px;
}

.domain-health-page .dhd-coverage-card .tool-checks-group-head {
  margin-bottom: 16px;
  padding-bottom: 14px;
}

.domain-health-page .dhd-coverage-card .tool-checks-list {
  flex: 1;
  gap: 10px;
}

.domain-health-page .dhd-coverage-card .tool-checks-list li {
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--color-muted);
}

.domain-health-page .dhd-coverage-card:hover {
  border-color: rgba(22, 199, 132, 0.3);
  box-shadow: 0 4px 16px rgba(7, 26, 51, 0.05);
  transform: none;
}

[data-theme="dark"] .domain-health-page .dhd-coverage-card:hover {
  border-color: rgba(52, 211, 153, 0.25);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.22);
}

/* Common issues — compact */
.domain-health-page .dhd-issue-compact-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.domain-health-page .dhd-issue-compact {
  padding: 16px 18px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-card);
}

.domain-health-page .dhd-issue-compact-title {
  margin: 0 0 6px;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.35;
}

.domain-health-page .dhd-issue-compact-text {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.5;
}

.domain-health-page .dhd-issue-note {
  margin: 18px auto 0;
  max-width: 600px;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.55;
  text-align: center;
}

/* How it works */
.domain-health-page .dhd-how-steps {
  gap: 16px;
}

.domain-health-page .dhd-how-step {
  padding: 20px 18px;
}

.domain-health-page .dhd-how-step h3 {
  margin-bottom: 6px;
}

.domain-health-page .dhd-how-step p {
  font-size: 0.8125rem;
  line-height: 1.5;
}

.domain-health-page .dhd-how-step:hover {
  border-color: rgba(22, 199, 132, 0.22);
  box-shadow: none;
}

/* Score bands — compact */
.domain-health-page .dhd-score-bands {
  gap: 12px;
}

.domain-health-page .dhd-score-bands .tool-score-band {
  padding: 16px 16px 14px;
}

.domain-health-page .dhd-score-bands .tool-score-band p {
  font-size: 0.75rem;
  line-height: 1.45;
}

.domain-health-page .dhd-score-note {
  margin: 16px auto 0;
  max-width: 720px;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.55;
  text-align: center;
}

.domain-health-page .dhd-score-note--secondary {
  margin-top: 10px;
  max-width: 640px;
  font-size: 0.75rem;
  opacity: 0.92;
}

/* Related tools — compact */
.domain-health-page .dhd-related-compact-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.domain-health-page .dhd-related-compact {
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-card);
}

.domain-health-page .dhd-related-compact-title {
  margin: 0 0 6px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-muted);
}

.domain-health-page .dhd-related-compact-tools {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.55;
}

.domain-health-page .dhd-related-compact-tools a {
  color: var(--color-text);
  font-weight: 500;
  text-decoration: none;
  transition: color 0.15s ease;
}

.domain-health-page .dhd-related-compact-tools a:hover {
  color: var(--color-accent-dark);
  text-decoration: underline;
}

[data-theme="dark"] .domain-health-page .dhd-related-compact-tools a:hover {
  color: #34D399;
}

.domain-health-page .dhd-related-sep {
  color: var(--color-muted);
  margin-right: 0.2em;
}

.domain-health-page .dhd-related-all {
  margin: 14px 0 0;
  text-align: center;
}

.domain-health-page .dhd-related-all a {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  text-decoration: none;
}

.domain-health-page .dhd-related-all a:hover {
  text-decoration: underline;
}

[data-theme="dark"] .domain-health-page .dhd-related-all a {
  color: #34D399;
}

/* Partner CTA — compact */
.domain-health-page .dhd-landing-help {
  padding-bottom: 48px;
}

.domain-health-page .dhd-cta-header {
  text-align: center;
  margin-bottom: 20px;
}

.domain-health-page .dhd-cta-header h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
}

.domain-health-page .dhd-cta-header .section-subtitle {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  font-size: 0.875rem;
}

.domain-health-page .dhd-partner-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  align-items: stretch;
}

.domain-health-page .dhd-partner-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 18px 18px 16px;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: var(--color-card);
}

.domain-health-page .dhd-partner-card--ihoster {
  border-top: 3px solid #2563eb;
}

.domain-health-page .dhd-partner-card--webfundament {
  border-top: 3px solid #7c3aed;
}

.domain-health-page .dhd-partner-brand {
  display: flex;
  align-items: center;
  height: 32px;
  margin-bottom: 10px;
}

.domain-health-page .dhd-partner-logo {
  display: block;
  height: 24px;
  width: auto;
  max-width: 112px;
  object-fit: contain;
  object-position: left center;
}

.domain-health-page .dhd-partner-card--webfundament .dhd-partner-logo {
  height: 26px;
  max-width: 120px;
}

.domain-health-page .dhd-partner-logo--dark {
  display: none;
}

[data-theme="dark"] .domain-health-page .dhd-partner-logo--light {
  display: none;
}

[data-theme="dark"] .domain-health-page .dhd-partner-logo--dark {
  display: block;
}

.domain-health-page .dhd-partner-name {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 2px;
}

.domain-health-page .dhd-partner-tagline {
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin: 0 0 10px;
  line-height: 1.4;
  min-height: 1.4em;
}

.domain-health-page .dhd-partner-bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-height: 2.9em;
}

.domain-health-page .dhd-partner-bullets li {
  font-size: 0.8125rem;
  color: var(--color-muted);
  padding-left: 12px;
  position: relative;
  line-height: 1.4;
}

.domain-health-page .dhd-partner-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-muted);
  opacity: 0.5;
}

.domain-health-page .dhd-partner-btn {
  margin-top: 14px;
  padding: 9px 16px;
  font-size: 0.8125rem;
  font-weight: 600;
  width: 100%;
  text-align: center;
  box-sizing: border-box;
}

.domain-health-page .dhd-partner-btn--ihoster {
  border-color: rgba(37, 99, 235, 0.4);
  color: #2563eb;
  background: rgba(37, 99, 235, 0.06);
}

.domain-health-page .dhd-partner-btn--ihoster:hover {
  background: rgba(37, 99, 235, 0.12);
  border-color: #2563eb;
}

.domain-health-page .dhd-partner-btn--webfundament {
  border-color: rgba(124, 58, 237, 0.4);
  color: #7c3aed;
  background: rgba(124, 58, 237, 0.06);
}

.domain-health-page .dhd-partner-btn--webfundament:hover {
  background: rgba(124, 58, 237, 0.12);
  border-color: #7c3aed;
}

[data-theme="dark"] .domain-health-page .dhd-partner-btn--ihoster {
  color: #60a5fa;
  border-color: rgba(96, 165, 250, 0.35);
  background: rgba(96, 165, 250, 0.08);
}

[data-theme="dark"] .domain-health-page .dhd-partner-btn--webfundament {
  color: #a78bfa;
  border-color: rgba(167, 139, 250, 0.35);
  background: rgba(167, 139, 250, 0.08);
}

/* FAQ — airy */
.domain-health-page .dhd-faq-section {
  padding-bottom: 72px;
}

.domain-health-page .dhd-faq-section .faq-list--grid {
  gap: 12px;
}

/* Mobile — flagship landing */
@media (max-width: 900px) {
  .domain-health-page .tool-hero-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .domain-health-page .dhd-hero-preview {
    order: 2;
    max-width: 380px;
    margin: 0 auto;
    width: 100%;
  }

  .domain-health-page .tool-hero-copy {
    order: 1;
  }

  .domain-health-page .dhd-coverage-grid,
  .domain-health-page .dhd-report-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .domain-health-page .dhd-related-compact-grid,
  .domain-health-page .dhd-partner-cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .domain-health-page .tool-hero {
    padding: 32px 0 36px;
  }

  .domain-health-page .dhd-section {
    padding: 44px 0;
  }

  .domain-health-page .tool-checks-section {
    padding: 44px 0;
  }

  .domain-health-page .dhd-section--related {
    padding: 40px 0;
  }

  .domain-health-page .dhd-coverage-grid,
  .domain-health-page .dhd-report-grid,
  .domain-health-page .dhd-issue-compact-grid,
  .domain-health-page .dhd-use-case-grid {
    grid-template-columns: 1fr;
  }

  .domain-health-page .tool-hero-helper {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }

  .domain-health-page .dhd-partner-tagline,
  .domain-health-page .dhd-partner-bullets {
    min-height: 0;
  }
}

/* ==========================================================================
   Flagship result report
   ========================================================================== */

.report-audit--flagship {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.report-audit--flagship #report-overview {
  margin-bottom: 0;
}

.report-audit--flagship .report-nav {
  margin-top: 0;
  margin-bottom: 0;
}

.report-audit--flagship .report-section {
  margin-bottom: 0;
}

.report-audit--flagship .why-score-block {
  padding: 12px 14px;
}

.report-audit--flagship .why-score-text {
  margin-bottom: 6px;
}

.report-audit--flagship .why-score-list {
  display: none;
}

.audit-dashboard--flagship {
  margin-bottom: 0;
}

.audit-dashboard-top--compact {
  margin-bottom: 10px;
}

.audit-dashboard-grid--flagship {
  grid-template-columns: 196px minmax(0, 1fr) auto;
  gap: 16px 24px;
  align-items: center;
  padding-bottom: 10px;
}

.audit-dashboard-score--dominant {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.audit-dashboard-score--dominant .audit-status-pill {
  padding: 5px 14px;
  font-size: 0.75rem;
}

.audit-domain-name--flagship {
  font-size: clamp(1.375rem, 2.5vw, 1.75rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

.audit-dashboard--flagship .audit-report-kicker {
  margin-bottom: 4px;
}

.score-ring--lg {
  width: 176px;
  height: 176px;
  margin: 0 auto;
}

.score-ring--flagship.score-ring--xl {
  width: 196px;
  height: 196px;
}

.score-ring--flagship.score-ring--xl .score-value {
  font-size: 3rem;
}

.score-ring--lg .score-value {
  font-size: 2.75rem;
  font-weight: 800;
  line-height: 1;
}

.score-ring--lg .score-max {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-muted);
}

.audit-score-tier {
  display: inline-block;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.audit-checked-time {
  font-size: 0.6875rem;
  color: var(--color-muted);
  margin: 4px 0 0;
}

.audit-summary-text--verdict {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
  max-width: 540px;
  color: var(--color-text);
  margin-bottom: 0;
}

.audit-dashboard-stats--counts {
  border-top: 1px solid var(--color-border-soft);
  padding: 8px 0 12px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 4px;
}

.audit-dashboard-stats--metrics {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  border-top: 1px solid var(--color-border-soft);
  padding: 12px 0 14px;
}

.audit-metric {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 10px 6px;
  border-radius: 10px;
  border: 1px solid var(--color-border-soft);
  background: var(--color-bg-soft);
  text-align: center;
  min-width: 0;
}

.audit-metric-value {
  font-size: 1.375rem;
  font-weight: 800;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
  color: var(--color-text);
}

.audit-metric-label {
  font-size: 0.625rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.audit-metric--good .audit-metric-value { color: #16a34a; }
.audit-metric--review .audit-metric-value { color: #b45309; }
.audit-metric--warn .audit-metric-value { color: #d97706; }
.audit-metric--bad .audit-metric-value { color: #dc2626; }
.audit-metric--neutral .audit-metric-value { color: #64748b; }

.audit-metric--good { border-color: rgba(22, 163, 74, 0.15); background: rgba(22, 163, 74, 0.04); }
.audit-metric--review { border-color: rgba(245, 158, 11, 0.2); background: rgba(245, 158, 11, 0.05); }
.audit-metric--warn { border-color: rgba(245, 158, 11, 0.25); background: rgba(245, 158, 11, 0.06); }
.audit-metric--bad { border-color: rgba(239, 68, 68, 0.2); background: rgba(239, 68, 68, 0.05); }
.audit-metric--neutral { border-color: rgba(100, 116, 139, 0.2); background: rgba(100, 116, 139, 0.05); }

.audit-dashboard-stats--counts .summary-bar-item--compact {
  padding: 4px 2px;
  text-align: center;
}

.audit-dashboard-stats--counts .summary-bar-value {
  font-size: 1.125rem;
  font-weight: 800;
  line-height: 1.2;
}

.audit-dashboard-stats--counts .summary-bar-label {
  font-size: 0.625rem;
  line-height: 1.3;
}

.why-score-inline {
  border-top: 1px solid var(--color-border-soft);
  padding: 10px 0 12px;
  text-align: left;
}

.why-score-inline .why-score-title {
  font-size: 0.8125rem;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--color-text);
}

.why-score-inline .why-score-text {
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.5;
  margin: 0;
  max-width: none;
}

.score-ring--flagship .score-ring-bg,
.score-ring--flagship .score-ring-fill {
  stroke-width: 10;
}

/* Priority action plan */
.report-section--priority {
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 16px 18px;
}

.report-section--priority .report-section-head {
  margin-bottom: 10px;
}

.report-section--priority .report-section-desc {
  margin-bottom: 0;
}

.priority-action-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.priority-action-item {
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-card);
  box-shadow: 0 1px 4px rgba(7, 26, 51, 0.05);
  border-left-width: 3px;
}

.priority-action-item--critical {
  border-left-color: #ef4444;
}

.priority-action-item--warning {
  border-left-color: #f59e0b;
}

.priority-action-item--info {
  border-left-color: #94a3b8;
}

.priority-action-item--hidden {
  display: none;
}

.priority-action-item--hidden.is-visible {
  display: flex;
}

.priority-action-num {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  background: var(--color-bg-soft);
  color: var(--color-muted);
}

.priority-action-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  align-items: center;
  margin-bottom: 8px;
  font-size: 0.6875rem;
}

.priority-meta-dot {
  margin: 0 6px;
  color: var(--color-border);
}

.priority-action-cat,
.priority-action-time,
.priority-action-diff {
  color: var(--color-muted);
  font-weight: 500;
}

.priority-action-diff {
  text-transform: capitalize;
}

.priority-sev {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 9px;
  border-radius: 6px;
  font-size: 0.625rem;
}

.priority-sev--critical { color: #b91c1c; background: rgba(239, 68, 68, 0.09); }
.priority-sev--warning { color: #b45309; background: rgba(245, 158, 11, 0.09); }
.priority-sev--info { color: #475569; background: rgba(100, 116, 139, 0.09); }

.priority-action-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}

.priority-action-btn {
  font-size: 0.75rem;
  padding: 5px 10px;
  text-decoration: none;
  white-space: nowrap;
}

.priority-action-tool {
  display: inline-flex;
  align-items: center;
}

.priority-action-copy,
.priority-action-link {
  cursor: pointer;
}

.priority-expand-wrap {
  margin-top: 12px;
  text-align: center;
}

.priority-show-all {
  font-size: 0.8125rem;
}

.priority-action-cat--badge {
  font-weight: 600;
  color: var(--color-text);
  background: var(--color-bg-soft);
  padding: 2px 8px;
  border-radius: 5px;
  border: 1px solid var(--color-border-soft);
}

.priority-action-title {
  font-size: 0.9375rem;
  font-weight: 800;
  margin: 0 0 3px;
  color: var(--color-text);
  line-height: 1.35;
}

.priority-action-fix {
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.45;
  margin: 0 0 6px;
}

/* Category health */
.category-health-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.category-health-card {
  padding: 14px 14px 12px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-card);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.category-health-status--lg {
  display: inline-flex;
  align-self: flex-start;
  font-size: 0.6875rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 5px 12px;
  border-radius: 8px;
  margin-bottom: 2px;
}

.category-health-status--warning {
  color: #b45309;
  background: rgba(245, 158, 11, 0.12);
}

.category-health-counts {
  font-size: 0.6875rem;
  color: var(--color-muted);
  margin: 4px 0 0;
  letter-spacing: 0.01em;
}

.category-health-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.category-health-title {
  font-size: 0.875rem;
  font-weight: 700;
  margin: 0;
  color: var(--color-text);
}

.category-health-status {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 100px;
  flex-shrink: 0;
}

.category-health-status--passed { color: #16a34a; background: rgba(22, 163, 74, 0.1); }
.category-health-status--review { color: #b45309; background: rgba(245, 158, 11, 0.1); }
.category-health-status--failed { color: #b91c1c; background: rgba(239, 68, 68, 0.1); }
.category-health-status--partial { color: #64748b; background: rgba(100, 116, 139, 0.1); }

.category-health-summary {
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.45;
  margin: 0;
}

.category-health-count {
  font-size: 0.75rem;
  color: var(--color-muted);
  margin: 6px 0 0;
}

/* Why score */
.why-score-block {
  padding: 16px 18px;
  border: 1px dashed var(--color-border);
  border-radius: 12px;
  background: var(--color-bg-soft);
}

.why-score-title {
  font-size: 0.875rem;
  font-weight: 700;
  margin: 0 0 8px;
}

.why-score-text {
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.55;
  margin: 0 0 10px;
}

.why-score-list {
  margin: 0;
  padding-left: 18px;
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.6;
}

/* Success strip */
.audit-success-strip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(22, 199, 132, 0.08);
  border: 1px solid rgba(22, 199, 132, 0.2);
  color: var(--color-success);
}

.audit-success-strip p {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
}

.audit-success-strip--soft {
  background: var(--color-bg-soft);
  border-color: var(--color-border);
  color: var(--color-muted);
}

/* Core checks accordion */
.check-categories-accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.check-category-accordion {
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-card);
  overflow: hidden;
}

.check-category-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px 12px;
  padding: 10px 14px;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

.check-category-toggle-main {
  flex: 1;
  min-width: 0;
}

.check-category-toggle-title {
  font-size: 0.875rem;
  font-weight: 700;
  margin: 0;
  color: var(--color-text);
}

.check-category-summary {
  font-size: 0.75rem;
  color: var(--color-muted);
  margin: 2px 0 6px;
  line-height: 1.4;
}

.check-category-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.check-category-metric {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 100px;
  font-size: 0.6875rem;
  border: 1px solid var(--color-border-soft);
  background: var(--color-bg-soft);
}

.check-category-metric-value {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

.check-category-metric-label {
  font-weight: 500;
  color: var(--color-muted);
}

.check-category-metric--passed .check-category-metric-value { color: #16a34a; }
.check-category-metric--review .check-category-metric-value { color: #b45309; }
.check-category-metric--warning .check-category-metric-value { color: #d97706; }
.check-category-metric--failed .check-category-metric-value { color: #dc2626; }
.check-category-metric--partial .check-category-metric-value { color: #64748b; }

.check-category-toggle-counts {
  font-size: 0.6875rem;
  color: var(--color-muted);
  margin: 2px 0 0;
}

.check-category-status {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 100px;
  flex-shrink: 0;
}

.check-category-status--passed { color: #16a34a; background: rgba(22, 163, 74, 0.1); }
.check-category-status--review { color: #b45309; background: rgba(245, 158, 11, 0.1); }
.check-category-status--warning { color: #b45309; background: rgba(245, 158, 11, 0.1); }
.check-category-status--failed { color: #b91c1c; background: rgba(239, 68, 68, 0.1); }
.check-category-status--partial { color: #64748b; background: rgba(100, 116, 139, 0.1); }

.check-category-expand-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  flex-shrink: 0;
}

.check-category-chevron {
  flex-shrink: 0;
  color: var(--color-muted);
  transition: transform 0.2s ease;
}

.check-category-accordion.is-open .check-category-chevron {
  transform: rotate(180deg);
}

.check-category-panel {
  padding: 0 10px 10px;
  border-top: 1px solid var(--color-border-soft);
}

.check-category-panel .checks-grid--minimal {
  padding-top: 8px;
}

/* Minimal core checks */
.checks-grid--minimal {
  grid-template-columns: 1fr;
  gap: 8px;
}

.check-category-title--minimal {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 0 8px;
}

.check-category--minimal + .check-category--minimal {
  margin-top: 16px;
}

.check-card--minimal {
  padding: 8px 10px;
  border-radius: 8px;
}

.check-card-minimal-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.check-card-minimal-main {
  min-width: 0;
  flex: 1;
}

.check-card--minimal .check-card-title {
  font-size: 0.8125rem;
  font-weight: 600;
  margin: 0 0 2px;
}

.check-card-result {
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.check-card--minimal .check-status {
  font-size: 0.625rem;
  padding: 2px 8px;
  flex-shrink: 0;
}

.check-card-detail-link {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  background: none;
  border: none;
  padding: 6px 0 0;
  cursor: pointer;
  display: inline-block;
}

.check-card-detail-link:hover {
  text-decoration: underline;
}

/* Compact checks (legacy) */
.checks-grid--compact {
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.report-audit--flagship .check-category-icon {
  display: none;
}

.report-audit--flagship .check-category-head {
  margin-bottom: 10px;
}

.check-card--compact {
  padding: 12px 14px;
}

.check-card-compact-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.check-card-compact-main {
  min-width: 0;
}

.check-card--compact .check-card-title {
  font-size: 0.8125rem;
  margin-bottom: 2px;
}

.check-card--compact .check-card-summary {
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.check-card--compact .check-status {
  font-size: 0.625rem;
  padding: 2px 8px;
  margin-top: 0;
}

.check-card-details--compact summary {
  font-size: 0.75rem;
  margin-top: 8px;
}

/* Expandable modules */
.report-modules {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.report-module {
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: var(--color-card);
  overflow: hidden;
}

.report-module-toggle {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 12px;
  padding: 12px 16px;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

.report-module-head {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}

.report-module-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
  color: var(--color-text);
}

.report-module-status {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 100px;
  flex-shrink: 0;
}

.report-module-status--passed { color: #16a34a; background: rgba(22, 163, 74, 0.1); }
.report-module-status--review { color: #b45309; background: rgba(245, 158, 11, 0.1); }
.report-module-status--warning { color: #b45309; background: rgba(245, 158, 11, 0.1); }
.report-module-status--failed { color: #b91c1c; background: rgba(239, 68, 68, 0.1); }
.report-module-status--partial { color: #64748b; background: rgba(100, 116, 139, 0.1); }

.report-module-summary {
  flex: 1 1 100%;
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.45;
  padding-left: 0;
}

.report-module-chevron {
  flex-shrink: 0;
  color: var(--color-muted);
  transition: transform 0.2s ease;
}

.report-module.is-open .report-module-chevron {
  transform: rotate(180deg);
}

.report-module-body {
  padding: 0 16px 14px;
  border-top: 1px solid var(--color-border-soft);
}

.report-audit--flagship .report-section-head {
  margin-bottom: 10px;
}

.report-audit--flagship .report-section-desc {
  margin-top: 2px;
  font-size: 0.8125rem;
}

.report-section-card--inner {
  border: none;
  padding: 16px 0 0;
  box-shadow: none;
}

.records-table--compact {
  font-size: 0.8125rem;
}

.dns-show-all-details {
  margin-top: 10px;
  font-size: 0.8125rem;
}

.dns-show-all-details summary {
  cursor: pointer;
  color: var(--color-accent-dark);
  font-weight: 600;
}

.dns-records-collapsed {
  margin-top: 4px;
}

.dns-records-collapsed summary {
  cursor: pointer;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  margin-bottom: 8px;
}

.record-value-expand summary {
  cursor: pointer;
  list-style: none;
}

.record-value-expand summary::-webkit-details-marker {
  display: none;
}

.record-value-expand .dns-value {
  font-size: 0.75rem;
  word-break: break-all;
}

.record-value-expand .dns-value--full {
  display: block;
  margin-top: 6px;
  white-space: pre-wrap;
  word-break: break-all;
}

.tech-record {
  margin-top: 6px;
}

.tech-record-value {
  display: block;
  font-size: 0.75rem;
  line-height: 1.45;
  word-break: break-all;
  white-space: pre-wrap;
  padding: 8px 10px;
  background: var(--color-bg-soft);
  border-radius: 8px;
  border: 1px solid var(--color-border-soft);
}

.tech-record-value--truncated {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  white-space: normal;
}

.tech-record-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  margin-top: 6px;
}

.tech-record-copy {
  font-size: 0.75rem;
  font-weight: 600;
}

.tech-record-expand {
  font-size: 0.75rem;
}

.tech-record-expand summary {
  cursor: pointer;
  color: var(--color-accent-dark);
  font-weight: 600;
}

.tech-record-value--full {
  margin-top: 6px;
}

.email-auth-grid--compact .email-auth-card {
  padding: 14px 16px;
}

.email-auth-expand summary {
  font-size: 0.75rem;
  cursor: pointer;
  color: var(--color-accent-dark);
  margin-top: 8px;
}

.ssl-website-grid--compact {
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.ssl-website-card--compact {
  padding: 14px 16px;
}

.ssl-website-note--muted {
  font-size: 0.6875rem;
  margin-top: 8px;
}

.security-headers-grid--compact {
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.security-headers-note {
  font-size: 0.75rem;
  color: var(--color-muted);
  margin: 12px 0 0;
}

.reputation-notice {
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin: 0 0 14px;
  padding: 10px 12px;
  background: var(--color-bg-soft);
  border-radius: 8px;
}

.reputation-detail-sections {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.reputation-detail-section + .reputation-detail-section {
  padding-top: 14px;
  border-top: 1px solid var(--color-border-soft);
}

.reputation-detail-title {
  font-size: 0.8125rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--color-text);
}

.reputation-detail-note {
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.45;
  margin: 0 0 10px;
}

.reverse-dns-block .reputation-detail-title {
  margin-bottom: 4px;
}

.blacklist-provider-list {
  margin-top: 10px;
}

.blacklist-provider-list ul {
  margin: 4px 0 0;
  padding-left: 18px;
  font-size: 0.8125rem;
}

/* Dual partner CTA on results */
.audit-cta--dual {
  padding: 22px 24px;
  margin-top: 4px;
}

.audit-cta-intro {
  margin-bottom: 20px;
}

.audit-cta-intro h2 {
  font-size: 1.25rem;
  margin-bottom: 8px;
}

.audit-cta-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.audit-cta-partners {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.audit-cta-partner {
  padding: 18px 20px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
}

.audit-cta-partner h3 {
  font-size: 1rem;
  margin: 0 0 4px;
  color: #fff;
}

.audit-cta-partner p {
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.72);
  margin: 0 0 14px;
}

.audit-cta-partner-btn {
  width: 100%;
  text-align: center;
  border-color: rgba(255, 255, 255, 0.25);
  color: #fff;
  background: rgba(255, 255, 255, 0.06);
}

.audit-cta-partners--ihoster .audit-cta-partner--ihoster {
  border-color: rgba(96, 165, 250, 0.35);
  background: rgba(37, 99, 235, 0.12);
}

.audit-cta-partners--webfundament .audit-cta-partner--webfundament {
  border-color: rgba(167, 139, 250, 0.35);
  background: rgba(124, 58, 237, 0.12);
}

/* Compact hero when checking or showing results (domain health checker only) */
.domain-health-page .tool-hero.tool-hero--compact {
  padding: 8px 0 0;
}

.domain-health-page.tool-page--has-results .tool-hero.tool-hero--compact {
  padding-top: 8px;
  padding-bottom: 0;
}

.domain-health-page.tool-page.tool-page--has-results .tool-hero {
  padding-top: 8px;
  padding-bottom: 0;
}

.domain-health-page.tool-page.tool-page--has-results .tool-hero .tool-search {
  margin-bottom: 14px;
}

.domain-health-page .tool-hero.tool-hero--scanning {
  padding: 8px 0 0;
}

.domain-health-page .tool-hero.tool-hero--compact .tool-hero-grid,
.domain-health-page.tool-page--has-results .tool-hero-grid,
.domain-health-page.tool-page--checking .tool-hero-grid {
  grid-template-columns: 1fr;
  gap: 0;
  max-width: 560px;
  margin: 0 auto;
}

.domain-health-page .tool-hero.tool-hero--compact .dhd-hero-badge,
.domain-health-page .tool-hero.tool-hero--compact .tool-hero-subtitle,
.domain-health-page .tool-hero.tool-hero--compact .tool-hero-trust,
.domain-health-page .tool-hero.tool-hero--compact .tool-hero-helper {
  display: none;
}

.domain-health-page .tool-hero.tool-hero--compact .tool-hero-grid {
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}

.domain-health-page .tool-hero.tool-hero--compact .tool-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
}

.domain-health-page .tool-hero.tool-hero--compact .tool-search {
  position: relative;
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

.domain-health-page .tool-hero.tool-hero--compact .tool-search .visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.domain-health-page .tool-hero.tool-hero--scanning .tool-hero h1,
.domain-health-page .tool-hero.tool-hero--scanning #tool-heading {
  display: block;
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 10px;
  text-align: center;
}

.domain-health-page .tool-hero.tool-hero--compact:not(.tool-hero--scanning) .tool-hero h1,
.domain-health-page .tool-hero.tool-hero--compact:not(.tool-hero--scanning) #tool-heading {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 10px;
  text-align: center;
}

.domain-health-page .tool-hero.tool-hero--scanning .tool-search {
  margin-bottom: 0;
}

.domain-health-page .tool-hero.tool-hero--compact:not(.tool-hero--scanning) .tool-search,
.domain-health-page.tool-page--checking .tool-hero.tool-hero--compact .tool-search {
  margin-bottom: 0;
}

.domain-health-page.tool-page--has-results .tool-hero.tool-hero--compact .tool-search {
  margin-bottom: 14px;
}

/* Inline search bar on compact hero (results + loading) */
.domain-health-page .tool-hero.tool-hero--compact .hero-search-inner,
.domain-health-page .tool-hero.tool-hero--compact .tool-search-inner {
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  padding: 5px;
  gap: 8px;
}

.domain-health-page .tool-hero.tool-hero--compact .hero-input,
.domain-health-page .tool-hero.tool-hero--compact .tool-input {
  flex: 1;
  min-width: 0;
  width: auto;
  padding: 10px 14px;
  font-size: 0.9375rem;
}

.domain-health-page .tool-hero.tool-hero--compact .hero-submit,
.domain-health-page .tool-hero.tool-hero--compact .tool-submit {
  width: auto;
  flex-shrink: 0;
  padding: 10px 18px;
  font-size: 0.875rem;
  min-width: 120px;
  white-space: nowrap;
}

.domain-health-page .tool-hero.tool-hero--compact .tool-hero h1,
.domain-health-page .tool-hero.tool-hero--compact #tool-heading {
  margin-bottom: 8px;
}

.domain-health-page.tool-page--has-results .tool-results.is-visible {
  padding-top: 0;
  margin-top: 0;
  scroll-margin-top: 75px;
}

.domain-health-page.tool-page--has-results .tool-results .container {
  padding-top: 0;
}

.domain-health-page.tool-page--has-results .report-audit {
  padding-top: 0;
}

.domain-health-page.tool-page--has-results #report-overview {
  margin-top: 0;
  scroll-margin-top: 75px;
}

.domain-health-page.tool-page--has-results .report-audit .report-section {
  scroll-margin-top: 75px;
}

.domain-health-page.tool-page--has-results .tool-hero {
  scroll-margin-top: 75px;
}

.domain-health-page.tool-page--checking .tool-loading {
  padding: 10px 0 40px;
  margin-top: 0;
}

.domain-health-page.tool-page--checking .tool-loading .container {
  max-width: 680px;
  margin: 0 auto;
}

.domain-health-page.tool-page--checking .tool-loading.is-visible {
  scroll-margin-top: 75px;
}

.domain-health-page.tool-page--checking .loading-card {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
  padding: 16px 18px;
  border-radius: 14px;
}

.domain-health-page.tool-page--checking .loading-domain {
  margin-bottom: 12px;
  text-align: center;
  font-size: 0.8125rem;
}

.domain-health-page.tool-page--checking .loading-steps {
  gap: 8px;
}

.domain-health-page.tool-page--checking .loading-step {
  font-size: 0.8125rem;
  gap: 10px;
}

.domain-health-page.tool-page--checking .loading-skeleton {
  display: none;
}

@media (max-width: 900px) {
  .category-health-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .checks-grid--compact {
    grid-template-columns: 1fr;
  }

  .ssl-website-grid--compact {
    grid-template-columns: 1fr;
  }

  .audit-cta-partners {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .domain-health-page .tool-hero.tool-hero--compact {
    padding: 8px 0 0;
  }

  .domain-health-page .tool-hero.tool-hero--scanning {
    padding: 6px 0 0;
  }

  .domain-health-page .tool-hero.tool-hero--compact:not(.tool-hero--scanning) .tool-search {
    margin-bottom: 8px;
  }

  .domain-health-page .tool-hero.tool-hero--compact:not(.tool-hero--scanning) .tool-hero h1,
  .domain-health-page .tool-hero.tool-hero--compact:not(.tool-hero--scanning) #tool-heading,
  .domain-health-page .tool-hero.tool-hero--scanning .tool-hero h1,
  .domain-health-page .tool-hero.tool-hero--scanning #tool-heading {
    font-size: 1rem;
    margin-bottom: 8px;
  }

  .domain-health-page.tool-page--checking .tool-loading {
    padding: 8px 0 28px;
  }

  .domain-health-page.tool-page--checking .loading-card {
    padding: 14px 12px;
  }

  .tech-record-value,
  .record-value-expand .dns-value--full,
  .dns-value {
    overflow-wrap: anywhere;
  }

  .priority-action-actions {
    gap: 8px 12px;
  }

  .domain-health-page .tool-hero.tool-hero--compact .hero-submit,
  .domain-health-page .tool-hero.tool-hero--compact .tool-submit {
    min-width: 104px;
    padding: 10px 12px;
    font-size: 0.8125rem;
  }

  .check-category-expand-label {
    display: none;
  }

  .audit-dashboard-grid--flagship {
    grid-template-columns: 1fr;
    text-align: left;
    gap: 14px;
  }

  .audit-dashboard-score--dominant {
    flex-direction: row;
    align-items: center;
    gap: 14px;
    justify-content: flex-start;
  }

  .score-ring--flagship.score-ring--xl {
    width: 108px;
    height: 108px;
    margin: 0;
  }

  .score-ring--flagship.score-ring--xl .score-value {
    font-size: 1.875rem;
  }

  .score-ring--lg {
    width: 120px;
    height: 120px;
    margin: 0;
  }

  .score-ring--lg .score-value {
    font-size: 2rem;
  }

  .audit-dashboard-stats--metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    padding: 10px 0 12px;
  }

  .audit-metric {
    padding: 8px 4px;
  }

  .audit-metric-value {
    font-size: 1.125rem;
  }

  .audit-dashboard-stats--counts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .audit-dashboard-grid--compact {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .audit-dashboard-head {
    flex-direction: column;
    align-items: center;
  }

  .audit-summary-text--verdict {
    margin-left: auto;
    margin-right: auto;
  }

  .category-health-grid {
    grid-template-columns: 1fr;
  }

  .priority-action-item {
    flex-direction: column;
    gap: 8px;
  }

  .report-module:not(.is-open) .report-module-body {
    display: none;
  }

  .security-headers-grid--compact {
    grid-template-columns: 1fr;
  }
}

/* Domain health compact top bar — keep search inline at tablet widths */
@media (max-width: 768px) {
  .domain-health-page .tool-hero.tool-hero--compact .hero-search-inner,
  .domain-health-page .tool-hero.tool-hero--compact .tool-search-inner {
    flex-direction: row;
    flex-wrap: nowrap;
  }

  .domain-health-page .tool-hero.tool-hero--compact .hero-submit,
  .domain-health-page .tool-hero.tool-hero--compact .tool-submit {
    width: auto;
  }

  .domain-health-page.tool-page--has-results .tool-hero.tool-hero--compact .tool-search {
    margin-bottom: 12px;
  }

  .domain-health-page.tool-page--checking .tool-hero.tool-hero--compact .tool-search {
    margin-bottom: 0;
  }

  .domain-health-page.tool-page--has-results .tool-hero.tool-hero--compact .tool-hero h1,
  .domain-health-page.tool-page--has-results .tool-hero.tool-hero--compact #tool-heading {
    margin-bottom: 6px;
  }
}
