/* ═══════════════════════════════════════════════════
   AUTREMENT AGENCY AFRICA — FEUILLE DE STYLE GLOBALE
   Charte : Bleu Minuit · Écru · Blanc cassé
   Typo   : Cormorant Garamond · EB Garamond · Tenor Sans
═══════════════════════════════════════════════════ */

/* ─── VARIABLES ─── */
:root {
  --blanc:    #F8F9FA;
  --nuit:     #0A2342;
  --ecru:     #E6D5B8;
  --ecru-dim: rgba(230,213,184,0.25);
  --nuit-dim: rgba(10,35,66,0.06);
  --tr:       0.6s cubic-bezier(0.25,0.46,0.45,0.94);
}

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--blanc); color:var(--nuit);
  font-family:'EB Garamond',Georgia,serif;
  font-size:1.05rem; line-height:1.78;
  cursor:none; overflow-x:hidden;
}

/* ─── GRAIN CINÉMATOGRAPHIQUE ─── */
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:8000;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.022;
}

/* ─── CURSEUR ─── */
.cursor {
  position:fixed; width:10px; height:10px;
  background:var(--ecru); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,background .3s;
}
.cursor-ring {
  position:fixed; width:36px; height:36px;
  border:1px solid var(--nuit); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .35s,height .35s;
}

/* ─── NAVIGATION ─── */
nav#nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.6rem 3.5rem;
  background:var(--blanc);
  border-bottom:1px solid transparent;
  transition:border-color .4s,padding .4s;
}
nav#nav.scrolled { border-color:var(--ecru); padding:1.1rem 3.5rem; }

.nav-logo {
  font-family:'Tenor Sans',sans-serif;
  font-size:.82rem; letter-spacing:.35em; text-transform:uppercase;
  color:var(--nuit); text-decoration:none;
  display:flex; flex-direction:column; gap:.1rem;
}
.nav-logo span {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:.68rem; letter-spacing:.22em;
  color:var(--ecru); text-transform:uppercase;
}

.nav-menu { display:flex; align-items:center; gap:2.4rem; list-style:none; }
.nav-menu a {
  font-family:'Tenor Sans',sans-serif; font-size:.66rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--nuit); text-decoration:none;
  position:relative; transition:color .3s;
}
.nav-menu a::after {
  content:''; position:absolute; bottom:-3px; left:0;
  width:0; height:1px; background:var(--ecru); transition:width .4s;
}
.nav-menu a:hover::after,
.nav-menu a.active::after { width:100%; }

.nav-cta {
  font-family:'Tenor Sans',sans-serif; font-size:.64rem;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--nuit); border:1px solid var(--ecru);
  padding:.55rem 1.3rem; text-decoration:none;
  transition:background .3s,color .3s;
}
.nav-cta:hover,
.nav-cta.active-cta { background:var(--nuit); color:var(--blanc); }
.nav-cta::after { display:none !important; }

/* ─── HERO — ACCUEIL ─── */
.hero {
  height:100vh; background:var(--nuit);
  display:flex; flex-direction:column;
  justify-content:flex-end; padding:0 3.5rem 5rem;
  position:relative; overflow:hidden;
}
.hero-vline {
  position:absolute; top:0; left:3.5rem;
  width:1px; height:100%; background:var(--ecru-dim);
}
.hero-vline.r { left:auto; right:3.5rem; }
.hero-counter {
  position:absolute; top:50%; right:3.5rem;
  transform:translateY(-50%);
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.3em; color:var(--ecru); writing-mode:vertical-rl; opacity:.45;
}
.hero-eyebrow {
  font-family:'Tenor Sans',sans-serif; font-size:.62rem;
  letter-spacing:.42em; text-transform:uppercase;
  color:var(--ecru); margin-bottom:2rem;
  opacity:0; animation:fadeUp .9s ease .3s forwards;
}
.hero-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(2.8rem,5.5vw,5.2rem); line-height:1.1;
  color:var(--blanc); max-width:800px;
  opacity:0; animation:fadeUp 1s ease .5s forwards;
}
.hero-title em { font-style:italic; color:var(--ecru); }
.hero-sig {
  margin-top:2.5rem;
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.35em; text-transform:uppercase; color:var(--ecru);
  opacity:0; animation:fadeUp .8s ease .9s forwards;
}
.hero-scroll {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.3em; text-transform:uppercase; color:var(--ecru);
  opacity:0; animation:fadeUp .8s ease 1.2s forwards;
}
.hero-scroll-line {
  width:1px; height:40px; background:var(--ecru);
  animation:scrollPulse 1.6s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%   { transform:scaleY(0); transform-origin:top; }
  50%  { transform:scaleY(1); transform-origin:top; }
  51%  { transform:scaleY(1); transform-origin:bottom; }
  100% { transform:scaleY(0); transform-origin:bottom; }
}

