/* Cv-flow styling — bouwt op de gedeelde design-tokens uit main.css (:root).
   Eigen stylesheet (CSP-veilig, geen inline styles), per pagina geladen via
   het head_extra-block — zo is geen Tailwind-rebuild nodig. */

/* ── Flash-berichten ─────────────────────────────────────────────── */
.flashes { margin: 1rem 0; display: grid; gap: .5rem; }
.flash { padding: .75rem 1rem; border-radius: var(--radius-knop); border: 1px solid; font-size: .95rem; }
.flash-fout { background: var(--flash-fout-bg); border-color: var(--flash-fout-border); color: var(--flash-fout-tekst); }
.flash-waarschuwing { background: var(--flash-waarschuwing-bg); border-color: var(--flash-waarschuwing-border); color: var(--flash-waarschuwing-tekst); }
.flash-succes { background: var(--flash-succes-bg); border-color: var(--flash-succes-border); color: var(--flash-succes-tekst); }
.flash-info { background: var(--flash-info-bg); border-color: var(--flash-info-border); color: var(--flash-info-tekst); }

/* ── Hero ────────────────────────────────────────────────────────── */
.cv-hero { text-align: center; padding: 1.5rem 0 1rem; }
.cv-hero h1 { font-size: 2rem; line-height: 1.2; }
.cv-hero .accent { color: var(--kleur-primair); }
.cv-hero__sub { color: var(--tekst-secundair); max-width: 34rem; margin: .75rem auto 0; }

/* ── Upload-/plak-formulier ──────────────────────────────────────── */
.cv-form {
  background: var(--achtergrond-card);
  border: 1px solid var(--border-standaard);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: var(--spacing-card);
  margin: 1.5rem 0;
  display: grid;
  gap: 1rem;
}
.cv-veld { display: grid; gap: .4rem; }
.cv-veld__label { font-weight: 600; }
.cv-file {
  padding: .6rem;
  border: 1px dashed var(--border-standaard);
  border-radius: var(--radius-knop);
  background: var(--achtergrond-subtiel);
  width: 100%;
}
.cv-textarea {
  width: 100%;
  padding: .75rem;
  border: 1px solid var(--border-standaard);
  border-radius: var(--radius-knop);
  font: inherit;
  resize: vertical;
}
.cv-textarea:focus, .cv-file:focus { outline: 2px solid var(--border-focus-primair); outline-offset: 1px; }
.cv-of { text-align: center; color: var(--tekst-meta); position: relative; }
.cv-of span { background: var(--achtergrond-card); padding: 0 .75rem; position: relative; z-index: 1; }
.cv-of::before { content: ""; position: absolute; left: 0; right: 0; top: 50%; border-top: 1px solid var(--border-standaard); }
.cv-submit { justify-self: start; }
.cv-privacy { margin: 0; }

