/* ============================================================
   landing.css — Templates SEO : service-detail, toulouse, secteurs
   ============================================================ */

/* ── Hero ──────────────────────────────────────────────────── */
.ld-hero {
  padding: 6rem 0 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  background: radial-gradient(ellipse 70% 60% at 50% 0%, rgba(247,147,29,.05) 0, transparent 60%);
}
/* 1. Grille de points en filigrane sur tous les heros landing */
.ld-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(247,147,29,.12) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 90% 85% at 50% 0%, black 5%, transparent 65%);
  -webkit-mask-image: radial-gradient(ellipse 90% 85% at 50% 0%, black 5%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}
.ld-hero .container {
  position: relative;
  z-index: 1;
}
.ld-hero .badge {
  margin-bottom: 1.25rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.ld-hero h1 {
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 900;
  letter-spacing: -.04em;
  line-height: 1.1;
  max-width: 800px;
  margin: 0 auto .5rem;
}
.ld-hero h1 .grad {
  background: var(--og);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.ld-hero-intro {
  font-size: 1.05rem;
  color: var(--mut);
  max-width: 640px;
  line-height: 1.75;
  margin: 1.5rem auto 2rem;
}
.ld-hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

/* 4. Ligne orange sous les h2 de toutes les sections landing */
.ld-features-header h2,
.ld-forwho-header h2,
.ld-faq-header h2,
.ld-challenges-header h2,
.ld-solutions-header h2,
.ld-points-header h2,
.ld-services-offered-header h2 {
  position: relative;
  padding-bottom: .85rem;
}
.ld-features-header h2::after,
.ld-forwho-header h2::after,
.ld-faq-header h2::after,
.ld-challenges-header h2::after,
.ld-solutions-header h2::after,
.ld-points-header h2::after,
.ld-services-offered-header h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 3px;
  background: var(--o);
  border-radius: 2px;
}

/* ── Features ──────────────────────────────────────────────── */
.ld-features {
  padding: 5rem 0;
  background: var(--c1);
}
.ld-features-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-features-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-features-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
.ld-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.25rem;
}
.ld-feature-card {
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 1.5rem;
  transition: border-color var(--tr), transform var(--tr);
}
.ld-feature-card--link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  display: flex;
  flex-direction: column;
}
.ld-fc-more {
  margin-top: auto;
  padding-top: 1rem;
  font-size: .82rem;
  color: var(--o);
  display: flex;
  align-items: center;
  gap: 4px;
  font-weight: 600;
}
.ld-feature-card--link:hover .ld-fc-more {
  gap: 8px;
}
.ld-feature-card:hover {
  border-color: var(--ol);
  transform: translateY(-3px);
}
.ld-fc-icon {
  width: 44px;
  height: 44px;
  background: var(--od);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--o);
  font-size: 1.2rem;
  margin-bottom: 1rem;
}
.ld-fc-title {
  font-weight: 700;
  margin-bottom: .4rem;
  font-size: .95rem;
  color: var(--txt);
}
.ld-fc-desc {
  font-size: .88rem;
  color: var(--mut);
  line-height: 1.6;
}

/* ── Pour qui ──────────────────────────────────────────────── */
.ld-forwho {
  padding: 5rem 0;
}
.ld-forwho-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-forwho-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-forwho-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
.ld-forwho-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.25rem;
}
.ld-forwho-card {
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 2rem 1.5rem;
  text-align: center;
  transition: border-color var(--tr), transform var(--tr);
}
.ld-forwho-card:hover {
  border-color: var(--ol);
  transform: translateY(-3px);
}
.ld-forwho-icon {
  width: 56px;
  height: 56px;
  background: var(--od);
  border-radius: 50%;
  margin: 0 auto 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--o);
  font-size: 1.4rem;
}
.ld-forwho-label {
  font-weight: 800;
  font-size: 1rem;
  margin-bottom: .5rem;
  color: var(--txt);
}
.ld-forwho-desc {
  font-size: .85rem;
  color: var(--mut);
  line-height: 1.6;
}