/* ─── ANCHOR STRIP ─── */
.anchor-strip {
  background:var(--nuit); border-top:1px solid rgba(230,213,184,.18);
  display:flex; overflow-x:auto; scrollbar-width:none;
}
.anchor-strip::-webkit-scrollbar { display:none; }
.anchor-strip a {
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.28em; text-transform:uppercase;
  color:rgba(248,249,250,.42); text-decoration:none;
  padding:1.2rem 2.4rem; white-space:nowrap;
  border-right:1px solid rgba(230,213,184,.1);
  transition:color .3s,background .3s; flex-shrink:0;
}
.anchor-strip a:hover,
.anchor-strip a.active { color:var(--ecru); background:rgba(230,213,184,.04); }

/* ─── PAGE HERO (sous-pages) ─── */
.page-hero {
  padding:140px 3.5rem 5rem;
  background:var(--nuit); min-height:54vh;
  display:flex; flex-direction:column; justify-content:flex-end;
  position:relative; border-bottom:1px solid rgba(230,213,184,.18);
}
.page-hero-vline {
  position:absolute; top:0; left:3.5rem;
  width:1px; height:100%; background:var(--ecru-dim);
}
.page-hero-eyebrow {
  font-family:'Tenor Sans',sans-serif; font-size:.58rem;
  letter-spacing:.42em; text-transform:uppercase; color:var(--ecru);
  margin-bottom:1.6rem;
  opacity:0; animation:fadeUp .8s ease .2s forwards;
}
.page-hero-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(2.4rem,4.8vw,4.6rem); line-height:1.1;
  color:var(--blanc); max-width:720px;
  opacity:0; animation:fadeUp 1s ease .4s forwards;
}
.page-hero-title em { font-style:italic; color:var(--ecru); }
.page-hero-intro {
  margin-top:2rem; max-width:560px;
  font-family:'EB Garamond',serif; font-size:1.12rem;
  line-height:1.82; color:rgba(248,249,250,.68);
  opacity:0; animation:fadeUp .8s ease .6s forwards;
}

/* ─── LAYOUT 2 COL + SIDEBAR ─── */
.two-col {
  display:grid; grid-template-columns:1fr 300px;
  border-bottom:1px solid var(--ecru);
}
.col-main { padding:6rem 4rem 6rem 3.5rem; }
.col-side {
  border-left:1px solid var(--ecru); padding:6rem 2.2rem;
  position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column; justify-content:space-between;
  background:var(--blanc);
}

/* ─── TYPOGRAPHIE SECTION ─── */
.lbl {
  font-family:'Tenor Sans',sans-serif; font-size:.54rem;
  letter-spacing:.45em; text-transform:uppercase; color:var(--ecru);
  display:block; margin-bottom:1.4rem;
}
.sec-num {
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.42em; color:var(--ecru); margin-bottom:1.6rem; display:block;
}
.sec-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(1.9rem,3vw,3.1rem); line-height:1.16;
  color:var(--nuit); margin-bottom:2rem; max-width:540px;
}
.sec-title em { font-style:italic; }
.sec-body {
  font-family:'EB Garamond',serif; font-size:1.08rem;
  line-height:1.88; color:var(--nuit); opacity:.82;
  max-width:510px; margin-bottom:2rem;
}

