/* ============================================
   ORIZON SOLS — CSS Pages internes
   À propos, Prestations, Réalisations, FAQ,
   Contact, Mentions légales
   ============================================ */

/* ══════════════════════════════════════════
   GALERIE ÉDITORIALE PREMIUM — RÉALISATIONS
   ══════════════════════════════════════════ */

/* Variables locales */
:root {
  --pf-bg:      #F6F3EE;
  --pf-navy:    #24364A;
  --pf-sand:    #C7B299;
  --pf-graphite:#3E4650;
  --pf-border:  1px solid var(--pf-navy);
  --pf-radius:  4px;
  --pf-gap:     28px;
}

.portfolio-section {
  background: var(--pf-bg);
  padding: 0 0 var(--space-4xl);
}

/* Intro */
.portfolio-intro {
  padding: var(--space-xl) 0 var(--space-lg);
}
.portfolio-intro__text {
  max-width: 64ch;
  color: var(--pf-graphite);
  font-family: 'Barlow', sans-serif;
  font-size: var(--text-base);
  line-height: 1.75;
  letter-spacing: 0.01em;
}

/* ── BLOC 1 HÉRO pleine largeur ── */
.portfolio-hero {
  margin-bottom: var(--pf-gap);
}
.pf-hero__figure {
  margin: 0;
  position: relative;
}
.pf-hero__img {
  width: 100%;
  height: 70vh;
  min-height: 420px;
  max-height: 680px;
  background-color: var(--color-navy);
  background-image: linear-gradient(145deg, var(--color-navy) 0%, var(--color-navy-dark) 100%);
  background-size: cover;
  background-position: center;
  border: var(--pf-border);
  border-left: none;
  border-right: none;
  filter: brightness(0.97) saturate(0.92);
}
.pf-hero__caption {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 14px 0 0 0;
  max-width: var(--container-max, 1200px);
  margin: 0 auto;
  padding-left: var(--space-xl);
  padding-right: var(--space-xl);
}

/* ── BLOCS DUO 2 colonnes ── */
.portfolio-duo {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: var(--pf-gap);
  margin-bottom: var(--pf-gap);
  align-items: start;
}
.portfolio-duo--reverse {
  grid-template-columns: 1fr 1.45fr;
}
.portfolio-duo--reverse .pf-duo__main { order: 2; }
.portfolio-duo--reverse .pf-duo__side  { order: 1; }

.pf-duo__main,
.pf-duo__side {
  margin: 0;
}

/* Image générique */
.pf-img {
  width: 100%;
  background-color: var(--color-navy);
  background-image: linear-gradient(145deg, var(--color-navy) 0%, var(--color-navy-dark) 100%);
  background-size: cover;
  background-position: center;
  border: var(--pf-border);
  border-radius: var(--pf-radius);
  filter: brightness(0.97) saturate(0.92);
}
.pf-duo__main .pf-img { height: 480px; }
.pf-duo__side  .pf-img { height: 340px; }

/* ── BLOC 4 SIGNATURE ── */
.portfolio-signature {
  max-width: 860px;
  margin: 0 auto var(--pf-gap);
  padding: 0 var(--space-xl);
}
.pf-signature__figure { margin: 0; }
.pf-signature__img {
  width: 100%;
  height: 520px;
  background-color: var(--color-navy);
  background-image: linear-gradient(145deg, var(--color-navy) 0%, var(--color-navy-dark) 100%);
  background-size: cover;
  background-position: center;
  border: var(--pf-border);
  border-radius: var(--pf-radius);
  filter: brightness(0.97) saturate(0.90);
}
.pf-signature__caption {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 12px 0 0;
}

/* ── LÉGENDES ── */
.pf-caption {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 10px;
}
.pf-caption__type {
  font-family: 'Barlow', sans-serif;
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pf-navy);
}
.pf-caption__desc {
  font-family: 'Barlow', sans-serif;
  font-size: 0.78rem;
  color: var(--pf-graphite);
  letter-spacing: 0.04em;
}
.pf-caption__type::after {
  content: '—';
  margin-left: 8px;
  color: var(--pf-sand);
  font-weight: 300;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .portfolio-duo,
  .portfolio-duo--reverse {
    grid-template-columns: 1fr;
  }
  .portfolio-duo--reverse .pf-duo__main { order: 1; }
  .portfolio-duo--reverse .pf-duo__side  { order: 2; }
  .pf-duo__main .pf-img { height: 280px; }
  .pf-duo__side  .pf-img { height: 220px; }
  .pf-hero__img {
    height: 50vw;
    min-height: 240px;
  }
  .pf-signature__img { height: 280px; }
  .portfolio-signature { padding: 0 var(--space-md); }
}



