/* ══════════════════════════════════════════
   CPCP — global.css
   Design System v2 · Bricolage Grotesque + Lato
══════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  /* Accent palette */
  --coral:         #FB926B;
  --coral-bg:      #fddfd8;
  --mint:          #BAFAEE;
  --mint-bg:       #dffdf7;
  --periwinkle:    #BFCCFB;
  --periwinkle-bg: #dee5fd;
  --cream:         #FEECC2;
  --cream-grid:    #fbefd3;
  --rose:          #FFCEEC;
  --rose-mid:      #FF9DB8;
  --lavender:      #CDB8FF;

  /* Hero backgrounds */
  --hero-bg: var(--mint);

  /* Neutrals */
  --ink:      #161616;
  --ink-dark: #2a2a2a;
  --ink-70:   rgba(22,22,22,.7);
  --ink-mid:  #555555;
  --ink-soft: #888888;
  --ink-45:   rgba(22,22,22,.45);
  --ink-20:   rgba(22,22,22,.2);

  /* Surfaces */
  --body-bg: #F2F2F2;
  --white:   #ffffff;
  --mid:     #c8c8c8;
  --border:  #161616;

  /* Type */
  --display: 'Bricolage Grotesque', system-ui, sans-serif;
  --sans:    'Lato', system-ui, sans-serif;

  /* Shape */
  --r:        0px;
  --r-btn:    6px;
  --r-grid:   12px;

  /* Animations */
  --ease-out:    cubic-bezier(.23,1,.32,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  /* Content width */
  --max-w:      1240px;
  --max-w-wide: 1560px;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family: var(--sans);background:var(--body-bg);color:var(--ink);font-size:16.8px;line-height:1.75}
p{font-size:1rem;line-height:1.75}

/* ── TITRES → Bricolage Grotesque ── */
h1,h2,h3,h4,h5,h6,
.hero-title,.detail-title,.s-title,.act-title,
.fc-title,.pc-title,.res-title,.section-title,
.legal-title,.contact-title{
  font-family:var(--display);
}

/* ── CONTAINER ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 3rem}

/* ── BREADCRUMB ── */
.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-45);margin-bottom:1.5rem;flex-wrap:wrap}
.breadcrumb a{text-decoration:none;color:inherit;transition:color .2s}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb span{opacity:.4}

/* ── KICKER / EYEBROW ── */
.s-kicker,.section-kicker,.section-eyebrow,.page-kicker{
  font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--coral);display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem
}
.s-kicker::before,.section-kicker::before,.section-eyebrow::before,.page-kicker::before{
  content:'';width:22px;height:2px;background:var(--coral)
}

/* ── SECTION TITLE ── */
h2.s-title,h2.section-title{
  font-size:clamp(2rem,3.5vw,3.2rem);font-weight:700;
  letter-spacing:-.04em;line-height:1.06;margin-bottom:1.2rem
}
h2.s-title em,h2.section-title em{font-style:normal;font-weight:300;color:var(--ink-mid)}

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn-primary{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--coral);color:#fff;
  padding:.9rem 2rem;
  border:1.5px solid var(--border);
  border-radius:var(--r-btn);
  font-family: var(--sans);font-size:.95rem;font-weight:700;
  text-decoration:none;cursor:pointer;
  transition:background .22s var(--ease-out),
             transform .18s var(--ease-spring),
             box-shadow .22s var(--ease-out);
  box-shadow:0 2px 0 rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.15);
  position:relative;overflow:hidden;
}
.btn-primary::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 60%);
  border-radius:inherit;pointer-events:none;
}
.btn-primary:hover{
  background:var(--ink);
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 6px 0 rgba(0,0,0,.3),0 12px 24px rgba(0,0,0,.15);
}
.btn-primary:active{transform:translateY(1px) scale(.98);box-shadow:0 1px 0 rgba(0,0,0,.25)}