/* ─── CTA LIGNE ─── */
.cta-line {
  display:inline-flex; align-items:center; gap:1rem;
  font-family:'Tenor Sans',sans-serif; font-size:.62rem;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--nuit); text-decoration:none; transition:gap .3s;
}
.cta-line::after {
  content:''; width:40px; height:1px;
  background:var(--ecru); transition:width .4s;
}
.cta-line:hover { gap:1.6rem; }
.cta-line:hover::after { width:64px; }

/* ─── SIDEBAR INTERNE ─── */
.side-list { list-style:none; margin-bottom:2.5rem; }
.side-list li {
  font-family:'EB Garamond',serif; font-size:.9rem;
  color:var(--nuit); padding:.42rem 0;
  border-bottom:1px solid var(--ecru-dim); opacity:.72;
}
.side-contact p {
  font-family:'EB Garamond',serif; font-size:.88rem;
  line-height:1.72; color:var(--nuit); opacity:.62;
}
.side-socials { margin-top:1rem; display:flex; gap:1.2rem; }
.side-socials a {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--nuit); text-decoration:none; opacity:.42;
  transition:opacity .3s;
}
.side-socials a:hover { opacity:1; }

/* ─── SÉPARATEUR ─── */
.sep { border:none; border-top:1px solid var(--ecru); margin:3.5rem 0; }

/* ─── LISTE STYLÉE ─── */
.s-list { list-style:none; margin:2rem 0; }
.s-list li {
  display:flex; gap:1.2rem; align-items:flex-start;
  padding:.9rem 0; border-bottom:1px solid var(--ecru-dim);
  font-family:'EB Garamond',serif; font-size:1rem;
  line-height:1.7; color:var(--nuit); opacity:.82;
}
.s-list li::before {
  content:'—'; color:var(--ecru); flex-shrink:0;
  font-family:'Cormorant Garamond',serif;
}

/* ─── CITATION ─── */
.quote {
  border-left:1px solid var(--ecru); padding:1.8rem 2.8rem; margin:3rem 0;
}
.quote blockquote {
  font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:300;
  font-size:clamp(1.4rem,2vw,2rem); line-height:1.46;
  color:var(--nuit); margin-bottom:1.2rem;
}
.quote cite {
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--ecru); font-style:normal;
}

/* ─── GRILLE CONCEPTS (À Propos) ─── */
.concept-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0; margin:3rem 0; }
.concept-card {
  padding:2.6rem 2.2rem;
  border:1px solid var(--ecru); margin:-1px;
}
.concept-num {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:2.4rem; color:var(--ecru); line-height:1; margin-bottom:.9rem;
}
.concept-title {
  font-family:'Tenor Sans',sans-serif; font-size:.6rem;
  letter-spacing:.24em; text-transform:uppercase;
  color:var(--nuit); margin-bottom:.7rem;
}
.concept-body {
  font-family:'EB Garamond',serif; font-size:.95rem;
  line-height:1.75; color:var(--nuit); opacity:.68;
}

/* ─── GRILLE CLIENTS ─── */
.profiles-section { padding:5rem 3.5rem; border-bottom:1px solid var(--ecru); }
.sec-header {
  display:flex; align-items:center; gap:2rem; margin-bottom:4rem;
}
.sec-header::after { content:''; flex:1; height:1px; background:var(--ecru); }
.profiles-grid { display:grid; grid-template-columns:repeat(3,1fr); }
.profile-card {
  padding:2.6rem 2.2rem;
  border-right:1px solid var(--ecru);
  border-bottom:1px solid var(--ecru);
}
.profile-card:nth-child(3n) { border-right:none; }
.profile-card:nth-last-child(-n+3) { border-bottom:none; }
.profile-tag {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.4em; text-transform:uppercase;
  color:var(--ecru); margin-bottom:.9rem;
}
.profile-name {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:1.4rem; line-height:1.3;
  color:var(--nuit); margin-bottom:.7rem;
}
.profile-detail {
  font-family:'EB Garamond',serif; font-size:.92rem;
  color:var(--nuit); opacity:.58; line-height:1.65;
}

