/* ============================================================
   Noumensia — feuille de style partagée
   Tokens, typographie et composants communs à toutes les pages
   ============================================================ */

/* ============ TOKENS ============ */
:root{
  --ardoise:      #1E2630;
  --ardoise-2:    #2A3440;  /* sections alternées, fond des "vitrines" sombres */
  --ardoise-3:    #3A4756;  /* bordures, séparateurs sur fond sombre */
  --bordeaux:     #7A1F2D;  /* aplats forts : CTA, bloc contact */
  --bordeaux-vif: #D98A95;  /* liens / accents lisibles sur fond sombre */
  --blanc-casse:  #F2EFEA;  /* texte principal sur fond sombre, fond des "vitrines" claires */
  --gris-doux:    #9AA7B5;  /* texte secondaire sur fond sombre */

  --font-display: "Newsreader", Georgia, serif;
  --font-body:    "IBM Plex Sans", -apple-system, sans-serif;
  --font-mono:    "IBM Plex Mono", "SF Mono", monospace;

  --maxw: 1180px;
  --pad:  clamp(1.25rem, 4vw, 3.5rem);
}

/* ============ RESET ============ */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation:none !important; transition:none !important; }
}
body{
  font-family:var(--font-body);
  background:var(--ardoise);
  color:var(--blanc-casse);
  line-height:1.65;
  font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:var(--bordeaux-vif); text-decoration:none; }
a:hover{ text-decoration:underline; }
a:focus-visible, button:focus-visible{
  outline:2px solid var(--bordeaux-vif);
  outline-offset:3px;
}
h1,h2,h3{ font-family:var(--font-display); font-weight:600; line-height:1.15; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }

/* ============ EYEBROW (motif "nœud") ============ */
.eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-mono); font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--gris-doux); margin-bottom:1rem;
}
.eyebrow::before{
  content:""; display:inline-block; width:8px; height:8px;
  border-radius:50%; background:var(--bordeaux-vif); flex-shrink:0;
}
.eyebrow--on-light{ color:var(--bordeaux); }
.eyebrow--on-light::before{ background:var(--bordeaux); }
.eyebrow--on-bordeaux{ color:var(--blanc-casse); }
.eyebrow--on-bordeaux::before{ background:var(--blanc-casse); }

/* ============ NAV ============ */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(30,38,48,.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--ardoise-3);
}
.nav .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:64px;
}
.brand{ display:flex; align-items:center; gap:.6rem; color:var(--blanc-casse); }
.brand:hover{ text-decoration:none; }
.brand-name{ font-family:var(--font-display); font-size:1.25rem; font-weight:600; letter-spacing:.01em; }
.nav-links{ display:flex; gap:1.75rem; list-style:none; }
.nav-links a{
  color:var(--blanc-casse); font-size:.92rem; font-weight:500;
  padding-bottom:.3rem; border-bottom:1px solid transparent;
}
.nav-links a:hover,
.nav-links a[aria-current="page"]{
  text-decoration:none; color:var(--bordeaux-vif);
  border-bottom-color:var(--bordeaux-vif);
}
.nav-toggle{
  display:none; background:none; border:1px solid var(--ardoise-3);
  color:var(--blanc-casse); border-radius:6px; padding:.5rem .75rem;
  font-family:var(--font-mono); font-size:.85rem; cursor:pointer;
}

