/* ==========================================================================
   components.css — Boutons, cartes, badges, hero, sections réutilisables
   ========================================================================== */

/* ---- Boutons ---- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.85rem 1.6rem;
  border-radius: var(--radius-full);
  font-weight: 600;
  font-size: var(--fs-sm);
  line-height: 1;
  transition: transform var(--t-base), box-shadow var(--t-base), background var(--t-base);
  white-space: nowrap;
}
.btn--primary {
  background: var(--gradient-brand);
  color: #fff;
  box-shadow: var(--shadow-glow);
}
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 18px 48px rgba(2,132,199,.45); }
.btn--ghost {
  background: rgba(255,255,255,.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,.25);
}
.btn--ghost:hover { background: rgba(255,255,255,.16); }
.btn--outline {
  background: transparent;
  color: var(--color-primary);
  border: 1.5px solid var(--color-line);
}
.btn--outline:hover { border-color: var(--color-primary); transform: translateY(-2px); }
.btn--lg { padding: 1.05rem 2rem; font-size: var(--fs-base); }
.btn--block { display: flex; width: 100%; }

/* ---- En-têtes de section ---- */
.section-head { max-width: 640px; margin: 0 auto var(--space-7); text-align: center; }
.section-head--left { margin-inline: 0; text-align: left; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--color-primary);
  background: rgba(2,132,199,.1);
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
}
.section--dark .eyebrow { color: var(--color-accent-light); background: rgba(34,211,238,.12); }
.section-head p { margin-top: var(--space-3); font-size: var(--fs-lg); }

/* ---- Cartes ---- */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: transparent; }
.card__icon {
  width: 52px; height: 52px;
  border-radius: var(--radius-md);
  background: var(--gradient-brand);
  display: grid; place-items: center;
  color: #fff;
  font-size: 1.4rem;
  margin-bottom: var(--space-4);
  box-shadow: var(--shadow-glow);
}
.card h3 { margin-bottom: var(--space-3); }
.card p { font-size: var(--fs-sm); }

/* ---- Carte avec image en en-tête ---- */
.card--media { padding: 0; overflow: hidden; display: flex; flex-direction: column; }
.card__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-base); }
.card--media:hover .card__media img { transform: scale(1.06); }
.card__body { padding: var(--space-6); }

/* ---- Hero ---- */
.hero {
  position: relative;
  padding-block: var(--space-9) var(--space-9);
  background: var(--gradient-dark);
  color: #fff;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--gradient-glow);
  pointer-events: none;
}
.hero__grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--space-8);
  align-items: center;
}

