/* =========================================================
   PAT Motors — Page Contact / Présentation Privée
   ========================================================= */

/* --- HERO --- */
.contact-hero {
  position: relative;
  padding: 160px 0 100px;
  overflow: hidden;
  text-align: center;
}

.contact-hero__bg {
  position: absolute;
  inset: 0;
}

.contact-hero__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.4) brightness(0.35);
}

.contact-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,13,10,0.85) 0%, rgba(15,13,10,0.45) 60%, transparent 100%);
}

.contact-hero .container { position: relative; z-index: 2; }

.contact-hero__content { max-width: 700px; margin: 0 auto; }

.contact-hero__tag {
  justify-content: center;
  color: var(--or);
  margin-bottom: 24px;
}

.contact-hero__tag::before { background: var(--or); }

.contact-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 6vw, 5rem);
  font-weight: 300;
  color: var(--blanc);
  line-height: 1.1;
  margin-bottom: 24px;
}

.contact-hero__title em {
  color: var(--rouge);
  font-style: italic;
}

.contact-hero__subtitle {
  font-size: var(--text-md);
  color: rgba(255,255,255,0.5);
  line-height: 1.8;
}

@media (max-width: 768px) {
  .contact-hero { padding: 120px 0 64px; }
  .contact-hero__title { font-size: clamp(2rem, 8vw, 3rem); }
  .contact-hero__subtitle { font-size: var(--text-base); }
}

@media (max-width: 640px) {
  .contact-hero { padding: 100px 0 48px; }
}


/* --- LAYOUT PRINCIPAL --- */
.contact-main { padding: var(--section-py) 0; }

.contact-layout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 80px;
  align-items: start;
}

@media (max-width: 1100px) {
  .contact-layout { grid-template-columns: 1fr; gap: 60px; }
}


/* --- FORMULAIRE --- */
.contact-form-header { margin-bottom: 40px; }

.contact-form-title {
  font-family: var(--font-display);
  font-size: clamp(1.625rem, 3.5vw, 2.75rem);
  font-weight: 300;
  color: var(--noir);
  line-height: 1.15;
  margin-bottom: 16px;
}

.contact-form-title em { color: var(--rouge); font-style: italic; }

.contact-form-intro {
  font-size: var(--text-base);
  color: var(--gris-texte);
  line-height: 1.75;
  max-width: 500px;
}

/* Champs */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

.form-group { margin-bottom: 20px; }
.form-row .form-group { margin-bottom: 0; }

.form-label {
  display: block;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gris-texte);
  margin-bottom: 8px;
}

.form-label span { color: var(--rouge); }

.form-input {
  width: 100%;
  padding: 14px 18px;
  background: var(--blanc);
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--noir);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  -webkit-appearance: none;
}

.form-input:focus {
  border-color: var(--rouge);
  box-shadow: 0 0 0 3px rgba(245,16,28,0.08);
}

.form-textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.6;
}

input[type="date"].form-input {
  cursor: pointer;
  color: var(--gris-texte);
}

/* Consentement */
.form-consent { margin-bottom: 28px; }

.form-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--gris-texte);
  line-height: 1.6;
}

.form-checkbox-label input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}

.form-checkbox-custom {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border: 1px solid rgba(0,0,0,0.2);
  border-radius: var(--radius-sm);
  background: var(--blanc);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
  transition: background 0.2s, border-color 0.2s;
}

.form-checkbox-label input:checked + .form-checkbox-custom {
  background: var(--rouge);
  border-color: var(--rouge);
}

.form-checkbox-label input:checked + .form-checkbox-custom::after {
  content: '';
  width: 9px; height: 5px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translateY(-1px);
}

/* Bouton submit */
.form-submit__btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 40px;
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  width: 100%;
  justify-content: center;
  margin-bottom: 16px;
}

.form-submit__btn svg {
  width: 16px; height: 16px;
  stroke: currentColor;
  fill: none;
  flex-shrink: 0;
}

.form-submit__note {
  font-size: var(--text-xs);
  color: var(--gris-texte);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}

.form-wa-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #25d366;
  font-weight: 700;
  text-decoration: none;
  transition: opacity 0.2s;
}

.form-wa-link:hover { opacity: 0.75; }

.form-wa-link svg { width: 16px; height: 16px; fill: #25d366; }

/* Messages feedback */
.form-success {
  padding: 16px 20px;
  background: rgba(22,163,74,0.08);
  border: 1px solid rgba(22,163,74,0.25);
  border-radius: var(--radius-sm);
  color: #15803d;
  font-size: var(--text-base);
  font-weight: 500;
  margin-bottom: 24px;
  line-height: 1.6;
}

.form-error {
  padding: 16px 20px;
  background: rgba(245,16,28,0.06);
  border: 1px solid rgba(245,16,28,0.2);
  border-radius: var(--radius-sm);
  color: var(--rouge-sombre);
  font-size: var(--text-base);
  margin-bottom: 24px;
  line-height: 1.6;
}

@media (max-width: 640px) {
  .form-row { grid-template-columns: 1fr; }
}


/* --- ASIDE SHOWROOM --- */
.contact-showroom-card {
  background: var(--noir);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-bottom: 24px;
}

.contact-showroom-card__header {
  background: var(--rouge);
  padding: 28px 28px 24px;
}

.contact-aside__label {
  display: block;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-bottom: 8px;
}

.contact-aside__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--blanc);
  line-height: 1.25;
}

.contact-aside__title span {
  font-size: 0.875rem;
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: 0.05em;
  opacity: 0.75;
  display: block;
  margin-top: 4px;
}

.contact-showroom-card__details {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.contact-info-item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.contact-info-item svg {
  width: 16px; height: 16px;
  stroke: var(--or);
  fill: none;
  flex-shrink: 0;
  margin-top: 2px;
}

.contact-info-item strong {
  display: block;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
  margin-bottom: 4px;
}

.contact-info-item span {
  font-size: var(--text-base);
  color: rgba(255,255,255,0.65);
  line-height: 1.65;
}

.contact-info-item a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}

.contact-info-item a:hover { color: var(--or); }

/* Promesse */
.contact-promise {
  background: var(--blanc);
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: var(--radius-sm);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.contact-promise__item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: var(--text-sm);
  color: var(--gris-texte);
  font-weight: 500;
}

.contact-promise__item svg {
  width: 14px; height: 14px;
  stroke: var(--rouge);
  fill: none;
  flex-shrink: 0;
}