.btn-secondary{
  display:inline-flex;align-items:center;gap:.6rem;
  background:transparent;color:var(--ink);
  padding:.9rem 2rem;
  border:1.5px solid var(--border);
  border-radius:var(--r-btn);
  font-family: var(--sans);font-size:.95rem;font-weight:600;
  text-decoration:none;cursor:pointer;
  transition:background .22s var(--ease-out),color .22s,
             transform .18s var(--ease-spring),box-shadow .22s;
  position:relative;overflow:hidden;
}
.btn-secondary::before{
  content:'';position:absolute;inset:0;
  background:var(--ink);transform:scaleY(0);transform-origin:bottom;
  transition:transform .25s var(--ease-out);border-radius:inherit;z-index:0;
}
.btn-secondary>*{position:relative;z-index:1}
.btn-secondary:hover{color:#fff;transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.18)}
.btn-secondary:hover::before{transform:scaleY(1)}
.btn-secondary:active{transform:translateY(0) scale(.98)}

.btn-white{
  display:inline-flex;align-items:center;gap:.6rem;
  background:#fff;color:var(--ink);
  padding:.9rem 2rem;border:1.5px solid #fff;border-radius:var(--r-btn);
  font-family: var(--sans);font-size:.95rem;font-weight:700;
  text-decoration:none;cursor:pointer;
  transition:background .22s,color .22s,transform .18s var(--ease-spring),box-shadow .22s;
  box-shadow:0 2px 0 rgba(0,0,0,.2);
}
.btn-white:hover{background:var(--coral);color:#fff;border-color:var(--coral);transform:translateY(-3px);box-shadow:0 6px 20px rgba(251,146,107,.4)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.6rem;
  background:transparent;color:rgba(255,255,255,.7);
  padding:.9rem 2rem;border:1.5px solid rgba(255,255,255,.25);border-radius:var(--r-btn);
  font-family: var(--sans);font-size:.95rem;font-weight:600;
  text-decoration:none;cursor:pointer;
  transition:border-color .2s,color .2s,transform .18s var(--ease-spring),background .2s;
}
.btn-ghost:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px)}

.link-all{display:inline-flex;align-items:center;gap:.5rem;font-size:.92rem;font-weight:700;text-decoration:none;color:var(--ink);border-bottom:2px solid var(--ink);padding-bottom:3px;transition:color .2s,border-color .2s,gap .25s var(--ease-spring)}
.link-all:hover{color:var(--coral);border-color:var(--coral);gap:1rem}

/* ══════════════════════════════════════════
   BADGES & TAGS
══════════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .85rem;border:1.5px solid var(--ink)}
.badge-coral{background:var(--coral);color:#7a3015}
.badge-periwinkle{background:var(--periwinkle);color:#1a3080}
.badge-mint{background:var(--mint);color:#0a5c50}
.badge-cream{background:var(--cream);color:#7a5500}
.badge-ink{background:var(--ink);color:#fff;border-color:var(--ink)}
.badge-rose{background:var(--rose);color:#7a1a4a}
.badge-lavender{background:var(--lavender);color:#3a1a80}

.pill{display:inline-block;font-size:.7rem;font-weight:600;background:rgba(22,22,22,.07);color:var(--ink-dark);padding:.2rem .65rem;border:1px solid rgba(22,22,22,.2)}

/* ══════════════════════════════════════════
   CARDS
══════════════════════════════════════════ */
.act-card{background:#fff;border:1.5px solid var(--border);padding:2rem;box-shadow:3px 3px 0 rgba(0,0,0,.1);transition:transform .3s var(--ease-spring),box-shadow .3s var(--ease-out),border-color .2s;cursor:pointer;position:relative;overflow:hidden}
.act-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease-out)}
.act-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:6px 14px 0 rgba(0,0,0,.12),0 16px 32px rgba(0,0,0,.08);border-color:var(--coral)}
.act-card:hover::before{transform:scaleX(1)}
.ac-coral::before{background:var(--coral)}
.ac-mint::before{background:var(--mint)}
.ac-peri::before{background:var(--periwinkle)}
.ac-cream::before{background:var(--cream)}