/* ── FAQ ────────────────────────────────────────────────────── */
.ld-faq {
  padding: 5rem 0;
  background: var(--c1);
}
.ld-faq-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-faq-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-faq-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
.ld-faq-list {
  max-width: 720px;
  margin: 0 auto;
}
.ld-faq-item {
  border-bottom: 1px solid var(--bdr);
}
.ld-faq-q {
  width: 100%;
  background: none;
  border: none;
  color: var(--txt);
  font-family: var(--font);
  font-size: .95rem;
  font-weight: 700;
  padding: 1.25rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  gap: 1rem;
  text-align: left;
}
.ld-faq-q i {
  color: var(--o);
  transition: transform var(--tr);
  flex-shrink: 0;
  font-size: 1rem;
}
.ld-faq-q.open i {
  transform: rotate(180deg);
}
.ld-faq-a {
  color: var(--mut);
  font-size: .9rem;
  line-height: 1.7;
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease, padding-bottom .35s ease;
  padding-bottom: 0;
}
.ld-faq-a.open {
  max-height: 300px;
  padding-bottom: 1.25rem;
}
.ld-faq-a p {
  margin: 0;
}

/* ── CTA final ─────────────────────────────────────────────── */
.ld-cta {
  padding: 5rem 0;
  text-align: center;
}
.ld-cta-inner {
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: 24px;
  padding: 4rem 2rem;
  position: relative;
  overflow: hidden;
}
.ld-cta-inner::before {
  content: '';
  position: absolute;
  top: -80px;
  left: 50%;
  transform: translateX(-50%);
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(247,147,29,.12) 0, transparent 65%);
  pointer-events: none;
}
.ld-cta-inner h2 {
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 900;
  letter-spacing: -.03em;
  position: relative;
}
.ld-cta-inner p {
  color: var(--mut);
  margin: 1rem 0 2rem;
  font-size: .95rem;
  line-height: 1.75;
  position: relative;
}
.ld-cta-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
}

/* ── Related ────────────────────────────────────────────────── */
.ld-related {
  padding: 3rem 0;
  border-top: 1px solid var(--bdr);
}
.ld-related-header {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--mut);
  margin-bottom: 1rem;
}
.ld-related-links {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}
.ld-related-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .85rem;
  font-weight: 600;
  color: var(--mut);
  border: 1px solid var(--bdr);
  padding: 8px 16px;
  border-radius: 50px;
  transition: var(--tr);
  text-decoration: none;
}
.ld-related-link:hover {
  color: var(--o);
  border-color: var(--ol);
}
.ld-related-link i {
  font-size: .8rem;
}

/* ── Points (toulouse / secteurs) ──────────────────────────── */
.ld-points {
  padding: 5rem 0;
}
.ld-points-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-points-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-points-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
.ld-points-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
}
.ld-point-card {
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 1.5rem;
  transition: border-color var(--tr), transform var(--tr);
}
.ld-point-card:hover {
  border-color: var(--ol);
  transform: translateY(-3px);
}

/* ── Services offered (toulouse hub) ───────────────────────── */
.ld-services-offered {
  padding: 5rem 0;
  background: var(--c1);
}
.ld-services-offered-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-services-offered-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-services-offered-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
.ld-service-card {
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 1.75rem 1.5rem;
  transition: border-color var(--tr), transform var(--tr);
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.ld-service-card:hover {
  border-color: var(--ol);
  transform: translateY(-3px);
}
.ld-service-card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--o);
  margin-top: auto;
  transition: gap var(--tr);
  text-decoration: none;
}
.ld-service-card-link:hover {
  gap: 10px;
}

/* ── Challenges / Solutions (secteurs) ─────────────────────── */
.ld-challenges {
  padding: 5rem 0;
  background: var(--c1);
}
.ld-challenges-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-challenges-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-challenges-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
/* 2. Défis — bordure gauche orange + icône chaude */
.ld-challenges .ld-feature-card {
  border-left: 3px solid var(--ol);
  padding-left: calc(1.5rem - 2px);
}
.ld-challenges .ld-feature-card:hover {
  border-left-color: var(--o);
}
.ld-challenges .ld-fc-icon {
  background: rgba(247,147,29,.15);
}

/* 5. Pont Défis → Solutions */
.ld-bridge {
  background: color-mix(in srgb, var(--bg) 92%, var(--o) 8%);
  border-top: 1px solid var(--ol);
  border-bottom: 1px solid var(--ol);
  padding: 1.5rem 0;
  text-align: center;
}
.ld-bridge-text {
  font-size: .95rem;
  font-weight: 800;
  color: var(--o);
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  letter-spacing: -.01em;
}
.ld-bridge-arrow {
  font-size: 1rem;
  opacity: .7;
}

