/* ============================================================
   audit.css — page publique /audit (lead magnet RGPD/CNIL).
   Hérite de marketing.css + tokens.css. Ne contient que les
   morceaux spécifiques à l'audit : score gauge, badges severity,
   tables risque, spinner.
   ============================================================ */

/* ---------- Hero spécifique audit ---------- */
.au-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-10);
}
.au-hero-wrap {
  max-width: 760px;
  text-align: center;
}
.au-hero .mk-hero-title {
  font-size: clamp(2rem, 4vw, 2.6rem);
  margin: var(--space-4) 0;
}
.au-hero .mk-hero-sub {
  font-size: var(--text-md);
  color: var(--tx2);
}

/* ---------- Form ---------- */
.au-form {
  max-width: 700px;
  margin: var(--space-6) auto 0;
  text-align: left;
}
.au-form .mk-form-row.is-split {
  gap: var(--space-3);
}
.au-form select {
  background: var(--bg2);
}
.au-form-error {
  margin-top: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}
:root.light .au-form-error {
  /* same in light, already light bg */
}

/* ---------- Loader ---------- */
/* Padding compact pour que le loader rentre dans le viewport sans scroll
   après scrollIntoView (sur la majorité des écrans, le loader doit être
   visible immédiatement, sans avoir à descendre). */
.au-loader {
  padding: var(--space-7) 0;
  text-align: center;
  min-height: 60vh;
}
.au-loader-inner {
  max-width: 560px;
  padding-top: var(--space-6);
}
.au-spinner {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-5);
  border: 4px solid color-mix(in srgb, var(--ac) 20%, transparent);
  border-top-color: var(--ac);
  border-radius: 50%;
  animation: au-spin 1s linear infinite;
}
@keyframes au-spin {
  to {
    transform: rotate(360deg);
  }
}
.au-loader-title {
  font-size: var(--text-lg);
  margin: 0 0 var(--space-3);
}
.au-loader-msg {
  font-family: var(--font-mono);
  color: var(--tx2);
  min-height: 1.4em;
  transition: opacity 0.2s;
}
.au-loader-hint {
  color: var(--tx2);
  font-size: var(--text-sm);
  margin-top: var(--space-4);
}

/* ---------- Error ---------- */
.au-error {
  padding: var(--space-10) 0;
  text-align: center;
}
.au-error h2 {
  color: #991b1b;
}

/* ---------- Report header ---------- */
.au-report {
  padding: var(--space-10) 0;
}
.au-report-head {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-5);
  border: 1px solid var(--bd);
  background: var(--bg2);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-8);
}
.au-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 120px;
  padding-right: var(--space-5);
  border-right: 1px solid var(--bd);
}
.au-score-grade {
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 56px;
  line-height: 1;
  color: var(--ac);
}
.au-score[data-grade='A'] .au-score-grade {
  color: #16a34a;
}
.au-score[data-grade='B'] .au-score-grade {
  color: #65a30d;
}
.au-score[data-grade='C'] .au-score-grade {
  color: #ca8a04;
}
.au-score[data-grade='D'] .au-score-grade {
  color: #ea580c;
}
.au-score[data-grade='E'] .au-score-grade {
  color: #dc2626;
}
.au-score[data-grade='F'] .au-score-grade {
  color: #991b1b;
}
.au-score-num {
  margin-top: var(--space-1);
  font-family: var(--font-mono);
}
.au-score-num b {
  font-size: var(--text-lg);
  font-weight: 600;
}
.au-score-num i {
  color: var(--tx2);
  font-style: normal;
  margin-left: 2px;
}

.au-target {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--text-md);
  word-break: break-all;
  margin: 0 0 var(--space-1);
}
.au-meta-line {
  color: var(--tx2);
  font-size: var(--text-sm);
  margin: 0;
}
.au-dot {
  color: var(--bd2);
  margin: 0 4px;
}

/* ---------- Blocs ---------- */
.au-block {
  margin-bottom: var(--space-8);
}
.au-block h2 {
  margin-bottom: var(--space-4);
}

/* Référentiel juridique appliqué — bandeau posé par renderLegalReferential
   à partir de report.legalReferential (sortie de localizeReport côté
   serveur). Discret mais clair : autorité + textes nationaux + URL
   officielle vers la page cookies/traceurs de l'autorité. */
.au-legal-ref {
  border: 1px solid var(--bd);
  border-left: 4px solid var(--ac);
  border-radius: var(--radius-md);
  background: var(--bg2);
  padding: var(--space-4);
  margin-bottom: var(--space-6);
}
.au-legal-ref-head {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-2);
}
.au-legal-ref-eyebrow {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--tx2);
}
.au-legal-ref-title {
  font-weight: 600;
  font-size: var(--text-md);
}
.au-legal-ref-link {
  color: var(--ac);
}
.au-legal-ref-link:hover {
  text-decoration: underline;
}
.au-legal-ref-law,
.au-legal-ref-guidelines {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--tx2);
  font-family: var(--font-mono);
  overflow-wrap: anywhere;
}
.au-legal-ref-guidelines {
  margin-top: var(--space-1);
}