.formation-card{background:#fff;border:1.5px solid var(--border);box-shadow:3px 3px 0 rgba(0,0,0,.1);overflow:hidden;cursor:pointer;transition:transform .3s var(--ease-spring),box-shadow .3s var(--ease-out),border-color .2s;display:flex;flex-direction:column}
.formation-card:hover{transform:translateY(-7px) scale(1.015);box-shadow:5px 16px 0 rgba(0,0,0,.12),0 20px 40px rgba(0,0,0,.08);border-color:var(--coral)}

.pcard{background:#fff;border:1.5px solid var(--ink);box-shadow:4px 4px 0 #c8c8c8;display:flex;flex-direction:column;cursor:pointer;position:relative;overflow:hidden;transition:box-shadow .28s var(--ease-out),transform .28s var(--ease-spring),border-color .2s}
.pcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.pcard:hover{transform:translate(-4px,-5px);box-shadow:8px 9px 0 #c8c8c8,0 20px 40px rgba(0,0,0,.1)}
.pcard:hover .pc-title{color:var(--coral)}
.pcard-coral::before{background:var(--coral)}
.pcard-peri::before{background:var(--periwinkle)}
.pcard-mint::before{background:var(--mint)}

.sidebar-card{background:#fff;border:1.5px solid var(--border);padding:1.5rem;box-shadow:3px 3px 0 rgba(0,0,0,.08)}
.sidebar-card-title{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1rem;padding-bottom:.6rem;border-bottom:1.5px solid var(--mid)}
.info-row{display:flex;justify-content:space-between;align-items:baseline;padding:.55rem 0;border-bottom:1px solid var(--mid);font-size:.9rem}
.info-row:last-child{border-bottom:none}
.info-label{color:var(--ink-45);font-size:.85rem}
.info-val{font-weight:600;color:var(--ink)}

/* ══════════════════════════════════════════
   FORMS
══════════════════════════════════════════ */
.form-field,.cf-input,.cf-textarea,.cf-select{
  width:100%;background:#fff;border:1.5px solid var(--border);
  padding:.85rem 1rem;font-family: var(--sans);font-size:.95rem;color:var(--ink);
  outline:none;transition:border-color .2s;display:block;border-radius:0;
}
.form-field:focus,.cf-input:focus,.cf-textarea:focus,.cf-select:focus{border-color:var(--coral)}
.form-field::placeholder,.cf-input::placeholder,.cf-textarea::placeholder{color:var(--ink-soft)}
textarea.form-field,textarea.cf-textarea{resize:vertical;min-height:120px}

.search-box{display:flex;align-items:center;max-width:480px;box-shadow:4px 4px 0 var(--coral-bg)}
.search-box input{flex:1;background:#fff;border:1.5px solid var(--border);padding:.85rem 1.1rem;font-family: var(--sans);font-size:.92rem;color:var(--ink);outline:none;transition:border-color .2s;border-right:none}
.search-box input:focus{border-color:var(--coral)}
.search-box input::placeholder{color:var(--ink-soft)}
.search-btn{background:var(--ink);color:#fff;border:1.5px solid var(--ink);padding:.85rem 1.1rem;cursor:pointer;transition:background .18s}
.search-btn:hover{background:var(--coral);border-color:var(--coral)}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:900;background:var(--body-bg);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 3rem;height:70px}
.admin-bar nav{top:32px}
@media screen and (max-width:782px){.admin-bar nav{top:46px}}

nav .logo{display:flex;align-items:center;text-decoration:none}
nav .logo img{height:112px;px;width:auto;display:block}

.nav-main{display:flex;align-items:center;gap:0;list-style:none}
.nav-main > li{position:relative}
.nav-main > li > a{display:flex;align-items:center;gap:.3rem;font-size:.93rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mid);text-decoration:none;padding:0 1.1rem;height:70px;transition:color .2s;white-space:nowrap}
.nav-main > li > a svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s}
.nav-main > li:hover > a{color:var(--ink)}
.nav-main > li:hover > a svg{transform:rotate(180deg)}

.dropdown{display:none;position:absolute;top:100%;left:0;min-width:220px;background:#fff;border:1.5px solid var(--border);box-shadow:4px 4px 0 rgba(0,0,0,.1);z-index:100;flex-direction:column}
.nav-main > li:hover .dropdown{display:flex}
.dropdown a{display:block;padding:.75rem 1.2rem;font-size:.90rem;font-weight:600;color:var(--ink-mid);text-decoration:none;border-bottom:1px solid var(--mid);transition:color .15s,background .15s}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{color:var(--ink);background:var(--body-bg)}

.nav-secondary{display:flex;align-items:center;gap:1.2rem;list-style:none}
.nav-secondary li a{font-size:.75rem;font-weight:500;color:var(--ink-soft);text-decoration:none;transition:color .2s;white-space:nowrap}
.nav-secondary li a:hover{color:var(--ink)}
.nav-btn{background:var(--coral) !important;color:#fff !important;padding:.5rem 1.2rem;border:1.5px solid var(--coral);font-weight:700 !important;font-size:.8rem;border-radius:var(--r-btn);transition:background .2s,transform .18s var(--ease-spring) !important}
.nav-btn:hover{background:var(--ink) !important;border-color:var(--ink) !important;transform:translateY(-2px)}

/* Body offset for fixed nav */
body{padding-top:70px}
.admin-bar body{padding-top:102px}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
footer{background:var(--ink)!important;color:rgba(255,255,255,.85)!important;padding:4rem 3rem 2rem;position:relative;z-index:99}
footer .container{max-width:var(--max-w);margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:2rem}
.footer-brand .logo{display:inline-block;margin-bottom:.8rem;text-decoration:none}
.footer-logo-img{height:112px;px;width:auto;display:block}
.footer-brand p{font-size:.82rem;line-height:1.75;color:rgba(255,255,255,.35);margin-top:.5rem}
.footer-social{display:flex;gap:.6rem;margin-top:1.2rem}
.social-btn{width:34px;height:34px;border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:border-color .2s,color .2s,background .2s}
.social-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.social-btn:hover{border-color:var(--coral);color:var(--coral)}
.footer-col h4{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:.9rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-col ul a{text-decoration:none;font-size:.85rem;color:rgba(255,255,255,.45);transition:color .2s}
.footer-col ul a:hover{color:var(--coral)}
.footer-newsletter h4{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:.9rem}
.footer-newsletter input{width:100%;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);padding:.75rem .9rem;color:#fff;font-family: var(--sans);font-size:.85rem;margin-bottom:.5rem;outline:none;border-radius:0}
.footer-newsletter input::placeholder{color:rgba(255,255,255,.25)}
.footer-newsletter input:focus{border-color:var(--coral)}
.btn-nl{width:100%;background:var(--coral);color:#fff;border:1.5px solid var(--coral);padding:.8rem;font-family: var(--sans);font-size:.85rem;font-weight:600;cursor:pointer;border-radius:var(--r-btn);transition:background .2s}
.btn-nl:hover{background:var(--ink);border-color:var(--ink)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.25)}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{font-size:.78rem;color:rgba(255,255,255,.25);text-decoration:none;transition:color .2s}
.footer-legal a:hover{color:var(--coral)}

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(32px) scale(.98);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0) scale(1)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

@keyframes up{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes popIn{0%{opacity:0;transform:scale(.8) translateY(12px)}60%{transform:scale(1.04) translateY(-2px)}100%{opacity:1;transform:scale(1) translateY(0)}}

/* ══════════════════════════════════════════
   SCROLLBAR
══════════════════════════════════════════ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--body-bg)}
::-webkit-scrollbar-thumb{background:var(--mid)}
::-webkit-scrollbar-thumb:hover{background:var(--coral)}

/* ══════════════════════════════════════════
   CURSOR POINTER GLOBAL
══════════════════════════════════════════ */
a, button, [onclick],
.pcard, .act-card, .formation-card, .team-card,
.ca-card, .related-item, .filter-item,
.sidebar-cta-btn, .fsc-contact-link,
.pn-card, .pcc-btn, .share-btn {
  cursor: pointer;
}

/* ══════════════════════════════════════════
   BLOCKQUOTE DESIGN SYSTEM
══════════════════════════════════════════ */
blockquote {
  border-left: 3px solid var(--coral);
  padding: 1rem 1.4rem;
  background: var(--cream-grid);
  border-right: 1.5px solid var(--mid);
  border-top: 1.5px solid var(--mid);
  border-bottom: 1.5px solid var(--mid);
  font-size: 1rem;
  font-style: italic;
  line-height: 1.7;
  color: var(--ink-dark);
  margin: 1.5rem 0;
}

/* ══════════════════════════════════════════
   BADGES — Design System
══════════════════════════════════════════ */
.badge {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: .3rem .85rem;
  border: 1.5px solid var(--ink);
}
.badge-coral      { background: var(--coral);      color: #7a3015; border-color: var(--coral); }
.badge-periwinkle { background: var(--periwinkle);  color: #1a3080; border-color: var(--periwinkle); }
.badge-mint       { background: var(--mint);        color: #0a5c50; border-color: var(--mint); }
.badge-cream      { background: var(--cream);       color: #7a5500; border-color: var(--cream); }
.badge-rose       { background: var(--rose);        color: #8a1050; border-color: var(--rose); }
.badge-lavender   { background: var(--lavender);    color: #3a1080; border-color: var(--lavender); }
.badge-ink        { background: var(--ink);         color: #fff;    border-color: var(--ink); }

.proj-type-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: .3rem .85rem; border: 1.5px solid;
}
.pc-badge {
  display: inline-flex; align-items: center;
  font-size: .68rem; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; padding: .2rem .6rem;
  border: 1.5px solid; line-height: 1.4;
}

/* ══════════════════════════════════════════
   CURSEUR ANIMÉ GLOBAL
══════════════════════════════════════════ */
#cur {
  width: 9px; height: 9px;
  background: var(--coral);
  border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: transform .12s, background .2s;
  mix-blend-mode: multiply;
}
#cur-r {
  width: 30px; height: 30px;
  border: 1.5px solid rgba(251,146,107,.4);
  border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: transform .3s cubic-bezier(.23,1,.32,1);
}
@media (hover: none) { #cur, #cur-r { display: none; } }

/* ══════════════════════════════════════════
   CORRECTIONS GLOBALES
══════════════════════════════════════════ */

/* ── pci-type en Bricolage Grotesque ── */
.pci-type {
  font-family: 'Bricolage Grotesque', var(--display), sans-serif !important;
  font-weight: 700;
}

/* ── pci-link → style link-all ── */
.pci-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .9rem;
  font-weight: 700;
  color: var(--ink) !important;
  text-decoration: none !important;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 1px;
  transition: color .2s, border-color .2s;
}
.pci-link:hover {
  color: var(--coral) !important;
  border-color: var(--coral);
}

/* ── pci-lieu plus grand ── */
.pci-lieu {
  font-size: 1rem !important;
  font-weight: 500;
}
.pci-lieu svg {
  width: 16px !important;
  height: 16px !important;
}

/* ── Corps de texte global ── */
p, li, td {
  font-size: 16.8px;
  line-height: 1.78;
}
.article-content p,
.proj-content p,
.fiche-body p,
.detail-body p {
  font-size: 16.8px;
  line-height: 1.82;
}

/* ── Pas d'italique dans les titres ── */
h1 em, h2 em, h3 em, h4 em,
.hero-title em, .anime-title em,
.s-title em, .section-title em,
.act-title em, .pc-title em {
  font-style: normal;
  font-weight: inherit;
  color: inherit;
}

/* ══════════════════════════════════════════
   NAV TOGGLE (hamburger)
══════════════════════════════════════════ */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1.5px solid var(--ink);
  border-radius: var(--r-btn);
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}
.nav-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--ink);
  border-radius: 1px;
  transition: transform .3s var(--ease-out), opacity .2s;
}
#siteNav.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
#siteNav.nav-open .nav-toggle span:nth-child(2) { opacity: 0; transform: scaleX(0); }
#siteNav.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── STICKY SCROLL STACK ── */
body.home [data-sticky-stack]{position:sticky;top:68px;box-shadow:0 -6px 32px rgba(0,0,0,.1);padding-bottom:8rem}

/* ══════════════════════════════════════════
   RESPONSIVE — 768px (tablette / mobile)
══════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Container */
  .container { padding: 0 1.25rem; }

  /* Nav */
  #siteNav {
    padding: 0 1.25rem;
    flex-wrap: wrap;
    height: auto;
    min-height: 60px;
    align-items: center;
  }
  body { padding-top: 60px; }

  .nav-toggle { display: flex; }

  .nav-main,
  .nav-secondary {
    display: none !important;
    width: 100%;
  }
  #siteNav.nav-open .nav-main,
  #siteNav.nav-open .nav-secondary {
    display: flex !important;
    flex-direction: column;
  }

  /* Nav-main items */
  .nav-main > li { width: 100%; position: static; }
  .nav-main > li > a {
    height: auto;
    padding: .85rem 0;
    border-bottom: 1px solid var(--mid);
    justify-content: space-between;
    font-size: .9rem;
  }
  .nav-main > li:last-child > a { border-bottom: none; }

  /* Dropdowns inline on mobile */
  .dropdown {
    position: static;
    display: none !important;
    box-shadow: none;
    border: none;
    padding-left: 1rem;
    background: transparent;
    border-radius: 0;
  }
  .nav-main > li.sub-open .dropdown { display: flex !important; }
  .dropdown a {
    padding: .65rem .8rem;
    font-size: .88rem;
    border-bottom: 1px solid var(--mid);
  }
  .dropdown a:last-child { border-bottom: none; }

  /* Nav secondary */
  .nav-secondary {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    border-top: 1.5px solid var(--mid);
    padding: .5rem 0 1.2rem;
  }
  .nav-secondary li { width: 100%; }
  .nav-secondary li a {
    display: block;
    padding: .75rem 0;
    font-size: .9rem;
    border-bottom: 1px solid var(--mid);
  }
  .nav-secondary li:last-child a { border-bottom: none; }
  .nav-btn {
    display: inline-flex !important;
    margin-top: .3rem;
    border-bottom: none !important;
  }

  /* Logo */
  nav .logo img { height: 44px; }

  /* Footer */
  .footer-top {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  footer { padding: 3rem 1.25rem 1.5rem; }
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: .6rem;
  }
  .footer-legal { flex-wrap: wrap; gap: 1rem; }
  body.home [data-sticky-stack]{position:static;box-shadow:none}
}

/* ══════════════════════════════════════════
   RESPONSIVE — 480px (mobile petit)
══════════════════════════════════════════ */
@media (max-width: 480px) {
  .container { padding: 0 1rem; }
  footer { padding: 2.5rem 1rem 1.5rem; }
  h2.s-title, h2.section-title { font-size: clamp(1.7rem, 7vw, 2.4rem); }
}