/* ---- PAGE À PROPOS ---- */

/* Histoire */
.about-story {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-4xl);
  align-items: center;
}

.about-story__content p {
  color: var(--color-gray-500);
  line-height: 1.8;
}

.about-story__visual {
  position: relative;
}

.about-story__img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: linear-gradient(135deg, #0E1B30 0%, #1D365F 50%, #142444 100%);
  min-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Placeholder pour les images */
.about-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  color: rgba(255,255,255,0.2);
}

.about-placeholder i {
  font-size: 3rem;
  color: rgba(200,169,110,0.3);
}

.about-placeholder span {
  font-size: var(--text-sm);
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.about-story__card {
  position: absolute;
  bottom: -var(--space-lg);
  right: -var(--space-xl);
  background: var(--color-navy);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--color-gold);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 200px;
}

.about-story__card-icon {
  color: var(--color-gold);
  font-size: 1.2rem;
  margin-bottom: var(--space-xs);
}

.about-story__card strong {
  color: var(--color-white);
  font-size: var(--text-base);
}

.about-story__card span {
  color: rgba(255,255,255,0.5);
  font-size: var(--text-xs);
}

/* Valeurs */
.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.value-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  border: 1px solid var(--color-gray-200);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: all var(--transition-base);
}

.value-card:hover {
  border-color: var(--color-gold);
  box-shadow: var(--shadow-gold);
  transform: translateY(-4px);
}

.value-card__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  background: var(--color-gold-pale);
  display: flex;
  align-items: center;
  justify-content: center;
}

.value-card__icon i {
  font-size: 1.3rem;
  color: var(--color-gold);
}

.value-card h3 {
  font-size: var(--text-lg);
  color: var(--color-charcoal);
}

.value-card p {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  line-height: 1.7;
}

/* Certifications */
.certif-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-4xl);
  align-items: start;
}

.certif-intro p {
  color: var(--color-gray-500);
  margin-top: var(--space-md);
  line-height: 1.8;
}

.certif-items {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.certif-item {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
  padding: var(--space-lg);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
}

.certif-item:hover {
  border-color: var(--color-gold);
  box-shadow: var(--shadow-gold);
}

.certif-item__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--color-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.certif-item__icon i {
  font-size: 1.1rem;
  color: var(--color-white);
}

.certif-item h4 {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-charcoal);
  margin-bottom: 6px;
}

.certif-item p {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  line-height: 1.6;
}

/* Compteur */
.numbers__grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items: center;
  gap: 0;
}

.numbers__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xl);
  text-align: center;
}

.numbers__value-wrap {
  display: block;
  margin-bottom: 6px;
  line-height: 1;
}

.numbers__value {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  color: var(--color-white);
  display: inline;
}

.numbers__suffix {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  color: var(--color-gold);
  display: inline;
}

.numbers__label {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
}

.numbers__divider {
  width: 1px;
  height: 80px;
  background: rgba(255,255,255,0.08);
  flex-shrink: 0;
}

/* ---- PAGE PRESTATIONS ---- */

.prestation-section {
  scroll-margin-top: calc(var(--nav-height) + var(--space-lg));
}

.prestation-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4xl);
  align-items: center;
}

.prestation-grid--reverse {
  direction: rtl;
}

.prestation-grid--reverse > * {
  direction: ltr;
}

