/* ─── GETA — Verticales v3 ───────────────────────────────────────────────
   Composants partagés (transport · location · pièces) portant le système
   dirA2 du pneumatique. À charger APRÈS pneumatique-home.css, dans un
   conteneur `.dirA2` pour hériter des tokens (--navy/--blue/--sky/--paper…). */

/* ── Hero verticale : héro dirA2 sombre + photo de fond masquée ── */
.dirA2-vertical .v3v-hero { padding: 96px 0 120px; }
.v3v-hero-photo {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  opacity: 0.24;
  mask-image: linear-gradient(90deg, transparent, #000 26%, #000 74%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 26%, #000 74%, transparent);
}
/* Héro verticale centré : le contenu occupe toute la largeur du héro */
.v3v-hero-inner { position: relative; z-index: 1; max-width: 1080px; margin: 0 auto; text-align: center; }
.v3v-hero .dirA2-eyebrow { font-size: 14.5px; padding: 8px 18px 8px 16px; letter-spacing: 0.05em; }
.v3v-hero .dirA2-h1 { font-size: clamp(46px, 6.4vw, 88px); }
.v3v-hero .dirA2-lead { font-size: 19.5px; max-width: 660px; margin-left: auto; margin-right: auto; }
.v3v-hero .v3v-hero-cta { justify-content: center; }
.v3v-hero .dirA2-stats { justify-content: center; flex-wrap: wrap; gap: 48px; }
.v3v-hero .dirA2-stats > div { align-items: center; text-align: center; }
/* Logo sous-marque (GETA …TRANSPORT/LOCATION/PIÈCES) : multicolore, conçu pour
   fond clair → posé sur une plaque claire pour rester lisible sur le héro sombre. */
.v3v-hero-logo {
  height: 152px; width: auto; margin-bottom: 32px; display: inline-block;
  background: rgba(255,255,255,0.96); padding: 9px 16px; border-radius: 20px;
  box-shadow: 0 16px 42px rgba(10,16,36,0.32), 0 1px 0 rgba(255,255,255,0.6) inset;
}
/* Pièces : héro élargi (la console finder occupe plus d'espace horizontal) */
.v3v-hero-wide { max-width: 1180px; }
.v3v-hero-wide .dirA2-h1-accent { white-space: nowrap; }
.v3v-hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }

/* ── Grille de cartes (services, atouts, véhicules) ── */
.v3v-grid {
  display: grid; gap: 22px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.v3v-grid-4 { grid-template-columns: repeat(4, 1fr); }
.v3v-grid-3 { grid-template-columns: repeat(3, 1fr); }

/* ── Carte verticale ── */
.v3v-card {
  display: flex; flex-direction: column; gap: 12px;
  background: white; border: 1px solid var(--line); border-radius: 18px;
  padding: 26px; height: 100%;
  transition: transform 0.4s cubic-bezier(0.16,1,0.3,1), box-shadow 0.4s, border-color 0.4s;
}
.v3v-card:hover { transform: translateY(-4px); border-color: rgba(45,123,168,0.4); box-shadow: 0 24px 56px rgba(20,33,61,0.13); }
.v3v-card-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: 14px;
  background: linear-gradient(135deg, rgba(45,123,168,0.12), rgba(74,163,217,0.18));
  color: var(--blue); font-size: 22px;
}
.v3v-card h3 { font-size: 19px; }
.v3v-card p { font-size: 14.5px; }
.v3v-card-foot { margin-top: auto; padding-top: 8px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.v3v-card-meta { font-size: 13px; color: var(--muted); display: inline-flex; align-items: center; gap: 6px; }
.v3v-card-link { font-size: 14px; font-weight: 600; color: var(--blue); display: inline-flex; align-items: center; gap: 6px; transition: gap 0.2s; }
.v3v-card:hover .v3v-card-link { gap: 10px; }
.v3v-card-tag { align-self: flex-start; font-size: 11px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--blue); background: rgba(45,123,168,0.1); padding: 4px 10px; border-radius: 999px; }

/* ── Carte avec photo (véhicules location) ── */
.v3v-card-photo {
  position: relative; height: 190px; overflow: hidden;
  background: linear-gradient(135deg, var(--navy-2), var(--navy));
}
.v3v-card-photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.5s cubic-bezier(0.16,1,0.3,1);
}
.v3v-card:hover .v3v-card-photo img { transform: scale(1.05); }
.v3v-card-photo-ph {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 2.4rem; color: var(--sky); opacity: 0.4;
}
.v3v-card-price {
  position: absolute; top: 12px; right: 12px;
  background: var(--sky); color: var(--navy); font-weight: 700; font-size: 13px;
  padding: 5px 11px; border-radius: 999px; box-shadow: 0 6px 16px rgba(20,33,61,0.25);
}
.v3v-card-pad { display: flex; flex-direction: column; gap: 10px; padding: 22px; flex: 1; }
.v3v-card-specs { display: flex; flex-wrap: wrap; gap: 8px; }
.v3v-card-specs span {
  font-size: 12.5px; color: var(--muted); background: var(--paper-2);
  border: 1px solid var(--line); border-radius: 8px; padding: 4px 10px;
  display: inline-flex; align-items: center; gap: 5px;
}

