/* =========================================================================
   OCDM · V7 — Pro & chaleureux (polices V4 + accent bleu glacier)
   ------------------------------------------------------------------------
   Direction finalisée :
       • Fraunces (display, italic accents)
       • Nunito Sans (corps + UI)
       • Caveat (hand, kickers + polaroid captions)
       • Accent unique : bleu glacier #b8d0db (remplace le jaune mimosa)
   Structure, ombres, bordures, espacements et rotations identiques à V6.
   ========================================================================= */

/* ──────────────────────────────────────────────────────────────
   POLICES — Fraunces (display) + Nunito Sans (corps + UI)
   ────────────────────────────────────────────────────────────── */
:root {
  --ocdm-font-display:   "Fraunces", "Georgia", "Times New Roman", serif;
  --ocdm-font-body:      "Nunito Sans", -apple-system, "Segoe UI", system-ui, sans-serif;
  --ocdm-font-serif:     "Fraunces", "Georgia", serif;
  --ocdm-font-hand:      "Caveat", "Kalam", cursive;
  --ocdm-font-mono:      "JetBrains Mono", ui-monospace, monospace;
}

/* ──────────────────────────────────────────────────────────────
   PALETTE — framboise + bleu glacier (#b8d0db)
   ────────────────────────────────────────────────────────────── */
:root[data-theme="framboise"] {
  --v7-blue:         #b8d0db;
  --v7-blue-soft:    #eaf3f7;
  --v7-ink:          #1f1820;
  --v7-warm-grey:    #d9c9c5;

  --ocdm-bg:                 #fdf6ee;
  --ocdm-bg-elevated:        #ffffff;
  --ocdm-bg-sunken:          #f6ebe0;

  --ocdm-text:               #2a1f24;
  --ocdm-text-strong:        var(--v7-ink);
  --ocdm-text-muted:         #6f5d63;
  --ocdm-text-subtle:        #a89aa0;

  --ocdm-border:             var(--v7-warm-grey);
  --ocdm-border-soft:        #ecdfd9;
  --ocdm-border-strong-color: var(--v7-ink);

  --ocdm-underline-color:    var(--v7-blue);
  --ocdm-underline-weight:   3px;
}

/* ──────────────────────────────────────────────────────────────
   FOND — crème avec grain papier subtil (identique V6)
   ────────────────────────────────────────────────────────────── */
body {
  font-family: "Nunito Sans", -apple-system, "Segoe UI", system-ui, sans-serif !important;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  background: var(--ocdm-bg) !important;
  background-image:
    radial-gradient(circle at 0 0, rgba(31, 24, 32, 0.035) 0.5px, transparent 0.5px),
    radial-gradient(circle at 7px 7px, rgba(31, 24, 32, 0.025) 0.5px, transparent 0.5px) !important;
  background-size: 14px 14px !important;
  color: var(--ocdm-text);
  letter-spacing: -0.005em;
}

/* ──────────────────────────────────────────────────────────────
   TITRES — Fraunces (serif), tracking et weights identiques V6
   ────────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: "Fraunces", "Georgia", serif !important;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--v7-ink);
  line-height: 1.1;
}
h1, .h1, .page-title {
  font-size: clamp(2.5rem, 2rem + 3.2vw, 4.5rem) !important;
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.03em;
}
h2, .h2 {
  font-size: clamp(1.75rem, 1.4rem + 1.4vw, 2.5rem) !important;
  letter-spacing: -0.025em;
}
h3, .h3 {
  font-size: clamp(1.15rem, 1.1rem + 0.4vw, 1.375rem) !important;
  font-weight: 700;
  letter-spacing: -0.015em;
}
h4 { font-size: 1.05rem; font-weight: 700; letter-spacing: -0.01em; }
h5 { font-size: 0.95rem; font-weight: 700; }
h6 {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 11px;
  font-weight: 700;
}

p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--ocdm-text);
}
.lead {
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--v7-ink);
  line-height: 1.5;
}

a {
  color: var(--ocdm-framboise);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  text-decoration-color: var(--v7-blue);
  transition: all 0.18s ease;
}
a:hover {
  color: var(--ocdm-framboise-dark);
  text-decoration-color: var(--ocdm-framboise);
}

::selection {
  background: var(--v7-blue);
  color: var(--v7-ink);
}

/* ──────────────────────────────────────────────────────────────
   KICKERS — Caveat (inchangé)
   ────────────────────────────────────────────────────────────── */