.prestation-number {
  display: block;
  font-family: var(--font-serif);
  font-size: 4rem;
  font-weight: 700;
  color: var(--color-gray-200);
  line-height: 1;
  margin-bottom: var(--space-xs);
  background: linear-gradient(135deg, var(--color-gold-pale), var(--color-gray-200));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.prestation-visual {
  position: relative;
}

.prestation-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.prestation-img--parquet {
  background: url('../assets/prestations/sol-interieur.jpg') center/cover no-repeat;
}

.prestation-img--carrelage {
  background: url('../assets/prestations/carrelage.jpg') center/cover no-repeat;
}

.prestation-img--beton {
  background: url('../assets/prestations/sols-interieurs.jpg') center/cover no-repeat;
}

.prestation-img--vinyle {
  background: url('../assets/prestations/finitions.jpg') center/cover no-repeat;
}

.prestation-img--renov {
  background: url('../assets/prestations/renovation.jpg') center/cover no-repeat;
}

/* Encadré photo avec image inline (background-image en style="…") */
.prestation-img--photo {
  background-color: var(--color-gray-100);
}

.prestation-content p {
  color: var(--color-gray-500);
  line-height: 1.8;
}

.prestation-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm) var(--space-lg);
  margin-top: var(--space-xl);
}

.prestation-feature {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
}

.prestation-feature i {
  color: var(--color-gold);
  font-size: 0.9rem;
  flex-shrink: 0;
}

/* ---- PAGE RÉALISATIONS ---- */

.realisations-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  justify-content: center;
}

.filter-btn {
  padding: 8px 20px;
  font-size: var(--text-sm);
  font-weight: 500;
  border-radius: 100px;
  border: 1.5px solid var(--color-gray-200);
  color: var(--color-gray-500);
  background: var(--color-white);
  transition: all var(--transition-fast);
  cursor: pointer;
}

.filter-btn:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
}

.filter-btn.active {
  background: var(--color-charcoal);
  border-color: var(--color-charcoal);
  color: var(--color-white);
}

.real-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

.real-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
}

.real-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-6px);
}

.real-card--large {
  grid-column: span 2;
}

/* ── Slider photo dans les cartes réalisation ── */
.real-card__slider {
  position: relative;
  height: 260px;
  overflow: hidden;
}

.real-card--large .real-card__slider {
  height: 320px;
}

.real-card__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-color: var(--color-navy);
  opacity: 0;
  transition: opacity 0.45s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.real-card__slide.active {
  opacity: 1;
  z-index: 1;
}

/* Placeholder dans les slides */
.real-card__slide .real-card__placeholder-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  color: rgba(200, 169, 110, 0.45);
  pointer-events: none;
}

/* Masquer le placeholder si une vraie image est définie */
.real-card__slide[style*="url('assets"]:not([style*="url('')"]) .real-card__placeholder-inner {
  display: none;
}

/* Boutons prev / next */
.slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(0,0,0,0.45);
  border: none;
  color: #fff;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  transition: background var(--transition-fast);
  opacity: 0;
  transition: opacity var(--transition-fast), background var(--transition-fast);
}

.real-card:hover .slider-btn {
  opacity: 1;
}

.slider-btn:hover {
  background: rgba(200, 169, 110, 0.85);
}

.slider-btn--prev { left: var(--space-sm); }
.slider-btn--next { right: var(--space-sm); }

/* Points de navigation */
.slider-dots {
  position: absolute;
  bottom: var(--space-sm);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 10;
}

.slider-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.slider-dot.active {
  background: var(--color-gold);
}

.real-card__img {
  position: relative;
  height: 260px;
  overflow: hidden;
}

.real-card--large .real-card__img {
  height: 320px;
}

.real-card__img-bg,
.real-card__img {
  transition: transform var(--transition-slow);
}

.real-card:hover .real-card__img {
  transform: none;
}

/* Placeholder — en attente des vraies photos */
.real-card__img--placeholder {
  background: linear-gradient(135deg, var(--color-navy-light) 0%, var(--color-navy) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.real-card__placeholder-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  color: rgba(200, 169, 110, 0.5);
  pointer-events: none;
}

.real-card__placeholder-inner i {
  font-size: 2.5rem;
}

.real-card__placeholder-inner span {
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-family: var(--font-sans);
}

/* Vraies photos — classe avec background-image */
.real-card__img--photo {
  background-size: cover;
  background-position: center;
  background-color: var(--color-navy);
}

/* Cartes avec rendu PDF via canvas */
.real-card__img--canvas {
  position: relative;
  height: 260px;
  overflow: hidden;
  background: var(--color-navy);
  display: flex;
  align-items: center;
  justify-content: center;
}

.real-card__canvas {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: absolute;
  inset: 0;
}

/* Placeholder visible par défaut dans les cartes photo */
.real-card__img--photo .real-card__placeholder-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  color: rgba(200, 169, 110, 0.45);
  pointer-events: none;
  position: absolute;
  inset: 0;
  justify-content: center;
  z-index: 0;
}

