/* ── Google Fonts ──────────────────────────────────────────────────────────── */
/* Polices officielles BistroBox (extraites des PDF de la graphiste) :
   - Sora          → display/titres (alternative libre à "Now Bold")
   - Public Sans   → corps de texte (identique aux PDF)
   - Inria Serif   → italiques d'emphase (identique aux PDF) */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Public+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,600&family=Inria+Serif:ital,wght@0,400;0,700;1,400;1,700&display=swap');

/* ══════════════════════════════════════════════════════════════════════════════
   VARIABLES — Charte BistroBox (extraites des PDF graphiste — cf. STYLE.md)
   Palette : cream #F1EADC · brown #5C4A3A · sage #A5B880
══════════════════════════════════════════════════════════════════════════════ */
:root {
  /* Fonds cream warm — variante claire (préférée) */
  --bb-bg:          #F1EADC;
  --bb-surface:     #FBF7EE;
  --bb-surface-alt: #E9E0CD;
  --bb-muted:       #E3D9C2;
  --bb-border:      #D8CCB0;
  /* Primary = sage green (accent de marque) */
  --bb-primary:     #A5B880;
  --bb-primary-dk:  #7A9660;
  --bb-primary-lt:  #E4EBD1;
  --bb-primary-fg:  #FBF7EE;
  /* Accent = brown (texte et wordmark) */
  --bb-accent:      #5C4A3A;
  --bb-accent-dk:   #3A2F23;
  --bb-warm:        #C9D6B1;
  --bb-accent-fg:   #FBF7EE;
  /* Typographie — valeurs de texte */
  --bb-text:        #5C4A3A;
  --bb-text-mid:    #6A584A;
  --bb-text-light:  #8B7A6A;
  --bb-text-xlight: #B5A699;
  --bb-error:       #B4412E;
  /* Fonts */
  --ff-heading: 'Sora', 'Public Sans', system-ui, sans-serif;
  --ff-body:    'Public Sans', system-ui, -apple-system, sans-serif;
  --ff-italic:  'Inria Serif', Georgia, serif;
  --fz-base:    1rem;
  --lh:         1.65;
  --radius:     0.75rem;
  --radius-sm:  0.4rem;
  --radius-xl:  1.5rem;
  --radius-pill: 9999px;
  --shadow-sm:  0 1px 4px rgba(92,74,58,.08);
  --shadow:     0 4px 16px rgba(92,74,58,.12);
  --shadow-lg:  0 12px 40px rgba(92,74,58,.16);
  --ease:       cubic-bezier(.4,0,.2,1);
  --dur:        240ms;
}

/* RESET & BASE */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--ff-body);font-size:var(--fz-base);line-height:var(--lh);color:var(--bb-text);background:var(--bb-bg);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-heading);font-weight:700;line-height:1.2;color:var(--bb-accent);letter-spacing:-.01em}
h1 em,h2 em,h3 em,h4 em,h5 em,h6 em{font-family:var(--ff-italic);font-style:italic;font-weight:400}
img,video,svg{display:block;max-width:100%}
a{color:var(--bb-primary);text-decoration:none}
a:hover{color:var(--bb-primary-dk)}
ul,ol{list-style:none}
button{cursor:pointer}
:focus-visible{outline:2px solid var(--bb-primary);outline-offset:3px;border-radius:var(--radius-sm)}

.skip-link{position:absolute;top:-100px;left:1rem;background:var(--bb-accent);color:var(--bb-accent-fg);padding:.5rem 1rem;border-radius:var(--radius-sm);z-index:9999;font-weight:600;transition:top var(--dur)}
.skip-link:focus{top:1rem}

/* LAYOUT */
.container{max-width:1160px;margin:0 auto;padding:0 1.5rem}

/* EYEBROW & SECTION HD */
.eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--bb-primary);margin-bottom:.75rem}
.section-hd{text-align:center;max-width:680px;margin:0 auto 4rem}
.section-hd h2{font-size:clamp(2rem,4.5vw,3rem);margin-bottom:1rem}
.section-hd h2 em{font-style:italic;color:var(--bb-primary)}
.section-lead{font-size:1.1rem;color:var(--bb-text-mid);line-height:1.7}