/* ─── FONDATRICE ─── */
.fondatrice-wrap {
  display:grid; grid-template-columns:380px 1fr;
  min-height:80vh; border-bottom:1px solid var(--ecru);
}
.fondatrice-visual {
  background:var(--nuit);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:3rem;
  border-right:1px solid rgba(230,213,184,.2);
}
.fondatrice-visual-placeholder {
  width:100%; aspect-ratio:4/5;
  background:rgba(230,213,184,.06);
  border:1px solid rgba(230,213,184,.2);
  display:flex; align-items:center; justify-content:center;
}
.fondatrice-visual-placeholder span {
  font-family:'Tenor Sans',sans-serif; font-size:.54rem;
  letter-spacing:.3em; text-transform:uppercase;
  color:rgba(230,213,184,.35);
}
.fondatrice-visual-caption {
  margin-top:1.8rem; font-family:'Tenor Sans',sans-serif;
  font-size:.52rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ecru); opacity:.5;
}
.fondatrice-content { padding:6rem 5rem 6rem 4.5rem; }
.fondatrice-doctrine {
  margin-top:2.5rem; margin-bottom:3rem;
  padding:2rem 2.5rem;
  border-left:1px solid var(--ecru);
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-size:clamp(1.4rem,2vw,1.9rem); line-height:1.5;
  color:var(--nuit);
}
.fondatrice-refuses {
  margin-top:2.5rem; padding-top:2rem;
  border-top:1px solid var(--ecru);
}
.fondatrice-refuses .lbl { margin-bottom:1.2rem; }

/* ─── PROJETS / ÉTUDES DE CAS ─── */
.cas-grid { display:grid; grid-template-columns:1fr; gap:0; }
.cas-card {
  display:grid; grid-template-columns:120px 1fr;
  padding:3.5rem; border-bottom:1px solid var(--ecru);
  transition:background .3s;
}
.cas-card:hover { background:var(--nuit-dim); }
.cas-num {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:3.5rem; color:var(--ecru); line-height:1;
  align-self:flex-start; padding-top:.3rem;
}
.cas-content {}
.cas-tag {
  font-family:'Tenor Sans',sans-serif; font-size:.52rem;
  letter-spacing:.38em; text-transform:uppercase;
  color:var(--ecru); margin-bottom:1rem; display:block;
}
.cas-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(1.5rem,2.2vw,2rem); line-height:1.25;
  color:var(--nuit); margin-bottom:1.2rem;
}
.cas-phases {
  display:flex; gap:2rem; flex-wrap:wrap; margin-bottom:1.5rem;
}
.cas-phase {
  font-family:'Tenor Sans',sans-serif; font-size:.52rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--nuit); opacity:.4;
}
.cas-phase.active { color:var(--ecru); opacity:1; }
.cas-body {
  font-family:'EB Garamond',serif; font-size:1rem;
  line-height:1.82; color:var(--nuit); opacity:.75; max-width:620px;
}

/* ─── BOUTIQUE ─── */
.boutique-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:0; border-bottom:1px solid var(--ecru);
}
.produit-card {
  padding:3.5rem 2.8rem;
  border-right:1px solid var(--ecru);
  border-bottom:1px solid var(--ecru);
  display:flex; flex-direction:column;
  transition:background .4s;
}
.produit-card:last-child { border-right:none; }
.produit-card:hover { background:var(--nuit-dim); }
.produit-maquette {
  width:100%; aspect-ratio:3/4;
  background:var(--nuit); margin-bottom:2rem;
  display:flex; align-items:flex-end; padding:1.5rem;
  position:relative; overflow:hidden;
}
.produit-maquette::before {
  content:''; position:absolute; top:0; left:0;
  width:3px; height:100%; background:var(--ecru);
}
.produit-maquette span {
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-weight:300; font-size:1.1rem; color:var(--blanc); line-height:1.3;
}
.produit-tag {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.38em; text-transform:uppercase;
  color:var(--ecru); margin-bottom:.8rem;
}
.produit-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:1.35rem; line-height:1.3;
  color:var(--nuit); margin-bottom:.8rem;
}
.produit-desc {
  font-family:'EB Garamond',serif; font-size:.92rem;
  line-height:1.72; color:var(--nuit); opacity:.65;
  flex:1; margin-bottom:2rem;
}
.produit-format {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--nuit); opacity:.38; margin-bottom:1.4rem;
}
.btn-commander {
  display:inline-flex; align-items:center; gap:.9rem;
  font-family:'Tenor Sans',sans-serif; font-size:.62rem;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--nuit); text-decoration:none; transition:gap .3s;
  align-self:flex-start;
}
.btn-commander::after {
  content:''; width:32px; height:1px;
  background:var(--ecru); transition:width .4s;
}
.btn-commander:hover { gap:1.4rem; }
.btn-commander:hover::after { width:52px; }

