/* ============================================================
   TAWSA — Pages d'activité (Cybersécurité, Infogérance, etc.)
   Surcouche tokens.css + homepage.css
   ============================================================ */

.activity-breadcrumb {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--tawsa-display);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--tawsa-anthracite);
  margin: 40px 0 32px;
  flex-wrap: wrap;
}
.activity-breadcrumb a {
  color: var(--tawsa-anthracite);
  transition: color var(--tawsa-duration) var(--tawsa-ease);
}
.activity-breadcrumb a:hover { color: var(--tawsa-dore); }
.activity-breadcrumb .sep { color: var(--tawsa-dore); opacity: 0.6; }
.activity-breadcrumb .current { color: var(--tawsa-bleu-nuit); font-weight: 500; }

/* — Hero — */
.activity-hero {
  padding: 40px 0 96px;
  border-top: none !important;
}
.activity-hero__eyebrow { margin-bottom: 28px; }
.activity-hero__title {
  font-family: var(--tawsa-serif);
  font-size: clamp(44px, 6.5vw, 76px);
  line-height: 1.04;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  letter-spacing: -0.022em;
  margin: 0 0 32px;
  max-width: 22ch;
  text-wrap: balance;
}
.activity-hero__title em { font-style: italic; color: var(--tawsa-dore); font-weight: 400; }
.activity-hero__sub {
  font-size: 19px;
  line-height: 1.6;
  color: var(--tawsa-anthracite);
  max-width: 56ch;
  margin: 0 0 48px;
}
.activity-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 48px;
  padding-top: 32px;
  border-top: 1px solid var(--tawsa-gris-bordure);
}
.activity-hero__meta > div {
  font-family: var(--tawsa-display);
  font-size: 14px;
  color: var(--tawsa-anthracite);
  line-height: 1.5;
}
.activity-hero__meta strong {
  display: block;
  color: var(--tawsa-dore);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

/* — Périmètre : grille 2x2 de cards — */
.scope-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--tawsa-gris-bordure);
  border: 1px solid var(--tawsa-gris-bordure);
  margin-top: 48px;
}
@media (max-width: 800px) { .scope-grid { grid-template-columns: 1fr; } }

.scope-card {
  background: white;
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
}
@media (max-width: 700px) { .scope-card { padding: 36px 28px; } }

.scope-card__num {
  font-family: var(--tawsa-serif);
  font-style: italic;
  font-size: 13px;
  color: var(--tawsa-dore);
  letter-spacing: 0.04em;
  margin-bottom: 18px;
}
.scope-card__icon {
  width: 40px;
  height: 40px;
  color: var(--tawsa-bleu-nuit);
  margin-bottom: 24px;
}
.scope-card__icon svg { width: 100%; height: 100%; }
.scope-card__title {
  font-family: var(--tawsa-serif);
  font-size: 24px;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  line-height: 1.2;
  margin: 0 0 14px;
  letter-spacing: -0.01em;
}
.scope-card__body {
  font-size: 15px;
  line-height: 1.65;
  color: var(--tawsa-anthracite);
  margin: 0 0 24px;
  max-width: 42ch;
}
.scope-card__list {
  list-style: none;
  margin: auto 0 0;
  padding: 20px 0 0;
  border-top: 1px solid var(--tawsa-gris-bordure);
  display: grid;
  gap: 10px;
}
.scope-card__list li {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--tawsa-display);
  font-size: 13px;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  line-height: 1.45;
}
.scope-card__list li::before {
  content: "→";
  color: var(--tawsa-dore);
  flex-shrink: 0;
  width: 14px;
}

/* — Méthode (timeline horizontale) — */
.method-section { background: var(--tawsa-blanc-casse); }
.method-timeline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 56px;
  position: relative;
}
@media (max-width: 1000px) { .method-timeline { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .method-timeline { grid-template-columns: 1fr; } }

.method-step {
  padding: 32px 28px 32px 0;
  border-top: 1px solid var(--tawsa-bleu-nuit);
  position: relative;
}
.method-step::before {
  content: "";
  position: absolute;
  top: -5px;
  left: 0;
  width: 9px;
  height: 9px;
  background: var(--tawsa-dore);
  border-radius: 50%;
}
.method-step__num {
  font-family: var(--tawsa-serif);
  font-style: italic;
  font-size: 32px;
  color: var(--tawsa-dore);
  line-height: 1;
  font-weight: 500;
  margin-bottom: 16px;
}
.method-step__title {
  font-family: var(--tawsa-serif);
  font-size: 20px;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  margin: 0 0 8px;
  letter-spacing: -0.005em;
}
.method-step__body {
  font-size: 14px;
  line-height: 1.6;
  color: var(--tawsa-anthracite);
  margin: 0 0 10px;
  max-width: 28ch;
}
.method-step__duration {
  font-family: var(--tawsa-display);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--tawsa-dore);
}

/* — Engagements — */
.engagements {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 64px;
  margin-top: 32px;
}
@media (max-width: 900px) { .engagements { grid-template-columns: 1fr; gap: 24px; } }