/* Violations */
.au-violation {
  padding: var(--space-4);
  border: 1px solid var(--bd);
  border-left-width: 4px;
  border-radius: var(--radius-md);
  background: var(--bg2);
  margin-bottom: var(--space-3);
  /* Le worker injecte parfois l'URL complète (>700 chars, query params Google
     non séparables) dans v.description / v.fixSuggestion. Sans césure forcée
     ces URLs poussent la largeur du conteneur et débordent du viewport sur
     mobile et même desktop étroit. anywhere = ne casse que si la ligne
     dépasserait, n'affecte pas le texte normal. */
  overflow-wrap: anywhere;
}
.au-violation[data-severity='high'] {
  border-left-color: #dc2626;
}
.au-violation[data-severity='medium'] {
  border-left-color: #d97706;
}
.au-violation[data-severity='low'] {
  border-left-color: #5b6172;
}
.au-severity {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-2);
}
.au-severity[data-severity='high'] {
  background: #fee2e2;
  color: #991b1b;
}
.au-severity[data-severity='medium'] {
  background: #fef3c7;
  color: #92400e;
}
.au-severity[data-severity='low'] {
  background: #e5e7eb;
  color: #374151;
}
.au-severity[data-severity='info'] {
  background: #dbeafe;
  color: #1e40af;
}
:root.light .au-severity[data-severity='high'] {
  background: #fee2e2;
  color: #991b1b;
}
:root.light .au-severity[data-severity='info'] {
  background: #dbeafe;
  color: #1e40af;
}
.au-violation-title {
  font-weight: 600;
  font-size: var(--text-md);
  margin: 0 0 var(--space-2);
}
.au-violation-desc {
  color: var(--tx);
  margin: 0 0 var(--space-2);
  font-size: var(--text-sm);
}
.au-violation-cnil {
  color: var(--tx2);
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  margin: 0 0 var(--space-2);
}
.au-violation-fix {
  color: var(--ac);
  background: color-mix(in srgb, var(--ac) 8%, transparent);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  margin: 0;
}
.au-violation-cta {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--bd);
  font-size: var(--text-sm);
}
.au-violation-cta a {
  color: var(--ac);
  font-weight: 500;
}

/* Vendor group : émis quand 2+ violations partagent un groupKey
   ("google", "meta"…). Wrap visuel léger autour des cards existantes
   — pas de double bordure (les .au-violation à l'intérieur deviennent
   plates) pour éviter le bruit. La bordure latérale colorée est portée
   par le groupe et reflète la sévérité max de la grappe. */
.au-violation-group {
  border: 1px solid var(--bd);
  border-left-width: 4px;
  border-radius: var(--radius-md);
  background: var(--bg2);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
  overflow-wrap: anywhere;
}
.au-violation-group[data-severity='high'] {
  border-left-color: #dc2626;
}
.au-violation-group[data-severity='medium'] {
  border-left-color: #d97706;
}
.au-violation-group[data-severity='low'] {
  border-left-color: #5b6172;
}
.au-violation-group-head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px dashed var(--bd);
}
.au-violation-group-vendor {
  font-weight: 600;
  font-size: var(--text-md);
}
.au-violation-group-count {
  color: var(--tx2);
  font-size: var(--text-sm);
  font-family: var(--font-mono);
}
.au-violation-group .au-violation {
  border-left-width: 2px;
  background: transparent;
  margin-bottom: var(--space-2);
  padding: var(--space-3);
}
.au-violation-group .au-violation:last-child {
  margin-bottom: 0;
}

/* Tables */
.au-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: var(--radius-md);
  overflow: hidden;
  font-size: var(--text-sm);
}
.au-table thead th {
  text-align: left;
  font-weight: 600;
  background: var(--bg3);
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--bd);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--tx2);
}
.au-table td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--bd);
  overflow-wrap: anywhere;
}
.au-table tr:last-child td {
  border-bottom: none;
}
.au-risk {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
}
.au-risk[data-risk='high'] {
  background: #fee2e2;
  color: #991b1b;
}
.au-risk[data-risk='medium'] {
  background: #fef3c7;
  color: #92400e;
}
.au-risk[data-risk='low'] {
  background: #d1fae5;
  color: #065f46;
}

.au-empty {
  color: var(--tx2);
  font-style: italic;
}

/* Banner block */
.au-banner-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}
.au-banner-grid b {
  color: var(--tx);
}
.au-banner-warn {
  grid-column: 1 / -1;
  background: #fef3c7;
  color: #92400e;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-weight: 500;
  font-size: var(--text-sm);
}