/* ─── BLOG / PLUME AUTREMENT ─── */
.plume-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:0; border-bottom:1px solid var(--ecru);
}
.article-card {
  padding:3.5rem; border-right:1px solid var(--ecru);
  border-bottom:1px solid var(--ecru);
  text-decoration:none; display:block; transition:background .3s;
}
.article-card:nth-child(2n) { border-right:none; }
.article-card:hover { background:var(--nuit-dim); }
.article-cat {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.38em; text-transform:uppercase;
  color:var(--ecru); margin-bottom:1rem; display:block;
}
.article-date {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.22em; color:var(--nuit); opacity:.35;
  margin-bottom:1.2rem; display:block;
}
.article-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(1.3rem,2vw,1.9rem); line-height:1.28;
  color:var(--nuit); margin-bottom:1.2rem;
}
.article-excerpt {
  font-family:'EB Garamond',serif; font-size:.96rem;
  line-height:1.78; color:var(--nuit); opacity:.65;
}

/* ─── ARTICLE SINGLE ─── */
.article-hero {
  padding:140px 3.5rem 4rem;
  background:var(--nuit); position:relative;
  border-bottom:1px solid rgba(230,213,184,.18);
}
.article-hero-vline {
  position:absolute; top:0; left:3.5rem;
  width:1px; height:100%; background:var(--ecru-dim);
}
.article-cat-hero {
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.4em; text-transform:uppercase; color:var(--ecru);
  margin-bottom:1.4rem; display:block;
}
.article-title-hero {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(2rem,4.2vw,4rem); line-height:1.12;
  color:var(--blanc); max-width:760px;
}
.article-meta {
  margin-top:2rem; display:flex; gap:3rem; align-items:center;
}
.article-meta span {
  font-family:'Tenor Sans',sans-serif; font-size:.52rem;
  letter-spacing:.28em; text-transform:uppercase; color:var(--ecru); opacity:.55;
}
.article-body-wrap {
  max-width:720px; margin:0 auto;
  padding:5rem 3.5rem;
}
.article-body-wrap p {
  font-family:'EB Garamond',serif; font-size:1.15rem;
  line-height:1.92; color:var(--nuit); margin-bottom:1.8rem;
}
.article-body-wrap h2 {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(1.5rem,2.2vw,2.2rem); line-height:1.3;
  color:var(--nuit); margin:3rem 0 1.5rem;
}
.article-body-wrap blockquote {
  border-left:1px solid var(--ecru); padding:1.5rem 2.5rem;
  margin:2.5rem 0;
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-size:1.3rem; line-height:1.5; color:var(--nuit);
}

/* ─── TALENTS ─── */
.talents-intro {
  padding:6rem 3.5rem;
  border-bottom:1px solid var(--ecru);
  max-width:800px;
}
.talents-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0; }
.talent-card {
  padding:3rem 2.8rem;
  border-right:1px solid var(--ecru);
  border-bottom:1px solid var(--ecru);
}
.talent-card:nth-child(2n) { border-right:none; }
.talent-card:nth-last-child(-n+2) { border-bottom:none; }