/* BOUTONS */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.9rem;border-radius:var(--radius-pill);font-family:var(--ff-body);font-size:.92rem;font-weight:600;letter-spacing:.02em;line-height:1;border:2px solid transparent;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);white-space:nowrap;text-decoration:none}
.btn--primary{background:var(--bb-primary);color:var(--bb-primary-fg);border-color:var(--bb-primary)}
.btn--primary:hover,.btn--primary:focus-visible{background:var(--bb-primary-dk);border-color:var(--bb-primary-dk);color:var(--bb-primary-fg);transform:translateY(-2px);box-shadow:0 6px 20px rgba(89,118,75,.35)}
.btn--ghost{background:transparent;color:var(--bb-accent);border-color:var(--bb-accent)}
.btn--ghost:hover,.btn--ghost:focus-visible{background:var(--bb-accent);color:var(--bb-primary-fg)}
.btn--outline{background:transparent;color:var(--bb-accent);border-color:var(--bb-accent)}
.btn--outline:hover,.btn--outline:focus-visible{background:var(--bb-accent);color:var(--bb-accent-fg)}
.btn--outline-light{background:transparent;color:rgba(246,244,238,.8);border-color:rgba(246,244,238,.4);font-size:.9rem;padding:.6rem 1.4rem}
.btn--outline-light:hover,.btn--outline-light:focus-visible{color:var(--bb-accent-fg);border-color:var(--bb-accent-fg);background:rgba(246,244,238,.1)}
.btn--lg{padding:.85rem 2.2rem;font-size:1rem}
.btn--full{width:100%;justify-content:center}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:900;padding:.85rem 0;background:transparent;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),padding var(--dur) var(--ease)}
.site-header.is-scrolled{background:rgba(241,234,220,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 20px rgba(92,74,58,.15);padding:.55rem 0}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;flex-direction:column;line-height:1;text-decoration:none}
.brand--stack{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.18rem;--brand-word-width:172px}
.brand__logo-slot{width:var(--brand-word-width);display:flex;justify-content:center;align-items:center;margin:0 auto}
.brand__logo{display:block;max-width:100%;height:auto}
.brand__logo--mark{width:22px;max-width:none}
.brand__logo--word{width:var(--brand-word-width);max-width:none}
.brand__logo--base{width:226px;max-width:none;transform:translateX(-2px)}
.brand__name{font-family:var(--ff-heading);font-size:1.55rem;font-weight:700;color:var(--bb-accent);letter-spacing:.01em}
.brand__sub{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bb-text-light);margin-top:.1rem}
.nav-menu{display:flex;align-items:center;gap:.25rem}
.nav-link{padding:.45rem .85rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--bb-text);transition:color var(--dur),background var(--dur)}
.nav-link:hover,.nav-link:focus-visible{color:var(--bb-accent);background:rgba(84,71,58,.07)}
.nav-cta{background:var(--bb-primary)!important;color:#fff!important;border-radius:var(--radius-pill);padding:.55rem 1.25rem;font-weight:600;letter-spacing:.02em}
.nav-cta:hover,.nav-cta:focus-visible{background:var(--bb-primary-dk)!important}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;padding:.4rem}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--bb-accent);border-radius:2px;transition:transform var(--dur) var(--ease),opacity var(--dur)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ANIMATIONS SCROLL */
.reveal{opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--delay,0s)}
.reveal--up{transform:translateY(40px)}
.reveal--left{transform:translateX(-40px)}
.reveal--right{transform:translateX(40px)}
.reveal.is-visible{opacity:1;transform:none}

/* SECTIONS */
.s-light{background:var(--bb-bg);padding:6rem 0}
.s-alt{background:var(--bb-surface);padding:6rem 0}
.s-dark{background:var(--bb-accent);padding:6rem 0;color:var(--bb-primary-fg);position:relative;overflow:hidden}
.s-dark::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(165,184,128,.15),transparent 60%),radial-gradient(ellipse at bottom left,rgba(165,184,128,.08),transparent 50%);pointer-events:none}
.s-dark>*{position:relative}
.s-dark .eyebrow{color:var(--bb-primary)}
.s-dark h2{color:var(--bb-primary-fg)}
.s-dark h2 em{color:var(--bb-primary)}
.s-dark .section-lead{color:rgba(251,247,238,.8)}
.s-dark p{color:rgba(251,247,238,.85)}
.s-contact{background:var(--bb-surface-alt);padding:6rem 0}

/* HERO */
.s-hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;background:var(--bb-bg);overflow:hidden;padding:7rem 0 4rem}
.s-hero__ornament{position:absolute;pointer-events:none;z-index:0;opacity:.15}
.s-hero__ornament--left{top:50%;left:-140px;transform:translateY(-50%) rotate(-8deg)}
.s-hero__ornament img{width:min(520px,40vw);height:auto;filter:saturate(.7)}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(30px,20px) scale(1.08)}}
.s-hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 420px;gap:4rem;align-items:center}
.s-hero__text{color:var(--bb-text)}
.s-hero__text .eyebrow{color:var(--bb-primary)}
.s-hero__title{font-size:clamp(2.6rem,5.5vw,4.4rem);font-weight:800;color:var(--bb-accent);line-height:1.1;margin-bottom:1.25rem;letter-spacing:-.015em}
.s-hero__title em{font-family:var(--ff-italic);font-style:italic;font-weight:400;color:var(--bb-primary-dk)}
.s-hero__sub{font-size:1.2rem;color:var(--bb-accent);font-weight:500;max-width:560px;margin-bottom:.9rem;line-height:1.55}
.s-hero__punch{font-family:var(--ff-italic);font-style:italic;font-size:1.1rem;color:var(--bb-primary-dk);font-weight:700;max-width:560px;margin-bottom:2.25rem;line-height:1.45}
.s-hero__desc{font-size:1.12rem;color:var(--bb-text-mid);max-width:520px;margin-bottom:2.25rem;line-height:1.75}
.s-hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hcard{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow)}
.hcard__badge{display:inline-block;background:var(--bb-primary);color:var(--bb-primary-fg);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .9rem;border-radius:999px;margin-bottom:1.5rem}
.hcard__list{display:flex;flex-direction:column;gap:.9rem;margin-bottom:1.75rem}
.hcard__list li{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--bb-text);font-weight:500}
.hcard__quote{font-family:var(--ff-heading);font-style:italic;font-size:1rem;color:var(--bb-text-light);border-top:1px solid var(--bb-border);padding-top:1.25rem;line-height:1.5}
.s-hero__scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);color:var(--bb-text-light);z-index:2;transition:color var(--dur)}
.s-hero__scroll:hover{color:var(--bb-text)}
.scroll-dot{animation:scrollDot 2s ease-in-out infinite}
@keyframes scrollDot{0%{transform:translateY(0);opacity:1}60%{transform:translateY(14px);opacity:0}61%{transform:translateY(0);opacity:0}100%{opacity:1}}