.ocdm-kicker,
.ocdm-section-head__kicker,
.home-hero__scroll {
  display: inline-block;
  font-family: "Caveat", cursive !important;
  font-weight: 600 !important;
  font-size: 1.35rem !important;
  color: var(--ocdm-framboise) !important;
  letter-spacing: 0;
  text-transform: none;
  line-height: 1;
  transform: none;
  margin-bottom: 6px;
}
.ocdm-section-head__kicker::before,
.home-hero__scroll::before { display: none; }

/* ──────────────────────────────────────────────────────────────
   SOULIGNÉ — onde jaune SVG (identique V6)
   ────────────────────────────────────────────────────────────── */
.ocdm-underline {
  height: 10px;
  background: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 260 10' fill='none' stroke='%23b8d0db' stroke-width='3' stroke-linecap='round'><path d='M3 6 Q 20 1, 36 6 T 68 6 T 100 6 T 132 6 T 164 6 T 196 6 T 228 6 T 254 6'/></svg>");
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 160px;
  border: 0;
}
.ocdm-underline--lg { width: 220px; height: 12px; }

/* ──────────────────────────────────────────────────────────────
   BOUTONS — Nunito Sans, pill, ombre soft
   ────────────────────────────────────────────────────────────── */
.ocdm-btn {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
  text-transform: none;
  border-radius: 999px;
  height: 48px;
  padding: 0 22px;
  border: 1px solid var(--v7-ink);
  background: #fff;
  color: var(--v7-ink);
  box-shadow: none;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.ocdm-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(31, 24, 32, 0.12);
}
.ocdm-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(31, 24, 32, 0.12);
}
.ocdm-btn--primary {
  background: var(--ocdm-framboise);
  color: #fff !important;
  border-color: var(--ocdm-framboise);
}
.ocdm-btn--primary:hover,
.ocdm-btn--primary:focus,
.ocdm-btn--primary:active {
  background: var(--ocdm-framboise-dark);
  border-color: var(--ocdm-framboise-dark);
  color: #fff !important;
  box-shadow: 0 6px 18px rgba(201, 53, 122, 0.25);
}
.ocdm-btn--secondary {
  background: var(--v7-blue);
  color: var(--v7-ink);
  border-color: var(--v7-ink);
}
.ocdm-btn--danger {
  background: var(--ocdm-framboise);
  color: #fff;
  border-color: var(--ocdm-framboise);
}
.ocdm-btn--ghost {
  background: transparent;
  border-color: transparent;
}
.ocdm-btn--ghost:hover {
  background: var(--v7-blue-soft);
  box-shadow: none;
}
.ocdm-btn--lg { height: 54px; padding: 0 28px; font-size: 16px; }
.ocdm-btn--sm { height: 36px; padding: 0 14px; font-size: 13px; }

/* ──────────────────────────────────────────────────────────────
   CHIPS / BADGES
   ────────────────────────────────────────────────────────────── */