/* ---------- CTAs duo ---------- */
.au-ctas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  margin-top: var(--space-10);
}
.au-cta {
  padding: var(--space-5);
  border: 1px solid var(--bd);
  background: var(--bg2);
  border-radius: var(--radius-lg);
}
.au-cta h3 {
  margin-top: 0;
  font-size: var(--text-lg);
}
.au-cta p {
  color: var(--tx2);
  font-size: var(--text-sm);
  margin: var(--space-2) 0 var(--space-4);
}
.au-cta .mk-btn {
  width: 100%;
}
.au-checkbox {
  display: flex !important;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--tx2);
  cursor: pointer;
}
.au-checkbox input {
  margin-top: 3px;
  flex-shrink: 0;
  width: auto !important;
}
.au-form-status {
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  margin-top: var(--space-3);
}
.au-form-status[data-status='ok'] {
  background: #d1fae5;
  color: #065f46;
}
.au-form-status[data-status='err'] {
  background: #fee2e2;
  color: #991b1b;
}

.au-restart-line {
  text-align: center;
  margin-top: var(--space-10);
}

/* ---------- Disclaimer + captcha (gating submit) ---------- */
.audit-disclaimer {
  margin: var(--space-4) 0 var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--bd);
  background: var(--bg2);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}
.audit-disclaimer summary {
  cursor: pointer;
  color: var(--ac);
  font-weight: 500;
  list-style: none;
}
.audit-disclaimer summary::-webkit-details-marker {
  display: none;
}
.audit-disclaimer summary::before {
  content: '▸ ';
  display: inline-block;
  margin-right: 4px;
  transition: transform 0.15s;
}
.audit-disclaimer[open] summary::before {
  transform: rotate(90deg);
}
.audit-disclaimer-body p {
  margin: var(--space-3) 0 0;
  color: var(--tx2);
  line-height: 1.5;
}

.audit-disclaimer-check {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  margin: var(--space-3) 0;
  font-size: var(--text-sm);
  color: var(--tx);
  cursor: pointer;
}
.audit-disclaimer-check input {
  margin-top: 3px;
  flex-shrink: 0;
  width: auto;
}

/* Case "engagement utilisateur" — visuellement distincte (border-left
   colorée) pour ne pas être confondue avec le disclaimer standard.
   Sprint scanner-hardening 2026-05-13. */
.audit-disclaimer-check.audit-user-pledge {
  padding: var(--space-2) var(--space-3);
  border-left: 3px solid var(--brand, #10b981);
  background: rgba(16, 185, 129, 0.06);
  border-radius: var(--radius-sm);
  margin-top: 0;
}

.audit-captcha {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin: var(--space-3) 0 var(--space-4);
  font-size: var(--text-sm);
  flex-wrap: wrap;
}
.audit-captcha label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--tx);
  margin: 0;
}
.audit-captcha #audit-captcha-question {
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--tx);
}
.audit-captcha input[type='number'] {
  width: 80px;
  padding: 6px 8px;
  border: 1px solid var(--bd);
  background: var(--bg2);
  color: var(--tx);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
}
.audit-captcha button {
  padding: 4px 10px;
  border: 1px solid var(--bd);
  background: var(--bg2);
  color: var(--tx2);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--text-md);
  line-height: 1;
}
.audit-captcha button:hover {
  color: var(--ac);
  border-color: var(--ac);
}

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
  .au-report-head {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }
  .au-score {
    border-right: none;
    padding-right: 0;
    min-width: auto;
  }
  .au-ctas {
    grid-template-columns: 1fr;
  }
  .au-banner-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Section "Vous êtes l'éditeur d'un site scanné ?" — opt-out
   public, droit de réponse, instructions robots.txt.
   Sprint scanner-hardening 2026-05-13.
   ============================================================ */
.au-publisher-optout {
  padding: var(--space-5) 0;
  border-top: 1px solid var(--bd);
  background: var(--bg);
}
.au-publisher-optout h2 {
  font-size: var(--text-2xl, 1.5rem);
  margin: 0 0 var(--space-3);
  color: var(--tx);
}
.au-publisher-optout-lead {
  color: var(--tx2);
  margin: 0 0 var(--space-4);
  max-width: 720px;
}
.au-publisher-optout-list {
  list-style: none;
  counter-reset: optout;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--space-4);
}
.au-publisher-optout-list > li {
  counter-increment: optout;
  position: relative;
  padding-left: 48px;
}
.au-publisher-optout-list > li::before {
  content: counter(optout);
  position: absolute;
  left: 0;
  top: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--brand, #10b981);
  color: #fff;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-md);
}
.au-publisher-optout-list strong {
  display: block;
  font-size: var(--text-md);
  color: var(--tx);
  margin-bottom: var(--space-1);
}
.au-publisher-optout-list p {
  margin: 0 0 var(--space-2);
  color: var(--tx2);
  line-height: 1.55;
}
.au-publisher-optout-code {
  margin: var(--space-2) 0 0;
  padding: var(--space-3);
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--tx);
  overflow-x: auto;
}
.au-publisher-optout-footer {
  margin: var(--space-5) 0 0;
  padding: var(--space-3);
  border-left: 3px solid var(--bd);
  color: var(--tx2);
  font-size: var(--text-sm);
  line-height: 1.55;
}