/* QUI SOMMES-NOUS */
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-bottom:4rem}
.about-text p{margin-bottom:1.1rem;color:var(--bb-text-mid);line-height:1.75}
.about-founders{display:flex;flex-direction:column;gap:1.25rem}
.founder-card{display:flex;gap:1.25rem;align-items:flex-start;background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm);transition:transform var(--dur),box-shadow var(--dur)}
.founder-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.founder-avatar{width:56px;height:56px;border-radius:50%;background:var(--bb-primary-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--bb-primary)}
.founder-card h3{font-size:1.05rem;margin-bottom:.2rem;color:var(--bb-accent)}
.founder-role{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--bb-primary);margin-bottom:.5rem}
.founder-card p{font-size:.9rem;color:var(--bb-text-light);margin:0}
.stats-row{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;padding:2.5rem;background:var(--bb-surface);border-radius:var(--radius-xl);border:1px solid var(--bb-border)}
.stat{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;min-width:120px}
.stat__num{font-family:var(--ff-heading);font-size:3rem;font-weight:700;color:var(--bb-primary);line-height:1}
.stat__label{font-size:.82rem;color:var(--bb-text-light);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-top:.3rem}
.stat > span:not(.stat__num):not(.stat__label){font-family:var(--ff-heading);font-size:2rem;font-weight:700;color:var(--bb-primary);line-height:1}

/* MISSION */
.mission-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.mission-quote{font-family:var(--ff-heading);font-style:italic;font-size:1.25rem;line-height:1.6;color:var(--bb-accent);border-left:3px solid var(--bb-primary);padding-left:1.5rem;margin-bottom:1.75rem}
.mission-text p{margin-bottom:1rem}
.mission-pillars{display:flex;flex-direction:column;gap:1.5rem}
.pillar{display:flex;gap:1.25rem;align-items:flex-start;background:rgba(255,255,255,.45);border:1px solid rgba(84,71,58,.12);border-radius:var(--radius);padding:1.25rem;transition:background var(--dur),box-shadow var(--dur)}
.pillar:hover{background:rgba(255,255,255,.65);box-shadow:var(--shadow-sm)}
.pillar__icon{flex-shrink:0;color:var(--bb-primary)}
.pillar h3{font-size:1rem;font-weight:600;color:var(--bb-accent);margin-bottom:.35rem}
.pillar p{font-size:.9rem;color:var(--bb-text-mid);margin:0}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem;margin-bottom:2rem}
.svc-card{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm);transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--bb-primary),var(--bb-primary-dk));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card__icon{color:var(--bb-primary);margin-bottom:1.25rem}
.svc-card h3{font-size:1.15rem;margin-bottom:.6rem;color:var(--bb-accent)}
.svc-card p{font-size:.9rem;color:var(--bb-text-mid);line-height:1.65;margin-bottom:1rem}
.svc-features{display:flex;flex-direction:column;gap:.4rem}
.svc-features li{font-size:.85rem;color:var(--bb-text-light);padding-left:1.5rem;position:relative}
.svc-features li::before{content:'';position:absolute;left:0;top:.2rem;width:.95rem;height:.95rem;background-image:url('../img/box.svg');background-repeat:no-repeat;background-size:contain;background-position:center}
.services-note{text-align:center;font-size:.9rem;color:var(--bb-text-light)}
.services-note a{color:var(--bb-primary);text-decoration:underline}

/* VALEURS */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.val-card{background:var(--bb-bg);border:1px solid var(--bb-border);border-radius:var(--radius);padding:1.75rem 1.5rem;text-align:center;transition:transform var(--dur),box-shadow var(--dur),background var(--dur);box-shadow:var(--shadow-sm)}
.val-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);background:var(--bb-primary-lt)}
.val-card__icon{color:var(--bb-primary);margin:0 auto 1rem}
.val-card h3{font-size:1.05rem;margin-bottom:.5rem;color:var(--bb-accent)}
.val-card p{font-size:.88rem;color:var(--bb-text-mid);line-height:1.6;margin:0}

