/*
Theme Name: VigiArtisan
Theme URI: https://vigiartisan.be
Author: Kwitek Solution
Description: Thème officiel VigiArtisan — protection des consommateurs belges. Vérifiez avant de payer.
Version: 3.0.0
License: Proprietary
Text Domain: vigiartisan
*/

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@24,400,0,0&display=block');

/* ── Design tokens (source: VigiArtisan Design System) ── */
:root {
  --va-primary:    #FFFFFF;
  --va-surface:    #FFFFFF;
  --va-surface-2:  #F4F6F8;
  --va-surface-3:  #ECEFF3;
  --va-header:     #1E3A6B;
  --va-header-2:   #14284D;
  --va-accent:     #C0392B;
  --va-accent-ink: #FFFFFF;
  --va-accent-2:   #2E8B57;
  --va-text:       #0F172A;
  --va-text-2:     #334155;
  --va-muted:      #64748B;
  --va-muted-2:    #94A3B8;
  --va-on-header:  #FFFFFF;
  --va-on-header-muted: rgba(255,255,255,.72);
  --va-success:    #2E8B57;
  --va-info:       #2563EB;
  --va-warning:    #E67E22;
  --va-warning-2:  #D35400;
  --va-danger:     #C0392B;
  --va-danger-2:   #A93226;
  --va-bg-success: #E8F3EE;
  --va-bg-danger:  #FBEAE7;
  --va-bg-warning: #FCEFE0;
  --va-bg-info:    #E8F0FE;
  --va-shield-blue:  #1E3A6B;
  --va-shield-green: #6FCF6A;
  --va-border:       rgba(15,23,42,.10);
  --va-border-faint: rgba(15,23,42,.06);
  --va-border-strong:rgba(15,23,42,.18);
  --va-shadow-card:  0 1px 2px rgba(15,23,42,.04), 0 2px 8px rgba(15,23,42,.06);
  --va-shadow-card-2:0 4px 14px rgba(15,23,42,.10);
  --va-r-sm:  8px;
  --va-r-md: 10px;
  --va-r-lg: 12px;
  --va-r-xl: 20px;
  --va-r-full: 9999px;
  --va-font: 'Roboto', system-ui, -apple-system, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; height: 100%; }
body {
  font-family: var(--va-font);
  background: var(--va-surface-2);
  color: var(--va-text);
  line-height: 1.6;
  font-size: 15px;
  overflow-x: hidden;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
main { flex: 1; }
h1,h2,h3,h4,h5 { font-family: var(--va-font); color: var(--va-text); line-height: 1.2; }
a { color: var(--va-accent); text-decoration: none; }
a:hover { color: var(--va-danger-2); }
img { max-width: 100%; height: auto; display: block; }
.container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 24px; border-radius: var(--va-r-md);
  font-family: var(--va-font); font-weight: 800; font-size: 15px;
  cursor: pointer; border: none; transition: all .2s; text-decoration: none; line-height: 1;
}
.btn-primary   { background: var(--va-accent); color: var(--va-accent-ink); box-shadow: 0 1px 2px rgba(15,23,42,.08); }
.btn-primary:hover { background: var(--va-danger-2); color: #fff; transform: translateY(-1px); }
.btn-blue      { background: var(--va-header); color: #fff; }
.btn-blue:hover { background: var(--va-header-2); color: #fff; }
.btn-success   { background: var(--va-success); color: #fff; }
.btn-outline   { background: transparent; border: 1.5px solid rgba(255,255,255,.4); color: #fff; }
.btn-outline:hover { background: rgba(255,255,255,.12); }
.btn-secondary { background: var(--va-surface); color: var(--va-text); border: 1px solid var(--va-border); }
.btn-sm        { padding: 10px 18px; font-size: 13px; }
.btn-lg        { padding: 16px 32px; font-size: 16px; }
.btn-full      { width: 100%; }

/* ── Cards ── */
.card {
  background: var(--va-surface); border-radius: var(--va-r-lg);
  border: 1px solid var(--va-border); padding: 20px;
  box-shadow: var(--va-shadow-card);
}

/* ── Score badge ── */
.score-pill {
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--va-r-md); font-weight: 900; color: #fff;
  font-family: var(--va-font); flex-shrink: 0;
}

/* ── Inputs ── */
.va-input {
  width: 100%; background: var(--va-surface);
  border: 1.5px solid var(--va-border-strong);
  border-radius: var(--va-r-md); color: var(--va-text);
  padding: 14px 16px; font-size: 14px; font-family: var(--va-font);
  outline: none; transition: border-color .2s;
}
.va-input:focus { border-color: var(--va-header); }
.va-input::placeholder { color: var(--va-muted-2); }
textarea.va-input { resize: vertical; min-height: 90px; }

/* ── Badges ── */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 700; padding: 4px 10px;
  border-radius: var(--va-r-full); font-family: var(--va-font);
}
.badge-success { background: var(--va-bg-success); color: var(--va-success); }
.badge-danger  { background: var(--va-bg-danger);  color: var(--va-danger); }
.badge-warning { background: var(--va-bg-warning); color: var(--va-warning-2); }
.badge-info    { background: var(--va-bg-info);    color: var(--va-info); }
.badge-gray    { background: var(--va-surface-3);  color: var(--va-muted); }

/* ── Alerts ── */
.va-alert {
  padding: 12px 16px; border-radius: var(--va-r-md);
  font-size: 14px; margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.va-alert-danger  { background: var(--va-bg-danger);  color: var(--va-danger);  border: 1px solid rgba(192,57,43,.2); }
.va-alert-success { background: var(--va-bg-success); color: var(--va-success); border: 1px solid rgba(46,139,87,.2); }
.va-alert-info    { background: var(--va-bg-info);    color: var(--va-info);    border: 1px solid rgba(37,99,235,.2); }

/* ── Spinner ── */
.spinner {
  width: 32px; height: 32px; border: 3px solid var(--va-surface-3);
  border-top-color: var(--va-accent); border-radius: 50%;
  animation: spin .7s linear infinite; margin: 48px auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Section ── */
.section { padding: 72px 0; }
.section-title { font-size: clamp(24px,3vw,36px); font-weight: 900; color: var(--va-text); margin-bottom: 12px; }
.section-sub { font-size: 16px; color: var(--va-muted); line-height: 1.7; max-width: 580px; margin: 0 auto; }
.section-header { text-align: center; margin-bottom: 48px; }