/* Quand une vraie image est définie (pas vide), on cache le placeholder */
.real-card__img--photo[style*="url('"]:not([style*="url('')"]) .real-card__placeholder-inner {
  display: none;
}

.real-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
  display: flex;
  align-items: flex-end;
  padding: var(--space-md);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.real-card:hover .real-card__overlay {
  opacity: 1;
}

.real-card__overlay-inner {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.real-card__overlay-inner .tag {
  background: var(--color-gold);
  color: var(--color-white);
  width: fit-content;
}

.real-card__overlay-inner h3 {
  font-size: var(--text-base);
  color: var(--color-white);
}

.real-card__overlay-inner p {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.8);
  line-height: 1.5;
}

.real-card__meta {
  display: flex;
  gap: var(--space-md);
  margin-top: 4px;
}

.real-card__meta span {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.7);
}

.real-card__meta i {
  color: var(--color-gold);
  font-size: 0.8rem;
}

.real-card__body {
  padding: var(--space-md) var(--space-lg);
}

.real-card__tags {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
}

.real-card__title {
  font-size: var(--text-base);
  font-family: var(--font-sans);
  font-weight: 600;
  color: var(--color-charcoal);
  margin-bottom: 6px;
}

.real-card__text {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  line-height: 1.6;
}

/* Card hidden by filter */
.real-card.hidden {
  display: none;
}

/* ---- PAGE FAQ ---- */

.faq-category {
  margin-bottom: var(--space-3xl);
}

.faq-category__title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-sans);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-charcoal);
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-md);
  border-bottom: 2px solid var(--color-gold-pale);
}

.faq-category__title i {
  color: var(--color-gold);
  font-size: 1.1rem;
}

.faq-full-list {
  border-top: 1px solid var(--color-gray-200);
}

/* Style de FAQ réutilisé depuis home.css */
.faq-item {
  border-bottom: 1px solid var(--color-gray-200);
}

.faq-item__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) 0;
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-charcoal);
  text-align: left;
  gap: var(--space-md);
  transition: color var(--transition-fast);
}

.faq-item__question:hover {
  color: var(--color-gold);
}

.faq-item__icon {
  flex-shrink: 0;
  color: var(--color-gold);
  transition: transform var(--transition-base);
  font-size: 0.85rem;
}

.faq-item.open .faq-item__icon {
  transform: rotate(180deg);
}

.faq-item__answer {
  padding-bottom: var(--space-lg);
}

.faq-item__answer p {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  line-height: 1.8;
}

.faq-still-question {
  margin-top: var(--space-3xl);
  text-align: center;
  padding: var(--space-3xl) var(--space-lg);
  background: var(--color-gold-pale);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(200,169,110,0.2);
}

.faq-still-question i {
  font-size: 2.5rem;
  color: var(--color-gold);
  margin-bottom: var(--space-md);
  display: block;
}

.faq-still-question h3 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-sm);
}

.faq-still-question p {
  color: var(--color-gray-500);
  margin-bottom: var(--space-xl);
}

/* ---- PAGE CONTACT ---- */

.contact-page-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-4xl);
  align-items: start;
}

.contact-form-header {
  margin-bottom: var(--space-xl);
}

.contact-form-header h2 {
  margin-bottom: var(--space-sm);
}

.contact-form-header p {
  color: var(--color-gray-500);
  line-height: 1.7;
}

.contact-form--large {
  background: var(--color-white);
  padding: var(--space-xl);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-gray-200);
  box-shadow: var(--shadow-sm);
}

.contact-form__section-title {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-gold-pale);
}

.required {
  color: var(--color-gold);
}

.contact-form__extras {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}

/* Grille cases à cocher — type de prestation */
.checkboxes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm) var(--space-md);
  margin-top: var(--space-sm);
  padding: var(--space-md);
  background: var(--color-gray-100);
  border: 1.5px solid var(--color-gray-200);
  border-radius: var(--radius-md);
}

