/* ============================================================
   SERVICE PAGES — CSS dédié
   ============================================================ */

/* === HERO SERVICE === */
.service-hero {
  padding: calc(var(--sp-32) + 60px) 0 var(--sp-20);
  background:
    radial-gradient(circle at 85% 20%, rgba(132, 196, 65, 0.10), transparent 50%),
    radial-gradient(circle at 5% 80%, rgba(77, 191, 219, 0.08), transparent 50%),
    linear-gradient(180deg, #fefdfb 0%, #f4f8ee 100%);
}
.service-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--sp-12);
  align-items: center;
}
@media (max-width: 980px) {
  .service-hero-grid { grid-template-columns: 1fr; }
  .service-hero-visual { order: -1; max-width: 560px; margin: 0 auto; }
  .service-hero { padding: calc(var(--sp-24) + 60px) 0 var(--sp-12); }
}
.breadcrumb {
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  margin-bottom: var(--sp-3);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.breadcrumb a { color: var(--green-deep); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb span { color: var(--ink-mute); }
.service-hero-text h1 {
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  margin-bottom: var(--sp-4);
  line-height: 1.1;
}
.service-hero-text h1 em {
  background: linear-gradient(120deg, var(--green-bright), var(--green-deep));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-style: italic;
}
.service-hero-desc {
  font-size: var(--fs-lg);
  color: var(--ink-soft);
  max-width: 58ch;
  line-height: 1.65;
  margin-bottom: var(--sp-6);
}
.service-hero-price {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding: var(--sp-4) var(--sp-6);
  background: white;
  border-radius: var(--radius);
  border: 1px solid var(--slate-200);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-4);
  width: fit-content;
}
.price-label {
  font-size: var(--fs-sm);
  color: var(--ink-mute);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.price-value {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 900;
  color: var(--green-deep);
  letter-spacing: 0;
  line-height: 1;
}
.price-unit {
  font-size: 1rem;
  font-weight: 500;
  color: var(--ink-mute);
}
.price-note {
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  font-weight: 500;
  width: 100%;
  border-top: 1px dashed var(--slate-200);
  padding-top: var(--sp-2);
  margin-top: var(--sp-1);
}
.service-certifs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}
.service-certifs span {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--ink-soft);
  background: var(--cream);
  padding: 0.3rem 0.75rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--slate-200);
}
.service-hero-visual .hero-slider {
  aspect-ratio: 4/3;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}
@media (max-width: 480px) {
  .service-hero-price { flex-direction: column; gap: var(--sp-2); }
  .price-value { font-size: 1.8rem; }
}

/* === URGENCY SECTION === */
.service-urgency {
  background: white;
  padding: var(--sp-20) 0;
  text-align: center;
}
.service-urgency h2 {
  font-size: var(--fs-3xl);
  margin-bottom: var(--sp-6);
  max-width: 20ch;
  margin-left: auto;
  margin-right: auto;
}
.service-urgency h2 em {
  background: linear-gradient(120deg, var(--green-bright), var(--green-deep));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-style: italic;
}
.service-urgency p {
  max-width: 65ch;
  margin: 0 auto var(--sp-12);
  font-size: var(--fs-md);
  line-height: 1.75;
  color: var(--ink-soft);
}
.urgency-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  max-width: 900px;
  margin: 0 auto;
}
@media (max-width: 768px) { .urgency-stats { grid-template-columns: 1fr; } }
.urgency-stat {
  background: var(--cream);
  padding: var(--sp-6);
  border-radius: var(--radius-lg);
  border: 1px solid var(--slate-200);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s;
}
.urgency-stat:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}
.urgency-stat strong {
  display: block;
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--green-deep);
  letter-spacing: 0;
  margin-bottom: var(--sp-2);
  line-height: 1;
}
.urgency-stat span {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  font-weight: 500;
}

/* === SUPPORTS GRID === */
.service-supports {
  padding: var(--sp-20) 0;
  background: var(--cream);
}
.supports-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  margin-top: var(--sp-12);
}
@media (max-width: 980px) { .supports-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .supports-grid { grid-template-columns: 1fr; } }
.support-card {
  background: white;
  padding: var(--sp-6);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--slate-100);
  transition: all 0.35s var(--ease-out);
}
.support-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow);
  border-color: var(--green-bright);
}
.zone-card-link {
  color: inherit;
  text-decoration: none;
}
.zone-card-link h3 {
  color: var(--ink);
  transition: color 0.3s var(--ease-out);
}
.zone-card-link:hover h3,
.zone-card-link:focus-visible h3 {
  color: var(--green-deep);
}
.support-icon {
  font-size: 2.2rem;
  margin-bottom: var(--sp-3);
  display: block;
  line-height: 1;
}
.support-card h3 {
  font-size: var(--fs-lg);
  margin-bottom: var(--sp-2);
}
.support-card p {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  margin: 0;
}
.support-card .card-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: var(--sp-5);
  padding: 0.85rem 1.25rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--green-bright), var(--green-deep));
  color: white;
  font-weight: 800;
  font-size: var(--fs-xs);
  line-height: 1;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 8px 22px rgba(42, 125, 62, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.28);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}
.support-card .card-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(42, 125, 62, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

/* === METHOD STEPS === */
.method-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  margin-top: var(--sp-12);
}
@media (max-width: 980px) { .method-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .method-steps { grid-template-columns: 1fr; } }
.method-step {
  position: relative;
  padding: var(--sp-6);
  background: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--slate-100);
  transition: all 0.3s var(--ease-out);
}
.method-step:hover {
  border-color: var(--green-bright);
  box-shadow: var(--shadow);
}
.method-step-num {
  font-family: var(--font-display);
  font-size: 3rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--green-bright), var(--blue-bright));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
  margin-bottom: var(--sp-3);
  letter-spacing: 0;
}
.method-step h3 {
  font-size: var(--fs-lg);
  margin-bottom: var(--sp-2);
}
.method-step p {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: 1.65;
  margin: 0;
}

/* === STICKY CTA === */
.service-sticky-cta {
  background: linear-gradient(135deg, var(--green-deep), var(--blue-deep));
  padding: var(--sp-8) 0;
  position: sticky;
  bottom: 0;
  z-index: 40;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.2);
}
@media (max-width: 768px) {
  .service-sticky-cta { display: none; } /* le mobile-sticky-cta prend le relais */
}
.service-sticky-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.service-sticky-inner p {
  color: rgba(255, 255, 255, 0.92);
  font-size: var(--fs-md);
  margin: 0;
  max-width: none;
}
.service-sticky-inner strong { color: white; }

/* === CARTES SERVICE (index.html) === */
.service-card {
  text-decoration: none;
  display: flex;
  flex-direction: column;
}
.service-card .card-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--green-deep);
  margin-top: auto;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding-top: var(--sp-4);
  border-top: 1px dashed var(--slate-200);
  transition: gap 0.3s;
}
.service-card:hover .card-cta { gap: var(--sp-3); color: var(--green-deep); }
.service-card .card-cta::after { content: "→"; transition: transform 0.3s; }
.service-card:hover .card-cta::after { transform: translateX(4px); }