/* POUR QUI */
.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.aud-card{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-sm);transition:transform var(--dur),box-shadow var(--dur)}
.aud-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.aud-card__icon{color:var(--bb-primary);margin-bottom:1rem}
.aud-card h3{font-size:1rem;margin-bottom:.5rem;color:var(--bb-accent)}
.aud-card p{font-size:.88rem;color:var(--bb-text-mid);line-height:1.6;margin:0}

/* CONFIANCE */
.trust-layout{display:grid;grid-template-columns:1fr 420px;gap:4rem;align-items:start}
.trust-list{display:flex;flex-direction:column;gap:1.5rem}
.trust-item{display:flex;gap:1.25rem;align-items:flex-start}
.trust-check{color:var(--bb-primary);flex-shrink:0;margin-top:.15rem}
.trust-item h3{font-size:1rem;font-weight:600;color:var(--bb-accent);margin-bottom:.3rem}
.trust-item p{font-size:.9rem;color:var(--bb-text-mid);margin:0}
.trust-quote{background:rgba(255,255,255,.45);border:1px solid rgba(84,71,58,.12);border-radius:var(--radius);padding:2rem;margin-bottom:1.75rem}
.trust-quote p{font-family:var(--ff-heading);font-style:italic;font-size:1.05rem;color:var(--bb-accent)!important;line-height:1.65;margin-bottom:1rem}
.trust-quote footer{font-size:.85rem;color:var(--bb-text-light);font-weight:600;letter-spacing:.05em}
.trust-badges{display:flex;flex-direction:column;gap:.85rem}
.trust-badge{display:flex;align-items:center;gap:1rem;background:rgba(255,255,255,.45);border:1px solid rgba(84,71,58,.1);border-radius:var(--radius);padding:.9rem 1.25rem}
.trust-badge__num{font-family:var(--ff-heading);font-size:1.8rem;font-weight:700;color:var(--bb-primary);line-height:1}
.trust-badge__icon{font-size:1.6rem}
.trust-badge__label{font-size:.88rem;color:var(--bb-text-mid);font-weight:500}
.trust-badge > span:not(.trust-badge__num):not(.trust-badge__label):not(.trust-badge__icon){font-family:var(--ff-heading);font-size:1.4rem;font-weight:700;color:var(--bb-primary);line-height:1}

/* CONTACT */
.contact-layout{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem;align-items:start}
.contact-direct{margin-bottom:2.5rem}
.contact-direct h3,.contact-reasons h3{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--bb-accent);margin-bottom:.85rem}
.contact-email{display:inline-flex;align-items:center;gap:.65rem;font-size:1.2rem;font-weight:600;color:var(--bb-primary);margin-bottom:.85rem;transition:color var(--dur)}
.contact-email:hover{color:var(--bb-primary-dk)}
.contact-direct p{font-size:.9rem;color:var(--bb-text-light)}
.contact-reasons ul{display:flex;flex-direction:column;gap:.55rem}
.contact-reasons li{font-size:.9rem;color:var(--bb-text-mid);padding-left:1.5rem;position:relative}
.contact-reasons li::before{content:'';position:absolute;left:0;top:.2rem;width:.95rem;height:.95rem;background-image:url('../img/box.svg');background-repeat:no-repeat;background-size:contain;background-position:center}
.contact-form-wrap{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:2.25rem;box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.15rem}
.form-group label{display:block;font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bb-text-mid);margin-bottom:.4rem}
.form-group label span[aria-hidden]{color:var(--bb-primary);margin-left:.2rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.7rem .95rem;background:var(--bb-bg);border:1.5px solid var(--bb-border);border-radius:var(--radius-sm);font-family:var(--ff-body);font-size:.95rem;color:var(--bb-text);line-height:1.5;transition:border-color var(--dur),box-shadow var(--dur)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--bb-text-xlight)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--bb-primary);box-shadow:0 0 0 3px rgba(89,118,75,.18)}
.form-group textarea{resize:vertical;min-height:130px}
.alert{display:flex;gap:1rem;align-items:flex-start;padding:1rem 1.25rem;border-radius:var(--radius-sm);margin-bottom:1.25rem}
.alert--success{background:var(--bb-primary-lt);border:1px solid var(--bb-primary);color:var(--bb-primary-dk)}
.alert--success svg{color:var(--bb-primary);flex-shrink:0}
.alert--success strong{display:block;font-weight:700}
.alert--success p{font-size:.9rem;margin:.2rem 0 0}
.alert--error{background:#fef2f2;border:1px solid #fecaca;color:var(--bb-error)}

/* FOOTER */
/* ══════════════════════════════════════════════════════════════════════════════
   FOOTER — refonte éditoriale (brand hero centré + divider sprig + colonnes)
══════════════════════════════════════════════════════════════════════════════ */
.site-footer{position:relative;background:var(--bb-accent);padding:4rem 0 2rem;color:rgba(251,247,238,.8);overflow:hidden}
.site-footer::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(165,184,128,.08),transparent 60%),radial-gradient(ellipse at bottom right,rgba(165,184,128,.05),transparent 50%);pointer-events:none}
.site-footer>*{position:relative}
.site-footer__top-ornament{position:absolute;top:0;left:0;right:0;color:var(--bb-primary);line-height:0;pointer-events:none}