.ld-solutions {
  padding: 5rem 0;
}
.ld-solutions-header {
  text-align: center;
  margin-bottom: 3rem;
}
.ld-solutions-header h2 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.ld-solutions-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
}
/* 3. Solutions — layout horizontal + checkmark sur icône */
.ld-solutions .ld-forwho-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
.ld-solutions .ld-forwho-card {
  flex-direction: row;
  text-align: left;
  padding: 1.5rem;
  gap: 1.25rem;
  align-items: flex-start;
}
.ld-solutions .ld-forwho-icon {
  margin: 0;
  flex-shrink: 0;
  background: rgba(247,147,29,.18);
  position: relative;
}
.ld-solutions .ld-forwho-icon::after {
  content: '✓';
  position: absolute;
  bottom: -4px;
  right: -4px;
  width: 16px;
  height: 16px;
  background: var(--o);
  color: #fff;
  border-radius: 50%;
  font-size: .6rem;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 16px;
}
.ld-solutions .ld-forwho-label,
.ld-solutions .ld-forwho-desc {
  text-align: left;
}

/* ══════════════════════════════════════════════════════════════
   HUB SECTEURS — page /fr/secteurs/
   ══════════════════════════════════════════════════════════════ */

/* Hero spécifique hub */
.sec-hub-hero {
  padding-bottom: 3rem;
}
/* 1. Grille de points en filigrane + glow renforcé */
.sec-hub-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(247,147,29,.14) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 90% 85% at 50% 0%, black 5%, transparent 65%);
  -webkit-mask-image: radial-gradient(ellipse 90% 85% at 50% 0%, black 5%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}
.sec-hub-hero .container {
  position: relative;
  z-index: 1;
}

/* Bandeau stats ─────────────────────────────────────────────── */
.sec-hub-stats {
  padding: 0 0 4rem;
}
/* 3. Stats — fond dégradé + ombre orange */
.sec-hub-stats-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: linear-gradient(135deg, var(--gl) 55%, color-mix(in srgb, var(--gl) 90%, var(--o) 10%));
  border: 1px solid var(--ol);
  border-radius: var(--r);
  padding: 2rem;
  flex-wrap: wrap;
  box-shadow: 0 4px 40px rgba(247,147,29,.08), inset 0 1px 0 rgba(255,255,255,.04);
}
.sec-hub-stat {
  flex: 1;
  min-width: 120px;
  text-align: center;
  padding: .5rem 1.5rem;
}
.sec-hub-stat-n {
  display: block;
  font-size: 2.6rem;
  font-weight: 900;
  letter-spacing: -.05em;
  color: var(--o);
  line-height: 1;
  margin-bottom: .35rem;
}
.sec-hub-stat-l {
  font-size: .75rem;
  color: var(--mut);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
}
.sec-hub-stat-sep {
  width: 1px;
  height: 36px;
  background: var(--bdr);
  flex-shrink: 0;
}

/* Grille listing secteurs ────────────────────────────────────── */
/* 4. Séparateur dégradé au-dessus de la grille */
.sec-hub-list {
  padding: 0 0 5rem;
  position: relative;
}
.sec-hub-list::before {
  content: '';
  display: block;
  width: 80px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--o), transparent);
  margin: 0 auto 4rem;
}
.sec-hub-list-header {
  text-align: center;
  margin-bottom: 3rem;
}
.sec-hub-list-header h2 {
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 900;
  letter-spacing: -.03em;
}
.sec-hub-list-header p {
  color: var(--mut);
  margin-top: .75rem;
  font-size: .95rem;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}
.sec-hub-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
/* 4e et 5e cartes centrées sur la 2e ligne */
.sec-hub-grid .sec-hub-card:nth-child(4) { grid-column: 1; }
.sec-hub-grid .sec-hub-card:nth-child(5) { grid-column: 2; }

/* 2. Numérotation automatique des cartes via CSS counter */
.sec-hub-grid {
  counter-reset: sec-card;
}