.engagements__rail {
  font-family: var(--tawsa-display);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--tawsa-dore);
}
.engagements__rail::before {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background: var(--tawsa-dore);
  margin-bottom: 18px;
}
.engagements__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
}
.engagements__list li {
  padding: 22px 0;
  border-top: 1px solid var(--tawsa-gris-bordure);
  display: flex;
  align-items: baseline;
  gap: 16px;
  font-size: 16px;
  line-height: 1.65;
  color: var(--tawsa-anthracite);
}
.engagements__list li:last-child { border-bottom: 1px solid var(--tawsa-gris-bordure); }
.engagements__list li::before {
  content: "✓";
  color: var(--tawsa-dore);
  font-family: var(--tawsa-display);
  font-weight: 600;
  font-size: 15px;
  flex-shrink: 0;
  width: 14px;
}
.engagements__list strong { color: var(--tawsa-bleu-nuit); font-weight: 500; }

/* — Stack / outils maîtrisés — */
.stack-section {
  padding-top: 0 !important;
}
.stack-grid {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 64px;
  margin-top: 32px;
}
@media (max-width: 900px) { .stack-grid { grid-template-columns: 1fr; gap: 24px; } }

.stack-grid__rail {
  font-family: var(--tawsa-display);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--tawsa-dore);
}
.stack-grid__rail::before {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background: var(--tawsa-dore);
  margin-bottom: 18px;
}
.stack-categories { display: grid; gap: 28px; }
.stack-cat__label {
  font-family: var(--tawsa-display);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--tawsa-dore);
  margin-bottom: 10px;
  display: block;
}
.stack-cat__tools {
  font-family: var(--tawsa-serif);
  font-size: 18px;
  color: var(--tawsa-bleu-nuit);
  line-height: 1.5;
  letter-spacing: -0.005em;
}
.stack-cat__tools em {
  font-style: italic;
  color: var(--tawsa-anthracite);
  font-size: 14px;
  font-family: var(--tawsa-sans);
  letter-spacing: 0;
}

/* — Cross-link autres expertises du pôle SI — */
.crosslinks {
  background: var(--tawsa-blanc-casse);
  border-top: 1px solid var(--tawsa-gris-bordure);
}
.crosslinks__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--tawsa-gris-bordure);
  border: 1px solid var(--tawsa-gris-bordure);
  margin-top: 48px;
}
@media (max-width: 900px) { .crosslinks__grid { grid-template-columns: 1fr; } }
.crosslink {
  background: white;
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: background var(--tawsa-duration) var(--tawsa-ease);
  text-decoration: none;
}
.crosslink:hover { background: var(--tawsa-blanc-casse); }
.crosslink__num {
  font-family: var(--tawsa-serif);
  font-style: italic;
  font-size: 13px;
  color: var(--tawsa-dore);
  letter-spacing: 0.04em;
}
.crosslink__title {
  font-family: var(--tawsa-serif);
  font-size: 22px;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  line-height: 1.2;
  letter-spacing: -0.005em;
  margin: 0;
}
.crosslink__body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--tawsa-anthracite);
  margin: 0 0 8px;
  flex: 1;
}
.crosslink__link {
  font-family: var(--tawsa-display);
  font-size: 12px;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--tawsa-bleu-nuit);
  align-self: flex-start;
  padding-bottom: 4px;
  transition: var(--tawsa-duration) var(--tawsa-ease);
}
.crosslink:hover .crosslink__link {
  color: var(--tawsa-dore);
  border-bottom-color: var(--tawsa-dore);
}

/* — Final CTA — */
.activity-cta {
  padding: 120px 0 !important;
  background: var(--tawsa-bleu-nuit);
  color: var(--tawsa-blanc-casse);
  text-align: center;
  border-top: none !important;
}
@media (max-width: 700px) { .activity-cta { padding: 80px 0 !important; } }
.activity-cta__eyebrow { margin-bottom: 32px; }
.activity-cta__eyebrow::before { background: var(--tawsa-dore); }
.activity-cta__title {
  font-family: var(--tawsa-serif);
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.1;
  font-weight: 500;
  color: var(--tawsa-blanc-casse);
  margin: 0 auto 24px;
  letter-spacing: -0.02em;
  text-wrap: balance;
  max-width: 22ch;
}
.activity-cta__title em { font-style: italic; color: var(--tawsa-dore); font-weight: 400; }
.activity-cta__sub {
  font-size: 17px;
  line-height: 1.6;
  color: rgba(248, 247, 244, 0.75);
  max-width: 52ch;
  margin: 0 auto 40px;
}
.activity-cta .tawsa-btn--primary {
  background: var(--tawsa-dore);
  color: var(--tawsa-bleu-nuit);
  padding: 18px 32px;
  font-size: 15px;
}
.activity-cta .tawsa-btn--primary:hover {
  background: var(--tawsa-blanc-casse);
}

/* — Slider on /systemes-information : ajout CTA "Découvrir" — */
.si-slide__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--tawsa-display);
  font-size: 13px;
  font-weight: 500;
  color: var(--tawsa-bleu-nuit);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--tawsa-bleu-nuit);
  align-self: flex-start;
  margin-top: 28px;
  transition: var(--tawsa-duration) var(--tawsa-ease);
  text-decoration: none;
}
.si-slide__link:hover {
  color: var(--tawsa-dore);
  border-bottom-color: var(--tawsa-dore);
}
.si-slide__link svg { transition: transform var(--tawsa-duration) var(--tawsa-ease); }
.si-slide__link:hover svg { transform: translateX(4px); }
