/* ============================================================================
   STUDIO KIT — base.css
   Socle commun à toutes les sections : reset léger, typographie tokenisée,
   intégrité typographique (non négociable), primitives partagées (conteneur,
   eyebrow, boutons, cartes, reveal au scroll, marquee).

   Dépend de tokens.css (chargé AVANT). N'écrit JAMAIS de couleur en dur.
   ============================================================================ */

*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: var(--leading-body);
  color: var(--text-default);
  background: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background-color var(--dur-base) var(--ease-out-expo),
              color var(--dur-base) var(--ease-out-expo);
}

img, picture, svg { display: block; max-width: 100%; }
img { height: auto; }

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text-strong);
}

p { margin: 0; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }

/* — ⛔ INTÉGRITÉ TYPOGRAPHIQUE (non négociable Jimos) --------------------- */
p, li, dd, blockquote, figcaption {
  hyphens: manual;            /* jamais auto : pas de coupures « inter-/ruption » */
  overflow-wrap: break-word;  /* casse un mot trop long SANS tiret */
  text-wrap: pretty;          /* rag soigné, zéro orphelin */
}
h1, h2, h3, h4, h5, h6 { text-wrap: balance; }

/* — Focus visible cohérent (a11y) ---------------------------------------- */
:focus-visible {
  outline: var(--focus-width) solid var(--focus-ring);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* — Visible uniquement pour les lecteurs d'écran (texte hors-écran) ------- */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================================
   PRIMITIVES PARTAGÉES
   ============================================================================ */

/* Conteneur centré */
.sk-container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.sk-container--narrow { max-width: var(--container-sm); }

/* Une section = un rythme vertical + un fond pioché dans les surfaces */
.sk-section { padding-block: var(--section-y); position: relative; }
.sk-section--compact { padding-block: var(--section-y-compact); }
.sk-section--page    { background: var(--surface-page); color: var(--text-default); }
.sk-section--sunken  { background: var(--surface-sunken); color: var(--text-default); }
.sk-section--invert  { background: var(--surface-invert); color: var(--text-on-invert); }
.sk-section--invert h1,
.sk-section--invert h2,
.sk-section--invert h3,
.sk-section--invert h4 { color: var(--text-on-invert); }

/* Eyebrow / label de section (mono, capitales espacées) */
.sk-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--accent);
  white-space: nowrap;   /* libellé court : jamais cassé en deux (« NOTRE / CONVICTION ») */
}
.sk-eyebrow::before {
  content: "";
  width: 1.75rem;
  height: 1px;
  flex: none;            /* le filet garde sa longueur, ne se comprime pas */
  background: currentColor;
  opacity: 0.7;
}
.sk-eyebrow--center { justify-content: center; }  /* modificateur CSP-friendly (vs style inline) */
.sk-section--invert .sk-eyebrow { color: var(--accent); }

/* En-tête de section réutilisable */
.sk-head { max-width: 46ch; }
.sk-head--center { max-width: 56ch; margin-inline: auto; text-align: center; }
.sk-head__title { font-size: var(--text-h2); margin-top: var(--space-4); }
.sk-head__lead {
  margin-top: var(--space-4);
  font-size: var(--text-lead);
  line-height: var(--leading-snug);
  color: var(--text-muted);
}

/* Boutons */
.sk-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 48px;                 /* touch target ≥ 44px */
  padding: 0.85rem 1.6rem;
  font-family: var(--font-body);
  font-size: var(--text-small);
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-spring),
              background-color var(--dur-fast) var(--ease-out-expo),
              border-color var(--dur-fast) var(--ease-out-expo),
              color var(--dur-fast) var(--ease-out-expo);
}
.sk-btn:hover { transform: translateY(-2px); }
.sk-btn:active { transform: translateY(0); }
.sk-btn--primary {
  background: var(--accent);
  color: var(--text-on-accent);
}
.sk-btn--primary:hover { background: var(--accent-strong); }
.sk-btn--ghost {
  background: transparent;
  color: var(--text-strong);
  border-color: var(--border-strong);
}
.sk-btn--ghost:hover { border-color: var(--accent); color: var(--accent); }
.sk-section--invert .sk-btn--ghost { color: var(--text-on-invert); border-color: var(--border-invert); }

/* Lien fléché */
.sk-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
  color: var(--accent);
}
.sk-link svg { transition: transform var(--dur-fast) var(--ease-spring); }
.sk-link:hover svg { transform: translateX(4px); }

/* Pastille / pill */
.sk-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.35rem 0.85rem;
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: var(--radius-pill);
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid var(--accent-tint);
}

/* Carte générique surélevée */
.sk-card {
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-base) var(--ease-out-expo),
              box-shadow var(--dur-base) var(--ease-out-expo),
              border-color var(--dur-base) var(--ease-out-expo);
}
.sk-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent-tint);
}

/* Index / numéro éditorial (gros chiffres) */
.sk-index {
  font-family: var(--font-mono);
  font-size: var(--text-small);
  color: var(--accent);
}

/* Emplacement média réutilisable — quand la vraie photo n'est pas encore posée.
   Fines rayures diagonales + étiquette mono : se lit comme un slot ASSUMÉ, pas
   un vide. Poser une <img> par-dessus le masque pour le remplacer. 100% tokenisé. */
.sk-mediaph::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: repeating-linear-gradient(135deg,
    transparent 0 13px,
    color-mix(in srgb, var(--text-strong) 5%, transparent) 13px 14px);
}
.sk-mediaph__label {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 1;
  font-family: var(--font-mono); font-size: var(--text-mono);
  letter-spacing: var(--tracking-wide); text-transform: uppercase; white-space: nowrap;
  color: var(--text-muted); background: var(--surface-raised);
  padding: 0.5em 0.9em; border-radius: var(--radius-pill); border: 1px solid var(--border);
}

/* ============================================================================
   REVEAL AU SCROLL — doux, compositor-only (opacity + translate)
   Activé en JS par IntersectionObserver (ajout de .is-in).
   Fallback : sans JS, le contenu reste visible (.no-js).
   ============================================================================ */
.sk-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity var(--dur-reveal) var(--ease-out-expo),
              transform var(--dur-reveal) var(--ease-out-expo);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
.sk-reveal.is-in { opacity: 1; transform: none; }
.no-js .sk-reveal { opacity: 1; transform: none; }

/* ============================================================================
   MARQUEE — défilement infini par translation (2 copies, on translate de -50%)
   ============================================================================ */
.sk-marquee {
  position: relative;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.sk-marquee__track {
  display: flex;
  width: max-content;
  animation: sk-scroll var(--marquee-duration) linear infinite;
  will-change: transform;
}
.sk-marquee:hover .sk-marquee__track { animation-play-state: paused; }
.sk-marquee__track > * { flex: 0 0 auto; }
@keyframes sk-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================================
   ⛔ prefers-reduced-motion — on coupe TOUT mouvement, le contenu reste lisible
   ============================================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .sk-reveal { opacity: 1 !important; transform: none !important; }
  .sk-marquee__track { animation: none !important; }
  .sk-btn:hover, .sk-card:hover { transform: none !important; }
}