/* Carte secteur ─────────────────────────────────────────────── */
.sec-hub-card {
  counter-increment: sec-card;
  display: flex;
  flex-direction: column;
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 2rem 1.75rem;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--tr), transform var(--tr), background var(--tr);
  position: relative;
  overflow: hidden;
}
/* Numéro en filigrane */
.sec-hub-card::before {
  content: '0' counter(sec-card);
  position: absolute;
  bottom: .5rem;
  right: 1rem;
  font-size: 5.5rem;
  font-weight: 900;
  letter-spacing: -.06em;
  color: var(--txt);
  opacity: .04;
  line-height: 1;
  pointer-events: none;
  z-index: 0;
}
.sec-hub-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(247,147,29,.04) 0, transparent 70%);
  opacity: 0;
  transition: opacity var(--tr);
  pointer-events: none;
}
.sec-hub-card:hover {
  border-color: var(--ol);
  transform: translateY(-4px);
  background: color-mix(in srgb, var(--gl) 97%, var(--o) 3%);
}
.sec-hub-card:hover::after {
  opacity: 1;
}
.sec-hub-card-top {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1.25rem;
}
.sec-hub-card-icon {
  width: 48px;
  height: 48px;
  background: var(--od);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--o);
  font-size: 1.3rem;
  flex-shrink: 0;
  transition: background var(--tr);
}
.sec-hub-card:hover .sec-hub-card-icon {
  background: rgba(247,147,29,.2);
}
.sec-hub-card-badge {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--o);
  background: var(--od);
  padding: 4px 10px;
  border-radius: 50px;
}
.sec-hub-card-title {
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--txt);
  margin: 0 0 .75rem;
  line-height: 1.3;
}
.sec-hub-card-desc {
  font-size: .87rem;
  color: var(--mut);
  line-height: 1.65;
  margin: 0;
  flex-grow: 1;
}
.sec-hub-card-cta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--o);
  margin-top: 1.5rem;
  transition: gap var(--tr);
}
.sec-hub-card:hover .sec-hub-card-cta {
  gap: 10px;
}
.sec-hub-card-cta i {
  font-size: .85rem;
}

/* Encart secteur non listé ──────────────────────────────────── */
/* 4. Séparateur avant l'encart */
.sec-hub-custom {
  padding: 0 0 5rem;
  position: relative;
}
.sec-hub-custom::before {
  content: '';
  display: block;
  width: 80px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--bdr), transparent);
  margin: 0 auto 5rem;
}
.sec-hub-custom-inner {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  background: var(--gl);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  padding: 1.75rem 2rem;
  flex-wrap: wrap;
}
.sec-hub-custom-icon {
  font-size: 2rem;
  color: var(--o);
  flex-shrink: 0;
  opacity: .8;
}
.sec-hub-custom-body {
  flex: 1;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.sec-hub-custom-body strong {
  font-size: .95rem;
  font-weight: 800;
  color: var(--txt);
}
.sec-hub-custom-body span {
  font-size: .88rem;
  color: var(--mut);
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .sec-hub-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .sec-hub-grid .sec-hub-card:nth-child(5) {
    grid-column: 1 / -1;
    max-width: 480px;
    margin: 0 auto;
    width: 100%;
  }
  .sec-hub-grid .sec-hub-card:nth-child(4) {
    grid-column: auto;
  }
}

@media (max-width: 768px) {
  .ld-hero {
    padding: 4rem 0 2rem;
  }
  .ld-hero h1 {
    font-size: 1.9rem;
  }
  .ld-features-grid,
  .ld-forwho-grid,
  .ld-points-grid {
    grid-template-columns: 1fr;
  }
  .ld-solutions .ld-forwho-grid {
    grid-template-columns: 1fr;
  }
  .sec-hub-grid {
    grid-template-columns: 1fr;
  }
  .sec-hub-grid .sec-hub-card:nth-child(4),
  .sec-hub-grid .sec-hub-card:nth-child(5) {
    grid-column: auto;
  }
  .sec-hub-stat-sep {
    display: none;
  }
  .sec-hub-stats-inner {
    gap: 1.25rem;
  }
  .sec-hub-custom-inner {
    flex-direction: column;
    text-align: center;
  }
  .ld-cta-inner {
    padding: 2.5rem 1.25rem;
  }
  .ld-features,
  .ld-forwho,
  .ld-faq,
  .ld-cta,
  .ld-points,
  .ld-services-offered,
  .ld-challenges,
  .ld-solutions {
    padding: 3.5rem 0;
  }
}