.ocdm-chip {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 600;
  border-radius: 999px;
  border: 1px solid var(--ocdm-border-soft);
  background: #fff;
  color: var(--ocdm-text);
  padding: 3px 11px;
  font-size: 12px;
  text-transform: none;
  letter-spacing: 0;
}
.ocdm-chip--ocre   { background: var(--ocdm-framboise-soft); border-color: transparent; color: var(--ocdm-framboise-dark); }
.ocdm-chip--sauge  { background: rgba(94, 195, 138, 0.15); border-color: transparent; color: #2d6a48; }
.ocdm-chip--brique { background: var(--ocdm-framboise); color: #fff; border-color: var(--ocdm-framboise); }

.ocdm-badge {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 700;
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 10.5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid var(--v7-ink);
  background: var(--v7-blue);
  color: var(--v7-ink);
}
.ocdm-badge--success { background: rgba(94, 195, 138, 0.9); color: var(--v7-ink); border-color: transparent; }
.ocdm-badge--danger  { background: var(--ocdm-framboise); color: #fff; border-color: var(--ocdm-framboise); }
.ocdm-badge--info    { background: #fff; color: var(--v7-ink); }
.ocdm-badge--warning { background: var(--v7-blue); color: var(--v7-ink); }
.ocdm-badge--neutral { background: #fff; color: var(--ocdm-text-muted); border-color: var(--ocdm-border); }

/* ──────────────────────────────────────────────────────────────
   CARDS ANIMAL — sticker conservé, name en Fraunces (h3)
   ────────────────────────────────────────────────────────────── */
.ocdm-card-animal {
  background: #fff !important;
  border: 1.5px solid var(--v7-ink) !important;
  border-radius: 14px !important;
  padding: 10px !important;
  box-shadow: 2px 2px 0 var(--v7-ink);
  transform: rotate(0);
  transition: transform 200ms ease, box-shadow 200ms ease;
}
.ocdm-card-animal:hover {
  transform: translate(-2px, -2px) !important;
  box-shadow: 4px 4px 0 var(--v7-ink);
}
.ocdm-card-animal__media {
  border-radius: 10px !important;
  aspect-ratio: 4 / 4;
  overflow: hidden;
  background: var(--v7-blue-soft);
}
.ocdm-card-animal__media .ocdm-photo-placeholder {
  aspect-ratio: 1 / 1;
  background: var(--v7-blue-soft);
}
.ocdm-card-animal__name {
  font-family: "Fraunces", "Georgia", serif !important;
  font-weight: 700 !important;
  margin-top: 10px !important;
  font-size: 1.05rem;
  letter-spacing: -0.015em;
}
.ocdm-card-animal__meta {
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-weight: 500;
  font-size: 12px;
  color: var(--ocdm-text-muted);
  letter-spacing: 0;
}

/* ──────────────────────────────────────────────────────────────
   POLAROIDS — V1-style avec ombre soft (identique V6)
   ────────────────────────────────────────────────────────────── */
.ocdm-polaroid {
  background: #fff !important;
  border: 1px solid var(--ocdm-border) !important;
  padding: 10px 10px 18px;
  box-shadow: 0 6px 20px rgba(31, 24, 32, 0.10), 0 1px 3px rgba(31, 24, 32, 0.08) !important;
  --ocdm-rotate: -2deg;
}
.ocdm-polaroid--right { --ocdm-rotate: 2deg; }
.ocdm-polaroid--left  { --ocdm-rotate: -2deg; }
.ocdm-polaroid:hover {
  transform: rotate(0deg) translate(-2px, -2px) !important;
  box-shadow: 0 10px 28px rgba(31, 24, 32, 0.14), 0 2px 4px rgba(31, 24, 32, 0.08) !important;
}
.ocdm-polaroid__caption {
  font-family: "Caveat", cursive !important;
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--ocdm-framboise);
}
.ocdm-photo-placeholder {
  background: var(--ocdm-bg-sunken);
  border-radius: 6px;
}

/* ──────────────────────────────────────────────────────────────
   HERO — surligneur jaune derrière <em> en Fraunces italic
   ────────────────────────────────────────────────────────────── */
.home-hero__title {
  font-family: "Fraunces", "Georgia", serif !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  line-height: 1 !important;
}
.home-hero__title em {
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic !important;
  font-weight: 600 !important;
  color: var(--ocdm-framboise) !important;
  font-variation-settings: "opsz" 144;
  background:
    linear-gradient(180deg, transparent 70%, var(--v7-blue) 70%, var(--v7-blue) 94%, transparent 94%);
  padding: 0 0.12em;
}

/* Badge "247" — yellow sticker, rotation discrète -4° */
.home-hero__badge {
  background: var(--v7-blue) !important;
  border: 1.5px solid var(--v7-ink) !important;
  width: 124px;
  height: 124px;
  box-shadow: 3px 3px 0 var(--v7-ink) !important;
  transform: rotate(-4deg) !important;
}
.home-hero__badge-num {
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic;
  font-weight: 700;
  color: var(--v7-ink) !important;
  font-size: 2.25rem;
  font-variation-settings: "opsz" 144;
}
.home-hero__badge-text {
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic;
  font-weight: 700;
  color: var(--v7-ink) !important;
  font-size: 1.05rem;
  line-height: 1.05;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  padding: 0 0.5rem;
  text-align: center;
}
.home-hero__badge-label {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  color: var(--v7-ink) !important;
  font-size: 12px !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ──────────────────────────────────────────────────────────────
   BANDEAU URGENT — framboise plein, ombre soft, label jaune pill
   ────────────────────────────────────────────────────────────── */
.ocdm-urgent {
  background: var(--ocdm-framboise) !important;
  border: 0 !important;
  border-radius: 14px !important;
  box-shadow: 0 6px 18px rgba(201, 53, 122, 0.22);
  padding: 14px 22px !important;
}
.ocdm-urgent__label {
  background: var(--v7-blue) !important;
  color: var(--v7-ink) !important;
  border: 0;
  border-radius: 999px !important;
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 700;
  font-size: 11px !important;
  letter-spacing: 0.08em !important;
  padding: 4px 10px !important;
  text-transform: uppercase;
}
.ocdm-urgent__label::before { content: none !important; }
.ocdm-urgent__text {
  color: #fff !important;
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 500 !important;
  font-size: 1rem;
}
.ocdm-urgent__text strong { color: var(--v7-blue-soft); font-weight: 700; }

/* ──────────────────────────────────────────────────────────────
   STATS — cards blanches, ombre soft, Fraunces italic numbers
   ────────────────────────────────────────────────────────────── */
.ocdm-stats {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  gap: 16px !important;
}
.ocdm-stats__item {
  background: #fff;
  border: 1px solid var(--ocdm-border);
  border-radius: 14px;
  box-shadow: 0 2px 8px rgba(31, 24, 32, 0.05);
  padding: 22px 20px;
  transform: none;
}
.ocdm-stats__item + .ocdm-stats__item::before { display: none; }
.ocdm-stats__number {
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic;
  font-weight: 700 !important;
  color: var(--ocdm-framboise) !important;
  line-height: 1;
  font-size: clamp(2.25rem, 1.8rem + 1.3vw, 3rem) !important;
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.02em;
}
.ocdm-stats__label {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 500;
  font-size: 13px;
  color: var(--ocdm-text-muted);
  margin-top: 6px;
  letter-spacing: 0;
  text-transform: none;
  line-height: 1.3;
}
.ocdm-stats__item .ocdm-stats__label::before { content: none !important; }

/* ──────────────────────────────────────────────────────────────
   STEPS — cards blanches, Fraunces italic numbers framboise
   ────────────────────────────────────────────────────────────── */
.ocdm-step {
  background: #fff !important;
  border: 1px solid var(--ocdm-border) !important;
  border-radius: 14px !important;
  box-shadow: 0 2px 8px rgba(31, 24, 32, 0.05);
  padding: 22px !important;
}
.ocdm-step__number {
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic;
  font-weight: 700 !important;
  font-size: 2.5rem !important;
  color: var(--ocdm-framboise) !important;
  line-height: 1;
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.02em;
}
.ocdm-step__title {
  font-family: "Fraunces", "Georgia", serif !important;
  font-weight: 700;
  font-size: 1.05rem;
  margin-top: 6px !important;
  color: var(--v7-ink);
  letter-spacing: -0.015em;
}
.ocdm-step__desc {
  color: var(--ocdm-text-muted);
  opacity: 1;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.5;
}

/* Section "Comment adopter" — fond crème */
.home-howto {
  background: var(--ocdm-bg-sunken) !important;
}

/* ──────────────────────────────────────────────────────────────
   SECTION HEADERS
   ────────────────────────────────────────────────────────────── */
.ocdm-section-head__title {
  font-family: "Fraunces", "Georgia", serif !important;
  font-weight: 800;
  letter-spacing: -0.025em;
}
.ocdm-section-head__link {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 600;
  font-size: 13px;
  background: transparent;
  color: var(--ocdm-framboise);
  padding: 6px 0;
  border-radius: 0;
  border: 0;
  text-decoration: underline;
  text-decoration-color: var(--v7-blue);
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
  text-transform: none;
  letter-spacing: 0;
  box-shadow: none;
}
.ocdm-section-head__link:hover {
  background: transparent;
  color: var(--ocdm-framboise-dark);
  text-decoration-color: var(--ocdm-framboise);
}

/* ──────────────────────────────────────────────────────────────
   PARTNERS — chips plates, sans rotation
   ────────────────────────────────────────────────────────────── */
.ocdm-partner {
  background: #fff !important;
  border: 1px solid var(--ocdm-border) !important;
  border-radius: 999px !important;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  font-size: 13px;
  color: var(--ocdm-text-muted);
  height: 48px;
  opacity: 1;
  transform: none;
  transition: all 0.15s ease;
}
.ocdm-partner:nth-child(odd),
.ocdm-partner:nth-child(even) { transform: none; }
.ocdm-partner:hover {
  color: var(--v7-ink);
  border-color: var(--v7-ink);
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(31, 24, 32, 0.08);
}

/* ──────────────────────────────────────────────────────────────
   HEADER
   ────────────────────────────────────────────────────────────── */
.ocdm-site-header {
  background: var(--ocdm-bg) !important;
  background-image: none !important;
  border-bottom: 1px solid var(--ocdm-border) !important;
}
.ocdm-site-brand__title {
  font-family: "Fraunces", "Georgia", serif !important;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.ocdm-site-brand__sub {
  font-family: "Caveat", cursive !important;
  font-weight: 600;
  font-size: 14px !important;
  color: var(--ocdm-framboise) !important;
  text-transform: none;
  letter-spacing: 0;
}
.ocdm-site-brand__mark {
  background: var(--v7-blue) !important;
  color: var(--v7-ink) !important;
  border: 1.5px solid var(--v7-ink);
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic;
  font-weight: 700;
  font-size: 1.4rem;
  font-variation-settings: "opsz" 144;
  transform: rotate(-3deg);
  box-shadow: 2px 2px 0 var(--v7-ink);
}
.ocdm-site-nav__link {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px;
  letter-spacing: -0.01em;
}
.ocdm-site-nav__link::after {
  background: var(--v7-blue);
  height: 3px;
  border-radius: 999px;
}
.ocdm-lang-switch {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-size: 12px !important;
  font-weight: 600;
  border-radius: 999px !important;
  letter-spacing: 0 !important;
  border: 1px solid var(--ocdm-border) !important;
}

/* ──────────────────────────────────────────────────────────────
   FOOTER — charcoal warm, titres jaunes
   ────────────────────────────────────────────────────────────── */
.ocdm-site-footer {
  background: var(--v7-ink) !important;
  color: #fff;
  padding-block: 56px 28px;
}
.ocdm-site-footer__title {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 700;
  color: var(--v7-blue) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px !important;
}
.ocdm-site-footer a {
  color: rgba(255, 255, 255, 0.85);
  font-size: 14px;
}
.ocdm-site-footer a:hover { color: var(--v7-blue); }

/* ──────────────────────────────────────────────────────────────
   NEWSLETTER — fond jaune doux, ombre soft
   ────────────────────────────────────────────────────────────── */
.home-newsletter__inner {
  background: var(--v7-blue-soft) !important;
  border: 1px solid rgba(31, 24, 32, 0.08) !important;
  border-radius: 18px !important;
  box-shadow: 0 4px 16px rgba(31, 24, 32, 0.06);
  color: var(--v7-ink) !important;
}
.home-newsletter__inner h2 {
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: normal !important;
  font-weight: 800;
  color: var(--v7-ink) !important;
  letter-spacing: -0.025em;
}
.home-newsletter__inner .ocdm-kicker {
  color: var(--ocdm-framboise) !important;
}
.home-newsletter__inner p {
  color: var(--ocdm-text) !important;
  font-weight: 400;
}
.home-newsletter__form input {
  background: #fff;
  border: 1px solid var(--ocdm-border);
  border-radius: 999px;
  height: 46px;
  padding: 0 20px;
  font-family: "Nunito Sans", system-ui, sans-serif;
}
.home-newsletter__form input:focus {
  outline: 0;
  border-color: var(--ocdm-framboise);
  box-shadow: 0 0 0 3px rgba(201, 53, 122, 0.15);
}

/* ──────────────────────────────────────────────────────────────
   QUOTE — Fraunces italic, guillemet jaune
   ────────────────────────────────────────────────────────────── */
.home-quote blockquote {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic !important;
  font-weight: 500;
  color: var(--v7-ink);
  position: relative;
  padding-left: 32px;
  font-variation-settings: "opsz" 144;
}
.home-quote blockquote::before {
  content: "\201C";
  position: absolute;
  left: 0;
  top: -10px;
  display: block;
  font-family: "Fraunces", "Georgia", serif;
  font-style: italic;
  font-weight: 700;
  font-size: 4.5rem;
  line-height: 1;
  color: var(--v7-blue);
  margin-bottom: 0;
  opacity: 1;
}
.home-quote blockquote cite {
  font-family: "Caveat", cursive !important;
  font-weight: 600;
  font-size: 1.2rem !important;
  font-style: normal !important;
  color: var(--ocdm-framboise) !important;
  margin-top: 12px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  display: block;
}

blockquote {
  background: var(--ocdm-bg-elevated);
  border-left: 3px solid var(--v7-blue);
  border-radius: 0;
  padding: 16px 22px;
  font-family: "Fraunces", "Georgia", serif !important;
  font-style: italic !important;
  font-weight: 500;
  color: var(--v7-ink);
  box-shadow: none;
}
blockquote::before { display: none; }

/* ──────────────────────────────────────────────────────────────
   FORMULAIRES
   ────────────────────────────────────────────────────────────── */
input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
textarea,
select {
  border-radius: 10px;
  border: 1px solid var(--ocdm-border);
  background: #fff;
  padding: 11px 14px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-weight: 500;
}
input:focus, textarea:focus, select:focus {
  outline: 0;
  border-color: var(--ocdm-framboise);
  box-shadow: 0 0 0 3px rgba(201, 53, 122, 0.15);
}
fieldset {
  border: 1px solid var(--ocdm-border);
  border-radius: 14px;
  padding: 24px;
  box-shadow: 0 2px 8px rgba(31, 24, 32, 0.04);
  background: #fff;
}
legend {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 700;
  background: var(--v7-blue);
  border: 0;
  border-radius: 999px;
  padding: 3px 12px;
  font-size: 13px;
}
label {
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-weight: 600;
  font-size: 13px;
}
.ocdm-choice {
  border-radius: 10px !important;
  border: 1px solid var(--ocdm-border) !important;
}
.ocdm-choice:has(input:checked) {
  background: var(--v7-blue-soft) !important;
  border-color: var(--v7-ink) !important;
  color: var(--v7-ink) !important;
}

/* ──────────────────────────────────────────────────────────────
   THEME SWITCHER
   ────────────────────────────────────────────────────────────── */
.ocdm-theme-switch {
  border: 1px solid var(--ocdm-border);
  background: #fff;
  border-radius: 999px;
  box-shadow: 0 4px 12px rgba(31, 24, 32, 0.06);
}
.ocdm-theme-switch__btn {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 600;
  font-size: 12px;
  border-radius: 999px;
  text-transform: none;
  letter-spacing: 0;
}
.ocdm-theme-switch__btn[aria-pressed="true"] {
  background: var(--ocdm-framboise);
  color: #fff;
}
.ocdm-theme-switch__label {
  font-family: "Nunito Sans", system-ui, sans-serif !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px;
}

/* ──────────────────────────────────────────────────────────────
   V7 TAG — petit, discret
   ────────────────────────────────────────────────────────────── */
.v7-tag {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 999;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 600;
  background: var(--v7-blue);
  color: var(--v7-ink);
  border: 1px solid var(--v7-ink);
  border-radius: 999px;
  box-shadow: 2px 2px 0 var(--v7-ink);
  transform: rotate(-1deg);
  text-decoration: none !important;
  letter-spacing: -0.005em;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.v7-tag:hover {
  background: var(--ocdm-framboise);
  color: #fff;
  border-color: var(--ocdm-framboise);
  transform: rotate(0) translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--v7-ink);
}

.ocdm-container { max-width: 1240px; }