@media (max-width: 480px) {
  .checkboxes-grid {
    grid-template-columns: 1fr;
  }
}

.checkbox-label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  cursor: pointer;
  user-select: none;
}

.checkbox-label input[type="checkbox"] {
  display: none;
}

.checkbox-box {
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--color-gray-300);
  border-radius: 4px;
  flex-shrink: 0;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.checkbox-label input:checked + .checkbox-box {
  background: var(--color-gold);
  border-color: var(--color-gold);
}

.checkbox-label input:checked + .checkbox-box::after {
  content: '\f00c';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  font-size: 0.65rem;
  color: var(--color-white);
}

.contact-page-aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  position: sticky;
  top: calc(var(--nav-height) + var(--space-lg));
}

.contact-aside-card {
  background: var(--color-navy);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  border-left: 3px solid var(--color-gold);
}

.contact-aside-card h3 {
  font-size: var(--text-lg);
  color: var(--color-white);
  margin-bottom: var(--space-lg);
}

.contact-process-steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.contact-process-steps li {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
}

.contact-process-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-gold);
  color: var(--color-white);
  font-size: var(--text-xs);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contact-process-steps strong {
  display: block;
  color: var(--color-white);
  font-size: var(--text-sm);
  margin-bottom: 4px;
}

.contact-process-steps p {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.5);
  line-height: 1.5;
}

.contact-aside-info {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  border: 1px solid var(--color-gray-200);
}

.contact-aside-info h4 {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: var(--space-sm);
}

.contact-aside-reassurance {
  background: var(--color-gold-pale);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  border: 1px solid rgba(200,169,110,0.2);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.contact-aside-reassurance__item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-charcoal);
}

.contact-aside-reassurance__item i {
  color: var(--color-gold);
  font-size: 0.9rem;
}

/* Réutilisation des contact-detail */
.contact-detail {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
  text-decoration: none;
}

.contact-detail:hover {
  background: var(--color-gold-pale);
}

.contact-detail__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-sm);
  background: var(--color-gold-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contact-detail__icon i {
  color: var(--color-gold);
  font-size: 1rem;
}

.contact-detail__label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-gray-400);
  margin-bottom: 2px;
}

.contact-detail__value {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-charcoal);
  line-height: 1.5;
}

/* ---- PAGES LÉGALES ---- */

.legal-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xl);
}

.legal-section h2 {
  font-size: var(--text-xl);
  color: var(--color-charcoal);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-gray-200);
}

.legal-section p,
.legal-section li {
  font-size: var(--text-base);
  color: var(--color-gray-500);
  line-height: 1.8;
  max-width: 100%;
}

.legal-section ul {
  margin-top: var(--space-sm);
  padding-left: var(--space-lg);
}

.legal-section ul li {
  list-style: disc;
  margin-bottom: var(--space-xs);
}

.legal-section a {
  color: var(--color-gold);
  text-decoration: underline;
}

.legal-section a:hover {
  color: var(--color-gold-dark);
}

.legal-date {
  font-size: var(--text-sm);
  color: var(--color-gray-400);
  font-style: italic;
  margin-top: var(--space-lg);
}

/* ═══════════════ RESPONSIVE PAGES ═══════════════ */

@media (max-width: 1200px) {
  .prestation-features { grid-template-columns: 1fr; }
}

@media (max-width: 1024px) {
  .about-story { grid-template-columns: 1fr; gap: var(--space-2xl); }
  .values-grid { grid-template-columns: repeat(2, 1fr); }
  .certif-grid { grid-template-columns: 1fr; gap: var(--space-2xl); }
  .prestation-grid { grid-template-columns: 1fr; gap: var(--space-xl); }
  .prestation-grid--reverse { direction: ltr; }
  .contact-page-grid { grid-template-columns: 1fr; gap: var(--space-xl); }
  .contact-page-aside { position: static; }
  .numbers__grid { grid-template-columns: 1fr 1fr; }
  .numbers__divider { display: none; }
  .real-grid { grid-template-columns: 1fr 1fr; }
  .real-card--large { grid-column: span 2; }
}