/* GRILLE 3 COLONNES — Navigation / Contact / Social (version sobre sans brand hero) */
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3rem;max-width:960px;margin:0 auto 3rem;padding-top:1.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(251,247,238,.1)}
.footer-col h3{font-family:var(--ff-body);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--bb-primary);margin-bottom:1.2rem;position:relative;padding-bottom:.6rem}
.footer-col h3::after{content:'';position:absolute;left:0;bottom:0;width:28px;height:2px;background:var(--bb-primary);border-radius:2px}

/* Navigation column */
.footer-col--nav ul{display:flex;flex-direction:column;gap:.65rem}
.footer-col--nav a{font-size:.92rem;color:rgba(251,247,238,.75);transition:color var(--dur),padding var(--dur);display:inline-block;position:relative}
.footer-col--nav a::before{content:'›';position:absolute;left:-14px;opacity:0;transition:opacity var(--dur),transform var(--dur);color:var(--bb-primary)}
.footer-col--nav a:hover{color:var(--bb-primary-fg);padding-left:6px}
.footer-col--nav a:hover::before{opacity:1;transform:translateX(2px)}

/* Contact list with icons */
.footer-contact-list{display:flex;flex-direction:column;gap:.9rem;list-style:none;padding:0}
.footer-contact-list li{display:flex;align-items:center;gap:.7rem;font-size:.92rem;color:rgba(251,247,238,.85)}
.footer-contact-list__icon{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);background:rgba(165,184,128,.12);color:var(--bb-primary)}
.footer-contact-list a{color:rgba(251,247,238,.9);transition:color var(--dur)}
.footer-contact-list a:hover{color:var(--bb-primary)}

/* Social card (Instagram) */
.footer-social-card{display:flex;align-items:center;gap:.85rem;padding:.85rem 1.1rem;background:rgba(251,247,238,.05);border:1px solid rgba(251,247,238,.12);border-radius:var(--radius);color:rgba(251,247,238,.9);text-decoration:none;transition:background var(--dur),border-color var(--dur),transform var(--dur);margin-bottom:1.25rem}
.footer-social-card:hover{background:rgba(251,247,238,.09);border-color:var(--bb-primary);transform:translateY(-2px)}
.footer-social-card__icon{flex-shrink:0;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--bb-primary),var(--bb-primary-dk));color:#fff}
.footer-social-card__body{display:flex;flex-direction:column;gap:.1rem;line-height:1.2}
.footer-social-card__body strong{font-size:.92rem;font-weight:700;color:var(--bb-primary-fg)}
.footer-social-card__body small{font-size:.82rem;color:rgba(251,247,238,.6)}
.footer-col__cta{display:inline-flex!important}

/* FOOTER BOTTOM — copyright + made in CH */
.footer-bottom{text-align:center;font-size:.78rem;color:rgba(251,247,238,.35);padding-top:1rem}
.footer-bottom p{margin:.35rem 0}
.footer-bottom a{color:rgba(251,247,238,.55);transition:color var(--dur)}
.footer-bottom a:hover{color:var(--bb-primary)}
.footer-bottom__made{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:rgba(251,247,238,.5);font-weight:500}
.footer-bottom__heart{display:inline-block;vertical-align:middle;animation:heartbeat 1.6s ease-in-out infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}15%{transform:scale(1.15)}30%{transform:scale(1)}45%{transform:scale(1.1)}60%{transform:scale(1)}}