/* ── Uitleg ──────────────────────────────────────────────────────── */
.cv-uitleg { margin: 2rem 0; }
.cv-uitleg__lijst { list-style: none; padding: 0; display: grid; gap: .5rem; }
.cv-uitleg__lijst li::before { content: "✓ "; color: #16A34A; font-weight: 700; }

/* ── Resultaat ───────────────────────────────────────────────────── */
.cv-score {
  width: 7rem; height: 7rem; border-radius: 9999px;
  display: grid; place-content: center; text-align: center;
  margin: 0 auto 1rem; color: #fff;
}
.cv-score__cijfer { font-size: 1.8rem; font-weight: 800; font-family: Poppins, sans-serif; line-height: 1; }
.cv-score__cijfer span { font-size: .9rem; opacity: .85; }
.cv-score__label { text-transform: capitalize; font-size: .85rem; }
.cv-score--zwak { background: #D97706; }
.cv-score--voldoende { background: #2563EB; }
.cv-score--goed { background: #16A34A; }
.cv-score--sterk { background: #15803D; }
.cv-samenvatting { text-align: center; font-size: 1.1rem; max-width: 40rem; margin: 0 auto 1.25rem; }

/* ── Rapport-kop: scoreband ──────────────────────────────────────── */
.cv-score-band {
  display: flex; align-items: center; gap: 1.25rem;
  background: var(--achtergrond-card); border: 1px solid var(--border-standaard);
  border-radius: var(--radius-card); box-shadow: var(--shadow-card);
  padding: 1.25rem 1.5rem; margin: 1rem 0 1.25rem;
}
.cv-score-band .cv-score { margin: 0; flex-shrink: 0; }
.cv-score-band__eyebrow {
  margin: 0; font-size: .72rem; text-transform: uppercase; letter-spacing: .05em;
  color: var(--tekst-meta);
}
.cv-score-band__oordeel {
  margin: .15rem 0 0; font-size: 1.3rem; font-weight: 700;
  font-family: Poppins, sans-serif; text-transform: capitalize; line-height: 1.2;
}
.cv-score-band__sub { margin: .3rem 0 0; color: var(--tekst-secundair); }
@media (max-width: 30rem) {
  .cv-score-band { flex-direction: column; text-align: center; }
}

/* ── Sectie-kaart (rapport-secties netjes in een container) ───────── */
.cv-kaart {
  background: var(--achtergrond-card); border: 1px solid var(--border-standaard);
  border-radius: var(--radius-card); box-shadow: var(--shadow-card);
  padding: 1.25rem 1.5rem; margin: 1rem 0;
}
.cv-kaart > h2 {
  font-size: 1.15rem; margin: 0 0 .85rem; display: flex; align-items: center; gap: .5rem;
}
.cv-kaart > :last-child { margin-bottom: 0; }

.cv-blok { margin: 1.5rem 0; }
.cv-blok h2 { font-size: 1.2rem; margin-bottom: .6rem; }
.cv-lijst { padding-left: 1.2rem; display: grid; gap: .35rem; }
.cv-lijst--goed { list-style: none; padding-left: 0; }
.cv-lijst--goed li::before { content: "✓ "; color: #16A34A; font-weight: 700; }

.cv-verbeter {
  border: 1px solid var(--border-standaard);
  border-left: 4px solid var(--border-standaard);
  border-radius: var(--radius-knop);
  padding: .75rem 1rem; margin-bottom: .75rem;
  background: var(--achtergrond-subtiel);
}
.cv-verbeter--hoog { border-left-color: #D97706; }
.cv-verbeter--midden { border-left-color: #2563EB; }
.cv-verbeter--laag { border-left-color: var(--tekst-meta); }
.cv-verbeter__kop { display: flex; gap: .5rem; align-items: center; margin-bottom: .25rem; }
.cv-prio { font-size: .7rem; text-transform: uppercase; letter-spacing: .03em; padding: .1rem .5rem; border-radius: 9999px; color: #fff; }
.cv-prio--hoog { background: #D97706; }
.cv-prio--midden { background: #2563EB; }
.cv-prio--laag { background: #6B7280; }

.cv-acties { margin: 1.5rem 0; text-align: center; }
.cv-meta { text-align: center; }
.cv-funnel { margin-top: 2rem; padding-top: 1rem; border-top: 1px solid var(--border-standaard); }

/* ── FAQ (landing) ───────────────────────────────────────────────── */
.cv-faq { margin: 2.5rem 0 1rem; }
.cv-faq h2 { font-size: 1.3rem; margin-bottom: .75rem; }
.faq-item { border: 1px solid var(--border-standaard); border-radius: var(--radius-knop); padding: .6rem .9rem; margin-bottom: .5rem; background: var(--achtergrond-card); }
.faq-item summary { cursor: pointer; font-weight: 600; }
.faq-item .faq-antwoord { margin-top: .5rem; color: var(--tekst-secundair); }

/* ── Print / opslaan als PDF ─────────────────────────────────────── */
@media print {
  .site-header, .site-footer, .flashes, .cv-acties, .cv-mail, .cv-funnel,
  .cv-slot, .a11y-voorlees-knop { display: none !important; }
  .content-blok { max-width: none; }
  /* Kleuren van scorebadge + kaarten mee afdrukken. */
  .cv-score, .cv-score-band, .cv-kaart, .cv-beroep-kaart {
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  .cv-kaart, .cv-score-band, .cv-beroep-kaart { box-shadow: none; }
  .cv-kaart, .cv-score-band, .cv-verbeter, .cv-beroep-kaart, .faq-item { break-inside: avoid; }
}

/* ── Advies mailen ───────────────────────────────────────────────── */
.cv-mail { margin: 1.5rem 0; text-align: center; }
.cv-mail__label { display: block; font-weight: 600; margin-bottom: .4rem; }
.cv-mail__rij { display: flex; gap: .5rem; justify-content: center; flex-wrap: wrap; }
.cv-mail__input { padding: .6rem .75rem; border: 1px solid var(--border-standaard); border-radius: var(--radius-knop); min-width: 16rem; font: inherit; }

/* ── Beheer ──────────────────────────────────────────────────────── */
.beheer-tabel { width: 100%; border-collapse: collapse; margin: .5rem 0 1.5rem; }
.beheer-tabel th, .beheer-tabel td { text-align: left; padding: .4rem .6rem; border-bottom: 1px solid var(--border-standaard); }
.beheer-tabel th { width: 14rem; color: var(--tekst-secundair); font-weight: 600; }
.beheer-log { background: #111827; color: #e5e7eb; padding: 1rem; border-radius: var(--radius-knop); overflow-x: auto; font-size: .78rem; max-height: 26rem; white-space: pre-wrap; word-break: break-word; }

/* ── Hero-variant met gradient ───────────────────────────────────── */
.cv-hero.hero-bg { border-radius: var(--radius-card); padding: 2.5rem 1.25rem; }
.cv-trust {
  list-style: none; padding: 0; margin: 1rem 0 0;
  display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap;
  color: var(--tekst-secundair); font-size: .9rem;
}

/* ── Stappen "hoe werkt het" ─────────────────────────────────────── */
.cv-stappen { margin: 2.5rem 0; }
.cv-stappen__grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr)); }
.cv-stap {
  background: var(--achtergrond-card); border: 1px solid var(--border-standaard);
  border-radius: var(--radius-card); padding: 1.25rem;
}
.cv-stap__nr {
  display: inline-grid; place-content: center; width: 2rem; height: 2rem;
  border-radius: 9999px; background: var(--kleur-primair); color: #fff;
  font-weight: 700; margin-bottom: .5rem;
}
.cv-stap h3 { font-size: 1.05rem; margin: .25rem 0; }
.cv-stap p { color: var(--tekst-secundair); margin: 0; }

/* ── Upsell: vergrendeld volledig advies ─────────────────────────── */
.cv-slot {
  border: 1px dashed var(--kleur-link);
  background: var(--kleur-link-licht);
  border-radius: var(--radius-card);
  padding: 1.25rem;
  margin: 1rem 0 1.5rem;
  text-align: center;
}
.cv-slot p { margin: 0 0 .75rem; }
.cv-slot code { word-break: break-all; }

/* ── Laad-overlay tijdens de analyse ─────────────────────────────── */
.cv-laden {
  position: fixed; inset: 0; z-index: 80;
  background: rgba(17, 24, 39, .55);
  display: flex; align-items: center; justify-content: center;
}
.cv-laden[hidden] { display: none; }
.cv-laden__box {
  background: var(--achtergrond-card); border-radius: var(--radius-card);
  padding: 2rem; text-align: center; box-shadow: var(--shadow-card-hover); max-width: 22rem;
}
.cv-spinner {
  width: 2.5rem; height: 2.5rem; margin: 0 auto 1rem;
  border: 3px solid var(--border-standaard); border-top-color: var(--kleur-primair);
  border-radius: 9999px; animation: cv-draai .8s linear infinite;
}
@keyframes cv-draai { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .cv-spinner { animation: none; } }

/* ── Gericht advies: modus-keuze + beroep-veld ───────────────────── */
.cv-modus {
  border: 1px solid var(--border-standaard); border-radius: var(--radius-knop);
  padding: .75rem 1rem; display: flex; gap: 1.5rem; flex-wrap: wrap; align-items: center;
}
.cv-modus legend { padding: 0 .4rem; }
.cv-radio { display: inline-flex; align-items: center; gap: .4rem; font-weight: 600; cursor: pointer; }
.cv-input {
  width: 100%; padding: .75rem; border: 1px solid var(--border-standaard);
  border-radius: var(--radius-knop); font: inherit;
}
.cv-input:focus { outline: 2px solid var(--border-focus-primair); outline-offset: 1px; }
[data-modus][hidden] { display: none; }
.cv-doel { text-align: center; margin: 0 0 .75rem; }

/* ── Herkend-beroep-kaart: crosslink naar gids + ecosysteem (synthese) ─ */
.cv-beroep-kaart {
  border: 1px solid var(--border-standaard); border-left: 4px solid var(--kleur-primair);
  border-radius: var(--radius-card); padding: 1.1rem 1.25rem; margin: 1.5rem 0;
  background: var(--achtergrond-card);
}
.cv-beroep-kaart__kop { display: flex; align-items: center; gap: .75rem; }
.cv-beroep-kaart__icoon { font-size: 1.6rem; line-height: 1; }
.cv-beroep-kaart__label {
  margin: 0; font-size: .72rem; text-transform: uppercase; letter-spacing: .05em;
  color: var(--tekst-meta);
}
.cv-beroep-kaart__naam {
  margin: 0; font-size: 1.25rem; font-weight: 700; font-family: Poppins, sans-serif;
  text-transform: capitalize; line-height: 1.2;
}
.cv-beroep-kaart__intro { color: var(--tekst-secundair); margin: .75rem 0 0; }
.cv-beroep-kaart__acties { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