/* ============ BOUTONS ============ */
.btn{
  font-family:var(--font-body); font-weight:600; font-size:.95rem;
  padding:.85rem 1.5rem; border-radius:4px; border:1px solid transparent;
  cursor:pointer; display:inline-block;
}
.btn--primary{ background:var(--bordeaux); color:var(--blanc-casse); }
.btn--primary:hover{ background:#8f2536; text-decoration:none; }
.btn--ghost{ border-color:var(--ardoise-3); color:var(--blanc-casse); }
.btn--ghost:hover{ border-color:var(--bordeaux-vif); color:var(--bordeaux-vif); text-decoration:none; }
.cta-row{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }

/* ============ HERO (accueil) ============ */
.hero{ padding:clamp(3rem,8vw,6rem) 0 clamp(2.5rem,6vw,4.5rem); }
.hero-grid{
  display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
.hero h1{
  font-size:clamp(2.3rem, 4.6vw, 3.6rem);
  letter-spacing:-.01em;
  margin-bottom:1.25rem;
}
.hero p{
  font-size:1.08rem; color:var(--gris-doux); max-width:34rem;
  margin-bottom:2rem;
}
.hero p em{ font-style:italic; color:var(--blanc-casse); }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:.9rem; }

/* ---- Diagramme signature (page d'accueil) ---- */
.diagram-svg{ width:100%; height:auto; }
.diagram-svg text{ font-family:var(--font-mono); }
.diagram-cap{ font-size:11px; letter-spacing:.16em; fill:var(--gris-doux); text-transform:uppercase; }
.node-top{ fill:var(--blanc-casse); }
.node-bottom{ fill:var(--ardoise-2); stroke:var(--gris-doux); stroke-width:1.5; }
.node-label-top{ font-size:12px; fill:var(--blanc-casse); }
.node-label-bottom{ font-size:12px; fill:var(--gris-doux); }
.edge{ stroke:var(--bordeaux-vif); stroke-width:1.25; stroke-opacity:.45; fill:none; }

/* ============ SECTIONS ============ */
.section{ padding:clamp(3rem,8vw,5.5rem) 0; }
.section--alt{ background:var(--ardoise-2); }
.section h2{
  font-size:clamp(1.7rem, 3vw, 2.4rem);
  max-width:42rem; margin-bottom:1.5rem;
}
.section .lede{
  color:var(--gris-doux); max-width:40rem; margin-bottom:2.25rem;
  font-size:1.02rem;
}
.prose{ max-width:42rem; }
.prose p{ margin-bottom:1.1rem; color:var(--blanc-casse); }
.prose h3{
  font-family:var(--font-display); font-size:1.25rem; font-weight:600;
  margin:2rem 0 .75rem;
}
.prose h3:first-child{ margin-top:0; }
.prose a{ text-decoration:underline; text-decoration-color:var(--ardoise-3); }
.prose a:hover{ text-decoration-color:var(--bordeaux-vif); }

/* ============ MODÈLES : cartes "vitrine" ============ */
.model-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem;
  margin-bottom:2rem;
}
.model-card{
  background:var(--blanc-casse); color:var(--ardoise);
  border-radius:6px; overflow:hidden; display:flex; flex-direction:column;
}
.model-shot{
  aspect-ratio:16/10; background:repeating-linear-gradient(
    45deg, rgba(30,38,48,.06), rgba(30,38,48,.06) 10px,
    transparent 10px, transparent 20px
  );
  border-bottom:1px solid rgba(30,38,48,.15);
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding:1rem;
}
.model-shot span{
  font-family:var(--font-mono); font-size:.75rem; letter-spacing:.06em;
  color:rgba(30,38,48,.55); text-transform:uppercase;
}
.model-body{ padding:1.25rem 1.4rem 1.5rem; display:flex; flex-direction:column; flex:1; }
.model-body .eyebrow{ margin-bottom:.6rem; }
.model-body h3{ font-size:1.18rem; margin-bottom:.6rem; color:var(--ardoise); }
.model-body p{ font-size:.92rem; color:#4a5566; margin-bottom:1.1rem; flex:1; }
.model-body .model-link{
  font-family:var(--font-mono); font-size:.85rem; font-weight:500;
  color:var(--bordeaux);
}
.model-note{ color:var(--gris-doux); font-size:.92rem; max-width:42rem; }

/* ============ DÉMONSTRATION : placeholder simulation ============ */
.demo-frame{
  background:var(--ardoise-2); border:1px solid var(--ardoise-3); border-radius:6px;
  aspect-ratio:16/7; display:flex; align-items:center; justify-content:center;
  margin-bottom:2.5rem; text-align:center; padding:2rem;
}
.demo-frame span{
  font-family:var(--font-mono); font-size:.85rem; color:var(--gris-doux);
  letter-spacing:.06em; text-transform:uppercase;
}

/* ============ MÉTHODE : étapes ============ */
.steps{
  display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
  margin:2.5rem 0 3rem; padding-top:2rem; border-top:1px solid var(--ardoise-3);
}
.step-num{
  display:block; font-family:var(--font-mono); font-size:.85rem;
  color:var(--bordeaux-vif); letter-spacing:.12em; margin-bottom:.6rem;
}
.steps h3{ font-size:1.15rem; margin-bottom:.6rem; }
.steps p{ color:var(--gris-doux); font-size:.92rem; }

/* ============ CITATION ============ */
.blockquote{
  border-left:2px solid var(--bordeaux-vif); padding-left:1.5rem; margin:1.75rem 0;
}
.blockquote p{
  font-family:var(--font-display); font-style:italic; font-size:1.15rem;
  color:var(--blanc-casse); line-height:1.55; margin-bottom:.5rem;
}
.blockquote cite{
  font-family:var(--font-mono); font-size:.8rem; color:var(--gris-doux);
  font-style:normal; letter-spacing:.04em;
}

/* ============ SOURCES ============ */
.sources{ list-style:none; margin-top:1.5rem; max-width:42rem; }
.sources li{
  font-family:var(--font-mono); font-size:.85rem; color:var(--gris-doux);
  padding:.6rem 0; border-top:1px solid var(--ardoise-3);
}
.sources li:last-child{ border-bottom:1px solid var(--ardoise-3); }
.sources li strong{ color:var(--blanc-casse); font-weight:500; }

/* ============ CONTACT ============ */
.contact{ background:var(--bordeaux); padding:clamp(3rem,8vw,5.5rem) 0; }
.contact h2{ color:var(--blanc-casse); max-width:38rem; }
.contact p{ color:#f4e4e7; max-width:36rem; margin-bottom:1.75rem; }
.contact-links{ display:flex; gap:1rem; flex-wrap:wrap; }
.contact-links a{
  font-family:var(--font-body); font-weight:600; font-size:.95rem;
  padding:.85rem 1.5rem; border-radius:4px; border:1px solid var(--blanc-casse);
  color:var(--blanc-casse);
}
.contact-links a:hover{ background:var(--blanc-casse); color:var(--bordeaux); text-decoration:none; }

/* ============ FOOTER ============ */
footer{ padding:2.5rem 0; border-top:1px solid var(--ardoise-3); }
footer .wrap{
  display:flex; flex-wrap:wrap; gap:1rem;
  justify-content:space-between; align-items:center;
  font-size:.85rem; color:var(--gris-doux);
}
footer ul{ list-style:none; display:flex; gap:1.5rem; flex-wrap:wrap; }
footer a{ color:var(--gris-doux); }
footer a:hover{ color:var(--bordeaux-vif); }

/* ============ RESPONSIVE ============ */
@media (max-width:860px){
  .nav-links{
    position:absolute; top:64px; left:0; right:0;
    background:var(--ardoise); border-bottom:1px solid var(--ardoise-3);
    flex-direction:column; gap:0; padding:.5rem var(--pad) 1rem;
    display:none;
  }
  .nav-links.is-open{ display:flex; }
  .nav-links a{ display:block; padding:.7rem 0; border-bottom:none; }
  .nav-toggle{ display:inline-block; }
  .hero-grid{ grid-template-columns:1fr; }
  .model-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; gap:1.75rem; }
}
@media (max-width:600px){
  .hero h1{ font-size:2rem; }
}