/* RESPONSIVE */
@media(max-width:1024px){
  .s-hero__inner,.about-layout,.mission-layout,.trust-layout,.contact-layout{grid-template-columns:1fr;gap:2.5rem}
  .s-hero__card{max-width:480px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  html{scroll-padding-top:64px}
  .s-light,.s-alt,.s-dark,.s-contact{padding:4rem 0}
  .brand--stack{--brand-word-width:152px}
  .brand__logo--mark{width:20px}
  .brand__logo--word{width:152px}
  .brand__logo--base{width:198px;transform:translateX(-1px)}
  .nav-toggle{display:flex}
  .nav-menu{position:fixed;inset:0 0 0 30%;background:var(--bb-accent-dk);flex-direction:column;align-items:flex-start;gap:0;padding:5rem 2rem 2rem;transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:-8px 0 32px rgba(0,0,0,.3);z-index:800}
  .nav-menu.is-open{transform:translateX(0)}
  .nav-link{width:100%;padding:.85rem .5rem;font-size:1.05rem;border-bottom:1px solid rgba(246,244,238,.08);border-radius:0;color:rgba(246,244,238,.85)}
  .nav-cta{margin-top:1.25rem;border-radius:var(--radius);border:none;background:var(--bb-primary);text-align:center;padding:.75rem 1rem;width:100%}
  .services-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .audience-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .form-row{grid-template-columns:1fr}
  .s-hero{padding:6rem 0 3rem}
  .s-hero__actions{flex-direction:column}
  .s-hero__actions .btn{width:100%;justify-content:center}
  .hcard{display:none}
}
@media(max-width:480px){
  .values-grid{grid-template-columns:1fr}
  .trust-layout{grid-template-columns:1fr}
}

/* ══ TICKER ══════════════════════════════════════════════════════════════════ */
.hero-ticker{position:absolute;bottom:0;left:0;right:0;overflow:hidden;background:var(--bb-accent);padding:.55rem 0;z-index:2}
.ticker-track{display:flex;gap:2rem;white-space:nowrap;width:max-content;animation:ticker 35s linear infinite}
.ticker-track span{font-size:.8rem;font-weight:500;letter-spacing:.04em;color:rgba(246,244,238,.85)}
.t-sep{color:var(--bb-primary)!important;opacity:.6!important}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ COUNTDOWN CARD ══════════════════════════════════════════════════════════ */
.s-hero__right{display:flex;align-items:center;justify-content:center}
.countdown-card{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-lg);width:100%}
.countdown-card__label{font-size:.85rem;font-weight:600;color:var(--bb-text-light);text-align:center;margin-bottom:1.25rem}
.countdown-card__label sup{font-size:.6em}
.countdown{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:1.5rem}
.cd-unit{display:flex;flex-direction:column;align-items:center;background:var(--bb-bg);border:1px solid var(--bb-border);border-radius:var(--radius);min-width:65px;padding:.7rem .4rem .45rem;transition:background var(--dur)}
.cd-unit span{font-family:var(--ff-heading);font-size:1.9rem;font-weight:700;color:var(--bb-primary);line-height:1;display:block;min-width:2ch;text-align:center}
.cd-unit small{font-size:.65rem;color:var(--bb-text-xlight);text-transform:uppercase;letter-spacing:.07em;margin-top:.25rem}
.cd-sep{font-family:var(--ff-heading);font-size:1.6rem;font-weight:700;color:var(--bb-accent);opacity:.35;margin-bottom:.5rem;user-select:none}
.cd-pills{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;list-style:none}
.cd-pills li{font-size:.78rem;font-weight:500;background:var(--bb-primary-lt);color:var(--bb-primary-dk);border-radius:999px;padding:.28rem .72rem;white-space:nowrap}

/* ══ HOW — Comment ça marche ═════════════════════════════════════════════════ */
/* (anciens .how-tabs / .how-tab / .how-panel retirés avec le design 3-étapes) */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
/* (anciens .how-steps / .how-step / .how-badge du design 3-étapes — retirés.
   Les nouvelles règles du design 4-étapes sont en bas du fichier.) */

/* ══ OFFRES ══════════════════════════════════════════════════════════════════ */
.offres-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.offre-card{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1.1rem;transition:transform var(--dur),box-shadow var(--dur);position:relative;overflow:hidden}
.offre-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--bb-primary),var(--bb-primary-dk))}
.offre-card--pro::before{background:linear-gradient(90deg,var(--bb-accent),var(--bb-accent-dk))}
.offre-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.offre-badge{display:inline-block;background:var(--bb-primary-lt);color:var(--bb-primary-dk);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .85rem;border-radius:999px;width:fit-content}
.offre-badge--pro{background:rgba(111,89,66,.1);color:var(--bb-accent-dk)}
.offre-card h3{font-size:1.4rem;color:var(--bb-accent);margin:0}
.offre-card>p{font-size:.95rem;color:var(--bb-text-mid);line-height:1.7;margin:0}
.offre-list{display:flex;flex-direction:column;gap:.5rem;flex:1;margin:0}
.offre-list li{font-size:.9rem;color:var(--bb-text);padding-left:1.7rem;position:relative;line-height:1.5}
.offre-list li::before{content:'';position:absolute;left:0;top:.2rem;width:1rem;height:1rem;background-image:url('../img/box.svg');background-repeat:no-repeat;background-size:contain;background-position:center}

/* ══ ABOUT condensé ══════════════════════════════════════════════════════════ */
.about-highlights{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.about-hl{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:1rem 1.1rem;text-align:center;flex:1;min-width:90px;transition:transform var(--dur)}
.about-hl:hover{transform:translateY(-3px)}
.about-hl__num{display:inline-block;font-family:var(--ff-heading);font-size:1.9rem;font-weight:700;color:var(--bb-primary);line-height:1}
.about-hl>span:not(.about-hl__num):not(.about-hl__icon){font-family:var(--ff-heading);font-size:1.4rem;font-weight:700;color:var(--bb-primary)}
.about-hl__icon{display:block;font-size:1.75rem;margin-bottom:.2rem;line-height:1}
.about-hl__icon svg{display:inline-block;vertical-align:middle}
.about-hl p{font-size:.8rem;color:var(--bb-text-light);margin:.35rem 0 0;line-height:1.4}

/* ══ SCROLL PROGRESS BAR ═════════════════════════════════════════════════════ */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--bb-primary),var(--bb-accent));transform-origin:left;transform:scaleX(0);z-index:1000;transition:transform .1s linear}