/* ─── CONTACT ─── */
.contact-layout {
  display:grid; grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--ecru);
}
.contact-left { padding:6rem 4rem 6rem 3.5rem; }
.contact-right {
  padding:6rem 3.5rem 6rem 4rem;
  border-left:1px solid var(--ecru);
}
.contact-right h2 {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(1.8rem,2.5vw,2.6rem); line-height:1.2;
  color:var(--nuit); margin-bottom:2rem;
}
.contact-detail { margin-top:3rem; display:flex; flex-direction:column; gap:1.6rem; }
.detail-item span {
  display:block; font-family:'Tenor Sans',sans-serif;
  font-size:.52rem; letter-spacing:.35em; text-transform:uppercase;
  color:var(--ecru); margin-bottom:.35rem;
}
.detail-item p, .detail-item a {
  font-family:'EB Garamond',serif; font-size:1rem;
  color:var(--nuit); opacity:.78; text-decoration:none;
}
.detail-item a:hover { opacity:1; text-decoration:underline; text-underline-offset:3px; }

/* ─── FORMULAIRE ─── */
.form-group { margin-bottom:2rem; }
.form-group label {
  display:block; font-family:'Tenor Sans',sans-serif;
  font-size:.52rem; letter-spacing:.35em; text-transform:uppercase;
  color:var(--nuit); margin-bottom:.7rem; opacity:.55;
}
.form-group input,
.form-group textarea,
.form-group select {
  width:100%; background:transparent;
  border:none; border-bottom:1px solid var(--ecru);
  padding:.7rem 0; font-family:'EB Garamond',serif;
  font-size:1rem; color:var(--nuit); outline:none;
  transition:border-color .3s; -webkit-appearance:none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { border-color:var(--nuit); }
.form-group textarea { resize:vertical; min-height:130px; }
.form-submit {
  background:var(--nuit); border:none; cursor:none;
  padding:1.1rem 2.8rem; font-family:'Tenor Sans',sans-serif;
  font-size:.62rem; letter-spacing:.3em; text-transform:uppercase;
  color:var(--blanc); transition:background .3s;
}
.form-submit:hover { background:var(--ecru); color:var(--nuit); }
.form-msg {
  padding:1rem 1.5rem; margin-bottom:1.5rem;
  font-family:'EB Garamond',serif; font-size:.95rem;
}
.form-msg.ok {
  border-left:2px solid var(--ecru); color:var(--nuit);
  background:rgba(230,213,184,.14);
}
.form-msg.err {
  border-left:2px solid var(--nuit); color:var(--nuit);
  background:rgba(10,35,66,.04);
}

/* ─── NEWSLETTER ─── */
.nl-section {
  padding:6rem 3.5rem; background:var(--nuit);
  display:flex; justify-content:space-between; align-items:center; gap:4rem;
  border-top:1px solid rgba(230,213,184,.12);
}
.nl-text .lbl { color:rgba(230,213,184,.45); }
.nl-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(1.8rem,2.5vw,2.8rem);
  color:var(--blanc); line-height:1.2;
}
.nl-form { display:flex; flex-shrink:0; min-width:380px; }
.nl-form input {
  flex:1; background:transparent;
  border:1px solid rgba(230,213,184,.28); border-right:none;
  padding:1rem 1.4rem; font-family:'EB Garamond',serif;
  font-size:1rem; color:var(--blanc); outline:none;
  transition:border-color .3s;
}
.nl-form input::placeholder { color:rgba(248,249,250,.28); }
.nl-form input:focus { border-color:var(--ecru); }
.nl-form button {
  background:var(--ecru); border:none; cursor:none;
  padding:1rem 1.8rem; font-family:'Tenor Sans',sans-serif;
  font-size:.58rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--nuit); transition:background .3s;
}
.nl-form button:hover { background:var(--blanc); }