/* ── Numéro d'étape (réutilise .v3v-card-icon, sur fond sombre) ── */
.v3v-card-num { font-weight: 800; font-size: 24px; font-family: var(--font-display, inherit); }

/* ── Atout (centré, icône ronde) ── */
.v3v-feature { text-align: center; padding: 30px 22px; }
.v3v-feature .v3v-card-icon { margin: 0 auto 16px; width: 64px; height: 64px; border-radius: 50%; font-size: 26px; }

/* ── Atout éditorial (sans pastille : grand numéro + filet d'accent) ── */
.v3v-feature-ed { text-align: left; padding: 28px 24px; }
.v3v-feature-ed .v3v-feature-no {
  font-family: 'Newsreader', Georgia, serif; font-style: italic; font-weight: 600;
  font-size: 30px; line-height: 1; color: var(--blue); display: block; margin-bottom: 4px;
}
.v3v-feature-ed .v3v-feature-no::after {
  content: ''; display: block; width: 34px; height: 2px; background: var(--blue);
  margin-top: 14px; border-radius: 2px; transition: width 0.4s cubic-bezier(0.16,1,0.3,1);
}
.v3v-feature-ed:hover .v3v-feature-no::after { width: 56px; }
.v3v-feature-ed h3 { font-size: 17.5px; margin-top: 16px; }
.v3v-dark .v3v-feature-ed .v3v-feature-no { color: var(--sky); }
.v3v-dark .v3v-feature-ed .v3v-feature-no::after { background: var(--sky); }

/* ── Section scindée image + texte (flotte) ── */
.v3v-split { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: center; }
.v3v-split-media img { width: 100%; height: 380px; object-fit: cover; border-radius: 22px; border: 1px solid var(--line); }
.v3v-mini-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 24px; }
.v3v-mini {
  display: flex; align-items: center; gap: 13px;
  background: var(--paper); border: 1px solid var(--line); border-radius: 13px; padding: 13px 15px;
}
.v3v-mini .v3v-card-icon { width: 42px; height: 42px; border-radius: 11px; font-size: 18px; flex-shrink: 0; }
.v3v-mini strong { font-size: 14.5px; color: var(--navy); display: block; }
.v3v-mini span { font-size: 12.5px; color: var(--muted); }

/* ── Section sombre (couverture) ── */
.v3v-dark { background: linear-gradient(180deg, var(--navy-2) 0%, var(--navy) 100%); }
.v3v-dark h2, .v3v-dark h3 { color: white; }
.v3v-dark p { color: rgba(255,255,255,0.72); }
.v3v-dark .dirA2-eyebrow { color: var(--sky-soft); background: rgba(74,163,217,0.12); border-color: rgba(74,163,217,0.3); }
/* les cartes blanches flottant sur la section sombre gardent leur texte foncé */
.v3v-dark .v3v-card h3 { color: var(--navy); }
.v3v-dark .v3v-card p { color: var(--muted); }
.v3v-chips { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin: 26px 0; }
.v3v-chip {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px; padding: 13px 16px; color: white; font-weight: 600; font-size: 14px;
}
.v3v-chip span.flag { font-size: 20px; }