/* ══ RESPONSIVE additions ════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .s-hero__inner{grid-template-columns:1fr;gap:3rem}
  .s-hero__right{justify-content:flex-start}
  .countdown-card{max-width:420px}
  .offres-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .how-steps{grid-template-columns:1fr}
  .offres-grid{grid-template-columns:1fr}
  .about-layout{grid-template-columns:1fr}
}

/* ── Lang switcher ────────────────────────────────────────────────────────── */
.nav-right {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.lang-switcher {
  display: flex;
  gap: .25rem;
  align-items: center;
}

.lang-btn {
  display: inline-block;
  padding: .2rem .55rem;
  border-radius: 4px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--bb-accent);
  text-decoration: none;
  border: 1.5px solid transparent;
  transition: background .2s, border-color .2s, color .2s;
}
.lang-btn:hover {
  background: var(--bb-warm);
  border-color: var(--bb-warm);
  color: var(--bb-accent);
}
.lang-btn--active {
  background: var(--bb-primary);
  border-color: var(--bb-primary);
  color: #fff;
}

/* header scrollé : adapter la couleur du switcher */
.site-header.scrolled .lang-btn {
  color: var(--bb-accent);
}
.site-header.scrolled .lang-btn--active {
  background: var(--bb-primary);
  color: #fff;
}

@media (max-width: 768px) {
  .lang-switcher {
    display: none; /* masqué sur mobile — les liens ?lang= sont dans le menu */
  }
}

/* ══════════════════════════════════════════════════════════════════════════════
   NOUVELLES SECTIONS — charte PDF (refonte jan 2026)
══════════════════════════════════════════════════════════════════════════════ */

/* TICKER BAND — bandeau autonome entre hero et "Pourquoi" */
.ticker-band{background:var(--bb-accent);color:var(--bb-primary-fg);padding:.9rem 0;overflow:hidden;border-top:1px solid rgba(251,247,238,.08);border-bottom:1px solid rgba(251,247,238,.08)}
.ticker-band .ticker-track{display:flex;gap:2rem;white-space:nowrap;width:max-content;animation:ticker 40s linear infinite;align-items:center}
.ticker-band .ticker-track span:not(.t-sep){font-size:.85rem;font-weight:600;letter-spacing:.05em;color:rgba(251,247,238,.9);text-transform:uppercase}
.ticker-band .t-sep{color:var(--bb-primary);font-size:1rem;opacity:.8}

/* POURQUOI BISTROBOX — grid 6 puces sur fond sombre */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.why-card{background:rgba(251,247,238,.04);border:1px solid rgba(251,247,238,.1);border-radius:var(--radius);padding:2rem 1.75rem;transition:transform var(--dur),background var(--dur),border-color var(--dur)}
.why-card:hover{transform:translateY(-4px);background:rgba(251,247,238,.07);border-color:var(--bb-primary)}
.why-card__icon{width:56px;height:56px;border-radius:var(--radius-pill);background:rgba(165,184,128,.15);color:var(--bb-primary);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.why-card__icon svg{width:28px;height:28px}
.why-card h3{font-size:1.15rem;font-weight:700;color:var(--bb-primary-fg);margin-bottom:.6rem;line-height:1.3}
.why-card p{color:rgba(251,247,238,.75);font-size:.94rem;line-height:1.55}

/* COMMENT CA MARCHE — 4 étapes refondues */
.how-steps--4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;list-style:none;padding:0;margin:3rem 0 2.5rem;counter-reset:step}
.how-step{position:relative;background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:2.5rem 1.75rem 2rem;text-align:center;transition:transform var(--dur),box-shadow var(--dur)}
.how-step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.how-step__badge{position:absolute;top:-24px;left:50%;transform:translateX(-50%);width:48px;height:48px;border-radius:var(--radius-pill);background:var(--bb-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-heading);font-size:1.1rem;font-weight:700;box-shadow:0 6px 16px rgba(165,184,128,.35);letter-spacing:-.02em}
.how-step h3{font-size:1.08rem;font-weight:700;color:var(--bb-accent);margin-bottom:.6rem;margin-top:.5rem}
.how-step p{font-size:.92rem;color:var(--bb-text-mid);line-height:1.55}

/* MENUS — grid des régimes avec photos */
.menus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2.5rem}
.menus-grid .menu-card:first-child{grid-column:span 2}
.menu-card{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);overflow:hidden;transition:transform var(--dur),box-shadow var(--dur);display:flex;flex-direction:column}
.menu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.menu-card__media{aspect-ratio:3/2;overflow:hidden;background:var(--bb-muted)}
.menu-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.menu-card:hover .menu-card__media img{transform:scale(1.04)}
.menu-card__body{padding:1.5rem 1.5rem 1.75rem;flex:1;display:flex;flex-direction:column}
.menu-card__body h3{font-size:1.2rem;font-weight:700;color:var(--bb-accent);margin-bottom:.5rem}
.menu-card__body p{font-size:.94rem;color:var(--bb-text-mid);line-height:1.55}
.menus-footer{text-align:center;margin-top:2.5rem}