/* ---- Fond de mer flou (Côte d'Azur) ---- */
.sea-layer {
  position: absolute;
  inset: -28px;                 /* léger débord pour masquer les bords flous */
  z-index: 0;
  background: url("https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1600&q=70") center/cover no-repeat;
  filter: blur(8px) saturate(1.05) brightness(0.5);
  pointer-events: none;
}
.hero::after,
.page-hero::after {
  content: "";
  position: absolute; inset: 0;
  z-index: 1;
  background: var(--gradient-sea-overlay);
  pointer-events: none;
}
.hero h1 { color: #fff; margin-bottom: var(--space-5); }
.hero h1 span { background: linear-gradient(120deg,#7dd3fc,#5eead4); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero__lead { font-size: var(--fs-lg); color: rgba(255,255,255,.78); max-width: 52ch; margin-bottom: var(--space-6); }
.hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.hero__stats {
  display: flex;
  gap: var(--space-7);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}
.hero__stat strong { font-family: var(--font-display); font-size: var(--fs-2xl); color: #fff; display: block; }
.hero__stat span { font-size: var(--fs-sm); color: rgba(255,255,255,.6); }

/* Carte visuelle flottante dans le hero */
.hero__visual {
  position: relative;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  backdrop-filter: blur(8px);
  box-shadow: var(--shadow-lg);
}
.hero__window-bar { display: flex; gap: 7px; margin-bottom: var(--space-4); }
.hero__window-bar i { width: 11px; height: 11px; border-radius: 50%; background: rgba(255,255,255,.25); }
.hero__window-bar i:nth-child(1){ background:#ff5f57; }
.hero__window-bar i:nth-child(2){ background:#febc2e; }
.hero__window-bar i:nth-child(3){ background:#28c840; }
.hero__bars { display: grid; gap: var(--space-3); }
.hero__bars div { height: 12px; border-radius: var(--radius-full); background: rgba(255,255,255,.14); }
.hero__bars div:nth-child(1){ width:80%; background:linear-gradient(90deg,#7dd3fc,#5eead4); }
.hero__bars div:nth-child(2){ width:100%; }
.hero__bars div:nth-child(3){ width:65%; }
.hero__bars div:nth-child(4){ width:90%; }
.hero__bars div:nth-child(5){ width:45%; background:rgba(34,211,238,.5); }
.hero__shot {
  width: 100%;
  border-radius: var(--radius-md);
  margin-top: var(--space-4);
  aspect-ratio: 16 / 10;
  object-fit: cover;
  box-shadow: var(--shadow-md);
}

/* ---- Image illustrée (sections) ---- */
.media {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.media img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4 / 3; transition: transform var(--t-base); filter: saturate(.95); }
.media:hover img { transform: scale(1.04); }

/* Voile azur léger pour fondre les photos dans la charte (et adoucir les contrastes) */
.media::after,
.card__media::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background: linear-gradient(160deg, rgba(2,132,199,.14), rgba(4,28,46,.22));
}

/* ---- Photo d'équipe / avatar image ---- */
.team-photo {
  width: 96px; height: 96px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto var(--space-4);
  box-shadow: var(--shadow-md);
  border: 3px solid var(--color-surface);
}

/* ---- Bande de logos / confiance ---- */
.trustbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-7); opacity:.7; }
.trustbar span { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-lg); color: var(--color-muted); letter-spacing: -0.02em; }

/* ---- Étapes du process ---- */
.steps { counter-reset: step; }
.step { display: flex; gap: var(--space-5); align-items: flex-start; }
.step__num {
  flex: none;
  width: 48px; height: 48px;
  border-radius: var(--radius-full);
  background: var(--gradient-brand);
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-weight: 700;
  box-shadow: var(--shadow-glow);
}
.step h3 { margin-bottom: var(--space-2); }

/* ---- Tarifs ---- */
.price-card { position: relative; display: flex; flex-direction: column; }
.price-card.is-featured {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-lg);
  transform: scale(1.03);
}
.price-card.is-featured:hover { transform: scale(1.03) translateY(-6px); }
.price-badge {
  position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  background: var(--gradient-brand);
  color: #fff;
  font-size: var(--fs-xs); font-weight: 600;
  padding: .35rem 1rem; border-radius: var(--radius-full);
  box-shadow: var(--shadow-glow);
}
.price-card .price { font-family: var(--font-display); font-size: var(--fs-3xl); font-weight: 800; color: var(--color-ink); margin: var(--space-3) 0; }
.price-card .price small { font-size: var(--fs-sm); font-weight: 500; color: var(--color-muted); }
.price-list { display: grid; gap: var(--space-3); margin: var(--space-5) 0 var(--space-6); flex: 1; }
.price-list li { display: flex; gap: var(--space-3); font-size: var(--fs-sm); color: var(--color-slate); }
.price-list li::before { content: "✓"; color: var(--color-success); font-weight: 700; }

/* ---- Portfolio ---- */
.work {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: flex-end;
  padding: var(--space-5);
  color: #fff;
  box-shadow: var(--shadow-md);
}
.work::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 35%,rgba(15,23,42,.85)); }
.work__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  transition: transform var(--t-base);
}
.work:hover .work__img { transform: scale(1.06); }
.work__content { position: relative; z-index: 1; transform: translateY(8px); transition: transform var(--t-base); }
.work:hover .work__content { transform: translateY(0); }
.work span { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .1em; opacity: .8; }
.work h3 { color: #fff; }
.work--g1 { background: linear-gradient(135deg,#0284c7,#06b6d4); }
.work--g2 { background: linear-gradient(135deg,#0f172a,#0284c7); }
.work--g3 { background: linear-gradient(135deg,#7c3aed,#ec4899); }
.work--g4 { background: linear-gradient(135deg,#0891b2,#10b981); }
.work--g5 { background: linear-gradient(135deg,#f59e0b,#ef4444); }
.work--g6 { background: linear-gradient(135deg,#1e293b,#0891b2); }

/* ---- Galerie mosaïque ---- */
.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}
.gallery img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  filter: saturate(.95) brightness(.97);
  transition: transform var(--t-base), box-shadow var(--t-base), filter var(--t-base);
}
.gallery img:hover { filter: none; }
.gallery img:hover { transform: translateY(-5px) scale(1.02); box-shadow: var(--shadow-lg); }
@media (max-width: 900px) { .gallery { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .gallery { grid-template-columns: repeat(2, 1fr); } }

/* ---- Échantillons / études de cas ---- */
.sample-tag {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}
/* ---- Pages légales ---- */
.legal { max-width: 820px; }
.legal h2 {
  margin-top: var(--space-7);
  margin-bottom: var(--space-3);
  font-size: var(--fs-xl);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-line);
}
.legal h2:first-child { margin-top: 0; }
.legal p { margin-bottom: var(--space-3); }
.legal ul { list-style: disc; padding-left: 1.3rem; display: grid; gap: var(--space-2); margin-bottom: var(--space-3); }
.legal li { color: var(--color-slate); }
.legal a { color: var(--color-primary); text-decoration: underline; }
.legal strong { color: var(--color-ink); }
.legal__note {
  background: rgba(251,191,36,.12);
  border: 1px solid rgba(251,191,36,.4);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  font-size: var(--fs-sm);
  margin-bottom: var(--space-6);
}
.legal__updated { font-size: var(--fs-sm); color: var(--color-muted); margin-top: var(--space-7); }

/* ---- Témoignages ---- */
.quote {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.quote p { color: var(--color-ink); font-size: var(--fs-base); }
.quote__author { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-5); }
.quote__avatar { width: 46px; height: 46px; border-radius: 50%; background: var(--gradient-brand); color:#fff; display:grid; place-items:center; font-weight:700; flex: none; }
img.quote__avatar { object-fit: cover; }
.quote__author strong { display: block; font-size: var(--fs-sm); }
.quote__author span { font-size: var(--fs-xs); color: var(--color-muted); }
.stars { color: #f59e0b; margin-bottom: var(--space-3); letter-spacing: 2px; }

/* ---- Bandeau CTA ---- */
.cta {
  background: var(--gradient-brand);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  text-align: center;
  color: #fff;
  box-shadow: var(--shadow-lg);
}
.cta h2 { color: #fff; }
.cta p { color: rgba(255,255,255,.85); margin: var(--space-3) auto var(--space-6); max-width: 50ch; }

/* ---- Page header (sous-pages) ---- */
.page-hero {
  background: var(--gradient-dark);
  color: #fff;
  padding-block: var(--space-9) var(--space-8);
  position: relative;
  overflow: hidden;
}
.page-hero::before { content:""; position:absolute; inset:0; background:var(--gradient-glow); }
.page-hero .container { position: relative; z-index: 2; }
.page-hero h1 { color: #fff; }
.page-hero p { color: rgba(255,255,255,.75); max-width: 56ch; margin-top: var(--space-4); font-size: var(--fs-lg); }
.breadcrumb { font-size: var(--fs-sm); color: rgba(255,255,255,.55); margin-bottom: var(--space-4); }
.breadcrumb a:hover { color: #fff; }

/* ---- Formulaire ---- */
.form { display: grid; gap: var(--space-5); }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.field { display: grid; gap: var(--space-2); }
.field label { font-size: var(--fs-sm); font-weight: 600; color: var(--color-ink); }
.field input, .field textarea, .field select {
  padding: 0.85rem 1rem;
  border: 1.5px solid var(--color-line);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  font-size: var(--fs-sm);
}
.field textarea { resize: vertical; min-height: 130px; }
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(2,132,199,.12);
}
.field.has-error input, .field.has-error textarea { border-color: var(--color-error); }
.field__error { font-size: var(--fs-xs); color: var(--color-error); min-height: 1em; }
.form__note { font-size: var(--fs-xs); color: var(--color-muted); }
.form__success {
  display: none;
  background: rgba(16,185,129,.1);
  border: 1px solid rgba(16,185,129,.4);
  color: #047857;
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 500;
}
.form__success.is-visible { display: block; }

/* ---- Infos contact ---- */
.info-item { display: flex; gap: var(--space-4); align-items: flex-start; margin-bottom: var(--space-5); }
.info-item__icon {
  flex: none; width: 46px; height: 46px;
  border-radius: var(--radius-md);
  background: rgba(2,132,199,.1);
  color: var(--color-primary);
  display: grid; place-items: center;
  font-size: 1.2rem;
}
.info-item strong { display: block; font-size: var(--fs-sm); }
.info-item span { font-size: var(--fs-sm); color: var(--color-slate); }

/* ---- FAQ (accordéon) ---- */
.faq__item { border-bottom: 1px solid var(--color-line); }
.faq__q {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-4);
  padding: var(--space-5) 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-lg);
  text-align: left;
  color: var(--color-ink);
}
.faq__q i { transition: transform var(--t-base); color: var(--color-primary); font-style: normal; font-size: 1.4rem; }
.faq__item.is-open .faq__q i { transform: rotate(45deg); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height var(--t-base); }
.faq__a p { padding-bottom: var(--space-5); font-size: var(--fs-sm); }

/* ---- Valeurs / À propos ---- */
.value { text-align: center; }
.value__icon { margin: 0 auto var(--space-4); width: 60px; height: 60px; border-radius: var(--radius-md); background: rgba(2,132,199,.1); color: var(--color-primary); display: grid; place-items: center; font-size: 1.5rem; }

.stat-block { text-align: center; }
.stat-block strong { font-family: var(--font-display); font-size: var(--fs-4xl); background: var(--gradient-brand); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; display: block; }
.stat-block span { color: var(--color-slate); font-size: var(--fs-sm); }

@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__visual { order: -1; max-width: 420px; }
  .form__row { grid-template-columns: 1fr; }
  .price-card.is-featured { transform: none; }
}