/* ─── FOOTER ─── */
.site-footer {
  background:var(--nuit); border-top:1px solid rgba(230,213,184,.1);
  padding:4.5rem 3.5rem;
  display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:3.5rem;
}
.footer-brand .footer-logo {
  font-family:'Tenor Sans',sans-serif; font-size:.8rem;
  letter-spacing:.35em; text-transform:uppercase; color:var(--blanc);
}
.footer-brand .footer-tagline {
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-weight:300; font-size:1rem; color:var(--ecru); opacity:.65;
  margin-top:.3rem;
}
.footer-brand .footer-cities {
  margin-top:.8rem; font-family:'Tenor Sans',sans-serif;
  font-size:.52rem; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(248,249,250,.3);
}
.footer-socials { margin-top:1.6rem; display:flex; gap:1.5rem; }
.footer-socials a {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--ecru); text-decoration:none; opacity:.52;
  transition:opacity .3s;
}
.footer-socials a:hover { opacity:1; }
.footer-nav { list-style:none; }
.footer-nav li { margin-bottom:.7rem; }
.footer-nav a {
  font-family:'Tenor Sans',sans-serif; font-size:.56rem;
  letter-spacing:.2em; text-transform:uppercase;
  color:rgba(248,249,250,.38); text-decoration:none; transition:color .3s;
}
.footer-nav a:hover { color:var(--ecru); }
.footer-addr {
  font-family:'EB Garamond',serif; font-size:.9rem;
  line-height:1.85; color:rgba(248,249,250,.4);
}
.footer-addr a {
  color:rgba(230,213,184,.65); text-decoration:none; transition:color .3s;
}
.footer-addr a:hover { color:var(--ecru); }
.footer-bottom {
  background:var(--nuit); border-top:1px solid rgba(230,213,184,.07);
  padding:1.4rem 3.5rem;
  display:flex; justify-content:space-between; align-items:center;
}
.footer-bottom p {
  font-family:'Tenor Sans',sans-serif; font-size:.5rem;
  letter-spacing:.16em; color:rgba(248,249,250,.16);
}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .9s ease,transform .9s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }
.d1 { transition-delay:.1s; }
.d2 { transition-delay:.25s; }
.d3 { transition-delay:.42s; }

/* ─── RESPONSIVE ─── */
@media (max-width:1024px) {
  .boutique-grid { grid-template-columns:1fr 1fr; }
  .boutique-grid .produit-card:nth-child(2n) { border-right:none; }
}
@media (max-width:900px) {
  nav#nav { padding:1.2rem 1.5rem; }
  .nav-menu li { display:none; }
  .nav-menu li:last-child { display:block; }
  .hero, .page-hero, .article-hero { padding-left:1.5rem; padding-right:1.5rem; }
  .hero-vline { display:none; }
  .two-col { grid-template-columns:1fr; }
  .col-side { display:none; }
  .col-main { padding:4rem 1.5rem; }
  .concept-grid { grid-template-columns:1fr; }
  .profiles-grid { grid-template-columns:1fr; }
  .profile-card { border-right:none; }
  .plume-grid { grid-template-columns:1fr; }
  .article-card:nth-child(2n) { border-right:none; }
  .boutique-grid { grid-template-columns:1fr; }
  .produit-card { border-right:none; }
  .fondatrice-wrap { grid-template-columns:1fr; }
  .fondatrice-visual { min-height:50vh; }
  .fondatrice-content { padding:4rem 1.5rem; }
  .contact-layout { grid-template-columns:1fr; }
  .contact-right { border-left:none; border-top:1px solid var(--ecru); }
  .contact-left, .contact-right { padding:4rem 1.5rem; }
  .nl-section { flex-direction:column; padding:4rem 1.5rem; }
  .nl-form { min-width:100%; }
  .site-footer { grid-template-columns:1fr; padding:3rem 1.5rem; }
  .talents-grid { grid-template-columns:1fr; }
  .talent-card:nth-child(2n) { border-right:none; }
  .cas-card { grid-template-columns:70px 1fr; padding:2.5rem 1.5rem; }
  .profiles-section, .talents-intro { padding:4rem 1.5rem; }
  .article-body-wrap { padding:4rem 1.5rem; }
}