/* SEGMENTS — Pour qui ? */
.segments-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.segment-card{background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);padding:2rem 1.5rem;text-align:center;transition:transform var(--dur),box-shadow var(--dur),border-color var(--dur)}
.segment-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--bb-primary)}
.segment-card__icon{width:64px;height:64px;border-radius:var(--radius-pill);background:var(--bb-primary-lt);color:var(--bb-primary-dk);display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.segment-card__icon svg{width:30px;height:30px}
.segment-card h3{font-size:1.15rem;font-weight:700;color:var(--bb-accent);margin-bottom:.6rem}
.segment-card p{font-size:.9rem;color:var(--bb-text-mid);line-height:1.55}

/* BANDEAU ECO — mise en avant emballages */
.s-eco{background:var(--bb-primary-lt);padding:3rem 0;border-top:1px solid var(--bb-primary);border-bottom:1px solid var(--bb-primary)}
.s-eco__inner{display:flex;align-items:center;gap:2rem;justify-content:center;max-width:900px;margin:0 auto;padding:0 1.5rem}
.s-eco__icon{flex-shrink:0;width:80px;height:80px;border-radius:var(--radius-pill);background:var(--bb-primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(165,184,128,.3)}
.s-eco__icon svg{width:40px;height:40px}
.s-eco__text h3{font-size:1.4rem;font-weight:700;color:var(--bb-accent);margin-bottom:.4rem}
.s-eco__text p{font-size:.98rem;color:var(--bb-text-mid);line-height:1.55;margin:0}

/* SWISS BADGE — label Made in Switzerland
   Display flex + width:fit-content + margin:auto → forcé sur sa propre ligne,
   centré horizontalement dans .section-hd (indépendant de .eyebrow en inline-block) */
.swiss-badge{display:flex;width:fit-content;align-items:center;gap:.55rem;padding:.45rem 1rem;background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius-pill);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--bb-accent);margin:0 auto 1rem}
.swiss-badge__flag{display:inline-flex;align-items:center;line-height:0}
.swiss-badge__flag svg{display:block}

/* ABOUT — enrichissements bios + citation + photos */
.about-quote{margin:1.75rem 0;padding:1.25rem 1.5rem;background:var(--bb-primary-lt);border-left:4px solid var(--bb-primary);border-radius:0 var(--radius) var(--radius) 0}
.about-quote p{font-family:var(--ff-italic);font-style:italic;font-size:1rem;color:var(--bb-accent);line-height:1.6;margin:0}
.founder-photo{width:88px;height:88px;border-radius:var(--radius-pill);overflow:hidden;flex-shrink:0;background:var(--bb-muted);border:3px solid var(--bb-surface);box-shadow:var(--shadow-sm)}
.founder-photo img{width:100%;height:100%;object-fit:cover;display:block}
.founder-card{display:flex;gap:1.25rem;align-items:flex-start;padding:1.5rem;background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius);margin-bottom:1.25rem;transition:transform var(--dur),box-shadow var(--dur)}
.founder-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.founder-card__body{flex:1;min-width:0}
.founder-card__body h3{font-size:1.1rem;font-weight:700;color:var(--bb-accent);margin-bottom:.1rem}
.founder-role{display:block;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--bb-primary-dk);margin-bottom:.25rem}
.founder-meta{font-size:.82rem;color:var(--bb-text-light);margin-bottom:.75rem;font-weight:500}
.founder-quote{font-family:var(--ff-italic);font-style:italic;font-size:.9rem;color:var(--bb-text-mid);line-height:1.6;margin:0}

/* HOW BADGES — refonte style pills discrets */
.how-badges{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:3rem}
.how-badge{padding:.55rem 1.1rem;background:var(--bb-surface);border:1px solid var(--bb-border);border-radius:var(--radius-pill);font-size:.82rem;font-weight:600;color:var(--bb-text-mid);letter-spacing:.01em}

/* RESPONSIVE — nouvelles sections */
@media (max-width: 960px) {
  .why-grid,.segments-grid{grid-template-columns:repeat(2,1fr)}
  .how-steps--4{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem;margin-top:3.5rem}
  .menus-grid{grid-template-columns:repeat(2,1fr)}
  .menus-grid .menu-card:first-child{grid-column:span 2}
  .s-hero__ornament--left{display:none}
}
@media (max-width: 640px) {
  .why-grid,.segments-grid,.menus-grid,.how-steps--4{grid-template-columns:1fr}
  .menus-grid .menu-card:first-child{grid-column:auto}
  .s-eco__inner{flex-direction:column;text-align:center;gap:1.25rem;padding:1.5rem}
  .founder-card{flex-direction:column;align-items:center;text-align:center}
  .founder-photo{width:110px;height:110px}
}