/* ── Bande CTA finale ── */
.v3v-cta-band {
  background: linear-gradient(135deg, var(--ink) 0%, var(--navy-2) 100%);
  border-radius: 28px; padding: 48px 52px;
  display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.v3v-cta-band h2 { color: white; font-size: clamp(26px, 3vw, 36px); }
.v3v-cta-band p { color: rgba(255,255,255,0.7); margin-top: 8px; max-width: 460px; }
.v3v-cta-actions { display: flex; gap: 14px; flex-wrap: wrap; }
/* sur la bande sombre, le bouton primaire navy→blue manque de contraste :
   on l'éclaire en blue→sky pour qu'il ressorte */
.v3v-cta-band .dirA2-btn-primary { background: linear-gradient(135deg, var(--blue) 0%, var(--sky) 100%); }
.v3v-cta-band .dirA2-btn-primary::before { background: linear-gradient(135deg, var(--sky) 0%, white 120%); }

/* ── Finder pièces : console verre (plaque / VIN / référence) sur héro sombre ── */
.v3v-pf { text-align: left; max-width: 920px; margin-left: auto; margin-right: auto; }
.v3v-pf-form + .v3v-pf-form { margin-top: 0; }
.v3v-pf-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--navy); margin-bottom: 10px;
}
.v3v-pf-label i { color: var(--blue); }
.v3v-pf-row { display: flex; gap: 12px; align-items: stretch; }
.v3v-pf-ig {
  flex: 1; display: flex; align-items: stretch; min-width: 0;
  background: white; border: 1px solid var(--line-strong); border-radius: 10px; overflow: hidden;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.v3v-pf-ig:focus-within { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(45,123,168,0.15); }
.v3v-pf-ig > i { display: flex; align-items: center; padding: 0 13px; color: var(--blue); font-size: 18px; }
.v3v-pf-ig input {
  flex: 1; min-width: 0; border: none; background: transparent; outline: none;
  padding: 13px 14px 13px 0; font-size: 16px; font-weight: 600; color: var(--navy);
}
.v3v-pf-ig input::placeholder { color: var(--muted); font-weight: 500; letter-spacing: normal; }
.v3v-pf-flag {
  display: flex; align-items: center; padding: 0 14px;
  background: #003399; color: #fff; font-weight: 700; font-size: 15px;
}
.v3v-pf-plate input { text-align: center; text-transform: uppercase; letter-spacing: 3px; font-size: 19px; }
.v3v-pf-row .dirA2-btn-primary,
.v3v-pf-row .dirA2-btn-outline-light { white-space: nowrap; }
.v3v-pf-hint { font-size: 12.5px; color: var(--muted); margin-top: 9px; }
.v3v-pf-hint strong { color: var(--navy); }
.v3v-pf-alert {
  margin-top: 10px; font-size: 13.5px; color: #8a5a00;
  background: rgba(255,193,7,0.16); border: 1px solid rgba(255,193,7,0.4);
  border-radius: 9px; padding: 9px 13px; display: inline-flex; align-items: center; gap: 7px;
}
.v3v-pf-or { display: flex; align-items: center; gap: 14px; margin: 16px 0; }
.v3v-pf-or::before, .v3v-pf-or::after { content: ''; flex: 1; height: 1px; background: var(--line); }
.v3v-pf-or span { font-size: 12px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; }
.v3v-pf-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.v3v-pf-grid2 .dirA2-btn-outline-light,
.v3v-pf-grid2 .dirA2-btn-mini { margin-top: 10px; }

/* ── Sélecteur de véhicule (marque / modèle / motorisation) ── */
.v3v-vselect { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 12px; align-items: end; max-width: 920px; margin: 0 auto; }
.v3v-vselect .dirA2-field { flex: none; }
.v3v-vselect .dirA2-btn-primary { height: 48px; }

/* ── Marques équipementiers (puces logo) ── */
.v3v-brands { display: flex; flex-wrap: wrap; gap: 10px; margin: 22px 0 28px; }
.v3v-brand {
  display: inline-flex; align-items: center; height: 56px; padding: 0 20px;
  background: white; border: 1px solid var(--line); border-radius: 12px;
  font-weight: 700; color: var(--muted); font-size: 14px;
  transition: border-color 0.2s, color 0.2s, transform 0.2s;
}
.v3v-brand:hover { border-color: var(--blue); color: var(--blue); transform: translateY(-2px); }

/* ── Bande de logos marques (réutilisable : équipementiers, constructeurs) ── */
.v3v-logos { display: flex; flex-wrap: wrap; gap: 14px; margin: 22px 0 28px; }
.v3v-logos-center { justify-content: center; }
.v3v-logo {
  display: inline-flex; align-items: center; justify-content: center;
  height: 70px; min-width: 138px; padding: 0 24px;
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  transition: box-shadow 0.22s, transform 0.22s, border-color 0.22s;
}
.v3v-logo img {
  max-height: 34px; max-width: 110px; width: auto; object-fit: contain;
  filter: grayscale(1); opacity: 0.7; transition: filter 0.25s, opacity 0.25s;
}
.v3v-logo:hover {
  transform: translateY(-3px); border-color: transparent;
  box-shadow: 0 10px 26px rgba(10, 16, 36, 0.12);
}
.v3v-logo:hover img { filter: grayscale(0); opacity: 1; }
/* version compacte dans une colonne de split (équipementiers) */
.v3v-split .v3v-logos .v3v-logo { height: 60px; min-width: 116px; padding: 0 18px; }
.v3v-split .v3v-logos .v3v-logo img { max-height: 28px; max-width: 92px; }

/* ── Responsive ── */
@media (max-width: 960px) {
  .v3v-grid-4, .v3v-grid-3 { grid-template-columns: 1fr 1fr; }
  .v3v-split { grid-template-columns: 1fr; gap: 30px; }
  .v3v-split-media img { height: 300px; }
  .v3v-vselect { grid-template-columns: 1fr 1fr; }
  .v3v-vselect .dirA2-btn-primary { grid-column: 1 / -1; width: 100%; }
}
@media (max-width: 600px) {
  .dirA2-vertical .v3v-hero { padding: 64px 0 84px; }
  .v3v-hero-logo { height: 98px; padding: 7px 12px; border-radius: 16px; }
  .v3v-hero .dirA2-stats { gap: 22px 30px; }
  .v3v-grid-4, .v3v-grid-3, .v3v-grid { grid-template-columns: 1fr; }
  .v3v-chips { grid-template-columns: 1fr 1fr; }
  .v3v-mini-grid { grid-template-columns: 1fr; }
  .v3v-cta-band { padding: 32px 26px; }
  .v3v-hero-cta .dirA2-btn-primary, .v3v-hero-cta .dirA2-btn-outline-light { flex: 1; justify-content: center; }
  .v3v-pf-row { flex-direction: column; }
  .v3v-pf-row .dirA2-btn-primary { width: 100%; justify-content: center; height: 48px; }
  .v3v-pf-grid2 { grid-template-columns: 1fr; }
  .v3v-vselect { grid-template-columns: 1fr; }
}

/* ============================================================
   Coming-soon preview — verticals still in construction.
   Home pages stay visible + scrollable; all in-page links and
   form controls are inert so users can't reach unfinished pages.
   ============================================================ */
.dirA2-preview { position: relative; }

/* ── Strong "griser" : whole vertical reads as a dimmed preview ──────────
   Hero kept a touch more alive so the page still gives envie. */
.dirA2-preview > :not(.v3v-coming-overlay) { filter: grayscale(0.62) opacity(0.8); }
.dirA2-preview > section.dirA2-hero { filter: grayscale(0.4) opacity(0.9); }

/* Disable every in-page interaction (scroll still works) */
.dirA2-preview a,
.dirA2-preview button,
.dirA2-preview input,
.dirA2-preview select,
.dirA2-preview textarea,
.dirA2-preview label,
.dirA2-preview form { pointer-events: none !important; cursor: default; }
.dirA2-preview .dirA2-btn-primary,
.dirA2-preview .dirA2-btn-outline-light,
.dirA2-preview .dirA2-btn-mini,
.dirA2-preview .v3v-card-link { opacity: 0.7; }

/* ── Giant fixed diagonal watermark — stays centred on screen while the
   page scrolls underneath. pointer-events:none so the navbar stays usable
   and the page keeps scrolling. ──────────────────────────────────────── */
.v3v-coming-overlay {
  position: fixed; inset: 0; z-index: 1045;
  overflow: hidden; pointer-events: none;
}
.v3v-coming-band {
  position: absolute; top: 50%; left: 50%;
  width: 160%; padding: 30px 0;
  transform: translate(-50%, -50%) rotate(-16deg);
  background: linear-gradient(90deg, rgba(20,33,61,0.97), rgba(29,47,84,0.97));
  border-top: 3px solid var(--sky); border-bottom: 3px solid var(--sky);
  box-shadow: 0 28px 80px rgba(10,16,36,0.45);
  text-align: center; color: #fff;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.v3v-coming-title {
  font-weight: 800; text-transform: uppercase;
  font-size: clamp(34px, 7vw, 88px); line-height: 0.95;
  letter-spacing: 0.06em; color: #fff;
  text-shadow: 0 3px 18px rgba(0,0,0,0.35);
}
.v3v-coming-title .v3v-coming-accent { color: var(--sky); }
.v3v-coming-sub {
  font-weight: 600; font-size: clamp(13px, 1.6vw, 18px);
  letter-spacing: 0.03em; color: rgba(255,255,255,0.92);
  max-width: 90%;
}
.v3v-coming-pulse {
  display: inline-block; width: 11px; height: 11px; border-radius: 50%;
  background: var(--sky); margin-right: 8px; vertical-align: middle;
  box-shadow: 0 0 0 0 rgba(74,163,217,0.7);
  animation: v3vPulse 2s infinite;
}
@keyframes v3vPulse {
  0%   { box-shadow: 0 0 0 0 rgba(74,163,217,0.65); }
  70%  { box-shadow: 0 0 0 14px rgba(74,163,217,0); }
  100% { box-shadow: 0 0 0 0 rgba(74,163,217,0); }
}
@media (prefers-reduced-motion: reduce) { .v3v-coming-pulse { animation: none; } }

@media (max-width: 600px) {
  .v3v-coming-band { width: 200%; padding: 22px 0; transform: translate(-50%, -50%) rotate(-18deg); }
}