@media (max-width: 768px) {
  .values-grid { grid-template-columns: 1fr; }
  .real-grid { grid-template-columns: 1fr; }
  .real-card--large { grid-column: span 1; }
  .numbers__grid { grid-template-columns: 1fr 1fr; }
  .prestation-img { min-height: 260px; }
  .contact-form--large { padding: var(--space-lg); }
}

@media (max-width: 480px) {
  .numbers__grid { grid-template-columns: 1fr; }
  .realisations-filters { justify-content: flex-start; }
}

/* ═══════════════ BARRE NAVIGATION PRESTATIONS ═══════════════ */

.prestations-nav {
  border-bottom: 1px solid var(--color-gray-200);
}

.prestations-nav__links {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
  justify-content: center;
  padding: var(--space-sm) 0;
}

.prestations-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-slate);
  padding: 0.45em 1em;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  background: var(--color-white);
  transition: all var(--transition-fast);
  text-decoration: none;
  white-space: nowrap;
}

.prestations-nav__link:hover {
  background: var(--color-navy);
  color: var(--color-white);
  border-color: var(--color-navy);
  transform: translateY(-1px);
  box-shadow: var(--shadow-navy);
}

.prestations-nav__link i {
  font-size: 0.8em;
  color: var(--color-gold);
  transition: color var(--transition-fast);
}

.prestations-nav__link:hover i {
  color: var(--color-gold-light);
}

/* ═══════════════ PATTERNS SERVICE CARDS FAÏENCE ═══════════════ */

.service-card__pattern--faience {
  background:
    linear-gradient(135deg, #E8E0F0 0%, #D8D0E8 50%, #EAE4F2 100%);
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(90,97,107,0.06) 0px, rgba(90,97,107,0.06) 1px,
      transparent 1px, transparent 40px
    ),
    repeating-linear-gradient(
      -45deg,
      rgba(90,97,107,0.04) 0px, rgba(90,97,107,0.04) 1px,
      transparent 1px, transparent 40px
    );
}

/* ═══════════════ RESPONSIVE AJOUT ═══════════════ */

@media (max-width: 768px) {
  .prestations-nav__links {
    gap: var(--space-xs);
    padding: var(--space-sm);
  }
  .prestations-nav__link {
    font-size: var(--text-xs);
    padding: 0.4em 0.8em;
  }
}

/* ═══════════════ BARRE NAVIGATION ANCRAGES PRESTATIONS ═══════════════ */

.prestations-nav {
  border-bottom: 1px solid var(--color-gray-200);
}

.prestations-nav__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  justify-content: center;
  padding: var(--space-md) 0;
}

.prestations-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  padding: 0.45em 1.1em;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-navy);
  background: var(--color-white);
  border: 1.5px solid var(--color-gray-200);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.prestations-nav__link:hover,
.prestations-nav__link:focus-visible {
  background: var(--color-navy);
  color: var(--color-white);
  border-color: var(--color-navy);
  transform: translateY(-1px);
  box-shadow: var(--shadow-navy);
}

.prestations-nav__link i {
  color: var(--color-gold);
  font-size: 0.85em;
  transition: color var(--transition-fast);
}

.prestations-nav__link:hover i {
  color: var(--color-gold-light);
}

/* Responsive barre nav */
@media (max-width: 768px) {
  .prestations-nav__links {
    gap: var(--space-xs);
    justify-content: flex-start;
  }
  .prestations-nav__link {
    font-size: var(--text-xs);
    padding: 0.4em 0.9em;
  }
}

/* ═══════════════ CARTE SERVICE — FAÏENCE (variante couleur) ═══════════════ */

.service-card__pattern--faience {
  background: linear-gradient(135deg, #E8F0F8 0%, #D0E2F4 50%, #EAF2FC 100%);
  background-image:
    repeating-linear-gradient(0deg, rgba(29,54,95,0.08) 0px, rgba(29,54,95,0.08) 1px, transparent 1px, transparent 40px),
    repeating-linear-gradient(90deg, rgba(29,54,95,0.08) 0px, rgba(29,54,95,0.08) 1px, transparent 1px, transparent 40px);
}

/* ═══════════════ HARMONISATION FOOTER ═══════════════ */

.footer__socials {
  margin-top: var(--space-md);
  display: flex;
  gap: var(--space-sm);
}
