:root{
  --slate:#171411; --slate-2:#0C0B09; --chalk:#F2E9D2; --chalk-warm:#F7DDA4;
  --paper:#F1E9D2; --rust:#A23B1F; --rust-deep:#762B12; --gold:#C99E55;
  --cap:'Oswald',sans-serif;
  --hand:'Caveat',cursive;
  --sans:'Inter',system-ui,sans-serif;
  --line:#3A2F26;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:#1E1A14;font-family:var(--sans);line-height:1.55}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px}
a{color:inherit}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;background:var(--slate);color:var(--chalk);padding:8px 14px;z-index:99}
:focus-visible{outline:2.5px solid var(--rust);outline-offset:3px}

/* Masthead */
.masthead{background:var(--paper);border-bottom:6px double var(--slate);padding:14px 0}
.mh{display:flex;align-items:center;justify-content:space-between;gap:18px}
.mh-brand{display:flex;align-items:center;gap:16px}
.knife{font-family:var(--hand);font-size:2.4rem;color:var(--rust);line-height:1}
.mh-title{font-family:var(--cap);font-weight:600;font-size:1.6rem;letter-spacing:.005em;color:var(--slate);margin:0;text-transform:uppercase}
.mh-sub{font-family:var(--hand);font-size:1.1rem;color:#7E5F40;margin:0}
.mh-call{font-family:var(--cap);font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);text-decoration:none;border:2px solid var(--slate);padding:8px 16px;background:transparent}
.mh-call strong{color:var(--rust);font-weight:600}
.mh-call:hover{background:var(--slate);color:var(--chalk)}

/* Chalkboard hero */
.chalkboard{background:radial-gradient(ellipse at center,#2A211A 0%,var(--slate) 70%,var(--slate-2) 100%);color:var(--chalk);padding:80px 28px;position:relative;border-top:1px solid #3F352B;border-bottom:8px solid #4A3A2A;text-align:center}
.chalkboard::before,.chalkboard::after{content:"";position:absolute;left:0;right:0;height:14px;background:repeating-linear-gradient(90deg,#4A3A2A 0 32px,#3F312A 32px 64px)}
.chalkboard::before{top:-7px}
.chalkboard::after{bottom:-7px}
.chalk-wrap{max-width:880px;margin:0 auto}
.chalk-eyebrow{font-family:var(--hand);font-size:1.3rem;color:var(--chalk-warm);margin:0 0 18px;letter-spacing:.04em}
.chalk-hero{font-family:var(--cap);font-weight:700;font-size:clamp(2.8rem,7vw,5.6rem);line-height:1;margin:0 0 22px;letter-spacing:.005em;text-transform:uppercase;color:var(--chalk);text-shadow:0 1px 0 rgba(255,255,255,.1)}
.chalk-hero em{font-family:var(--hand);font-style:italic;font-weight:600;color:var(--chalk-warm);letter-spacing:0;font-size:.95em;text-transform:none}
.chalk-tag{font-family:var(--hand);font-size:clamp(1.3rem,2.4vw,1.8rem);color:#D9C893;margin:0 0 30px}
.chalk-meta{font-family:var(--cap);font-size:.95rem;letter-spacing:.12em;text-transform:uppercase;color:#B8A876;display:flex;flex-wrap:wrap;justify-content:center;gap:14px;align-items:center}
.chalk-meta .dot{color:var(--rust)}
.chalk-meta strong{color:var(--chalk-warm)}

/* Slate boards */
.board-wrap{padding:80px 0;background:var(--paper)}
.slate{background:var(--slate);color:var(--chalk);padding:36px 32px;margin-bottom:30px;border-radius:6px;border:6px solid #5A4530;box-shadow:0 6px 0 #4A3A2A,0 12px 30px rgba(0,0,0,.18);position:relative}
.slate:last-child{margin-bottom:0}
.slate::after{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border:1px dashed rgba(242,233,210,.18);pointer-events:none}
.slate-h{display:flex;align-items:baseline;gap:18px;margin-bottom:22px;border-bottom:1px dashed rgba(242,233,210,.25);padding-bottom:14px}
.slate-no{font-family:var(--hand);font-size:2.6rem;color:var(--gold);line-height:1}
.slate-h h2{font-family:var(--cap);font-weight:600;font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:.02em;margin:0;text-transform:uppercase;color:var(--chalk-warm)}
.slate-rows{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.slate-rows li{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;font-family:var(--cap);font-size:1.05rem;letter-spacing:.02em}
.cut{color:var(--chalk);font-weight:500}
.origin{font-family:var(--hand);font-size:1.1rem;color:#C9B989;font-weight:400}
.slate-rows .dots{flex:1;border-bottom:2px dotted #5A4530;align-self:end;margin-bottom:5px;min-width:30px}
.price{color:var(--chalk-warm);font-weight:600;letter-spacing:.04em}
.slate-foot{margin:18px 0 0;font-family:var(--hand);font-size:1.1rem;color:#A89878;font-style:italic;line-height:1.4}

/* Counter trio */
.counter-trio{padding:80px 0;background:var(--paper)}
.ct-h{text-align:center;margin-bottom:50px}
.ct-mark{display:block;font-family:var(--hand);color:var(--rust);font-size:1.4rem;margin-bottom:8px}
.ct-h h2,.ct-h.h2{font-family:var(--cap);font-weight:600;font-size:clamp(2rem,4vw,3rem);text-transform:uppercase;margin:0;color:var(--slate);letter-spacing:.005em}
.ct-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.counter-trio article{background:var(--slate);color:var(--chalk);padding:28px 24px;border-radius:4px;border-top:5px solid var(--rust)}
.ct-num{font-family:var(--hand);font-size:3.6rem;color:var(--rust);line-height:1;display:block;margin-bottom:10px}
.counter-trio article h3{font-family:var(--cap);font-weight:600;font-size:1.4rem;color:var(--chalk-warm);margin:0 0 12px;text-transform:uppercase;letter-spacing:.02em}
.counter-trio article p{margin:0;color:#C9B989;font-size:.95rem}

/* Philo */
.philo{padding:80px 0;background:var(--slate);color:var(--chalk)}
.philo-h{font-family:var(--cap);font-weight:600;font-size:clamp(2rem,4vw,2.8rem);text-transform:uppercase;color:var(--chalk-warm);margin:0 0 36px;text-align:center;letter-spacing:.005em}
.philo-list{list-style:none;padding:0;margin:0;display:grid;gap:0;max-width:840px;margin-left:auto;margin-right:auto}
.philo-list li{display:grid;grid-template-columns:80px 1fr;gap:24px;padding:24px 0;border-top:1px dashed rgba(242,233,210,.2)}
.philo-list li:last-child{border-bottom:1px dashed rgba(242,233,210,.2)}
.philo-no{font-family:var(--cap);font-weight:700;font-size:2.4rem;color:var(--gold);line-height:1}
.philo-list strong{font-family:var(--cap);font-weight:600;color:var(--chalk-warm);text-transform:uppercase;letter-spacing:.04em;font-size:1.1rem;display:block;margin-bottom:6px}
.philo-list p,.philo-list div{margin:0;color:#C9B989}

/* Testi */
.testi{padding:80px 0;background:var(--paper)}
.testi h2{margin-bottom:50px}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.testi figure{margin:0;padding:24px 22px;background:#F8F0D8;border:1px dashed var(--slate);border-radius:3px}
.testi blockquote{margin:0 0 12px;font-family:var(--hand);font-size:1.25rem;color:var(--slate);line-height:1.4}
.testi figcaption{font-family:var(--cap);font-size:.85rem;color:var(--rust);letter-spacing:.1em;text-transform:uppercase}

/* QA */
.qa{padding:80px 0;background:var(--paper)}
.qa h2{margin-bottom:30px}
.qa-list{max-width:880px;margin:0 auto;display:grid;gap:0}
.qa details{border-top:1px solid var(--slate);padding:18px 0}
.qa details:last-child{border-bottom:1px solid var(--slate)}
.qa summary{font-family:var(--cap);font-weight:500;font-size:1.2rem;text-transform:uppercase;color:var(--slate);cursor:pointer;list-style:none;position:relative;padding-right:40px;letter-spacing:.04em}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);color:var(--rust);font-family:var(--hand);font-size:2rem;transition:transform .25s}
.qa details[open] summary::after{content:"×"}
.qa p{margin:14px 0 6px;color:#3F352A;font-family:var(--sans)}

/* Big foot */
.bigfoot{padding:90px 0;background:var(--slate);color:var(--chalk);text-align:center;background-image:radial-gradient(ellipse at center,#28201A 0%,var(--slate) 100%)}
.bf-kicker{font-family:var(--hand);font-size:1.4rem;color:var(--gold);margin:0 0 18px}
.bf-phone{display:inline-block;font-family:var(--cap);font-weight:700;font-size:clamp(2.4rem,7vw,4.8rem);color:var(--chalk-warm);text-decoration:none;letter-spacing:.005em;border-top:2px solid var(--rust);border-bottom:2px solid var(--rust);padding:12px 28px;text-transform:uppercase;margin-bottom:24px}
.bf-phone:hover{color:#fff}
.bf-addr{font-family:var(--cap);font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:#C9B989;margin:14px 0 6px}
.bf-hours{font-family:var(--hand);font-size:1.2rem;color:#A89878;margin:0}

/* Foot */
.foot{padding:32px 28px;background:var(--slate-2);color:#8B7E62;text-align:center}
.foot p{margin:0 0 6px;font-family:var(--cap);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}
.foot .craft{color:#C9B989;font-family:var(--sans);font-size:.78rem;text-transform:none;letter-spacing:0}
.foot strong{color:var(--rust);font-weight:600}

@media (max-width:780px){
  .mh{flex-direction:column;align-items:stretch}
  .mh-call{text-align:center}
  .slate{padding:24px 20px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto}}

/* ═══════════════════════════════════════════════════════════
   ANIMATION PASS — added by AnimationDesigner
   Fully encapsulé dans prefers-reduced-motion: no-preference
   ═══════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: no-preference) {

  /* --- Scroll-reveal : éléments individuels ---------------------- */
  @keyframes fade-up {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  [data-reveal] {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .55s ease, transform .55s ease;
  }
  [data-reveal].revealed {
    opacity: 1;
    transform: translateY(0);
  }

  /* --- Scroll-reveal : groupes avec stagger ---------------------- */
  [data-reveal-stagger] > * {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .5s ease, transform .5s ease;
  }
  [data-reveal-stagger].revealed > * { opacity: 1; transform: translateY(0); }
  [data-reveal-stagger].revealed > *:nth-child(1) { transition-delay: 0s; }
  [data-reveal-stagger].revealed > *:nth-child(2) { transition-delay: .08s; }
  [data-reveal-stagger].revealed > *:nth-child(3) { transition-delay: .16s; }
  [data-reveal-stagger].revealed > *:nth-child(4) { transition-delay: .24s; }
  [data-reveal-stagger].revealed > *:nth-child(5) { transition-delay: .32s; }
  [data-reveal-stagger].revealed > *:nth-child(6) { transition-delay: .40s; }
  [data-reveal-stagger].revealed > *:nth-child(7) { transition-delay: .48s; }
  [data-reveal-stagger].revealed > *:nth-child(8) { transition-delay: .56s; }

  /* --- Hover cartes génériques ----------------------------------- */
  .card, .service-card, .feature-card, .feat, .prestations-card,
  .menu-item, .offer-card, .avis-card, .tarif-card, .gallery-item,
  .partner, .blog-card, .room-card, .product-card {
    transition: transform .22s ease, box-shadow .22s ease;
  }
  .card:hover, .service-card:hover, .feature-card:hover, .feat:hover,
  .prestations-card:hover, .menu-item:hover, .offer-card:hover,
  .avis-card:hover, .tarif-card:hover, .gallery-item:hover,
  .partner:hover, .blog-card:hover, .room-card:hover, .product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0,0,0,.12);
  }

  /* --- Hover liens nav ------------------------------------------- */
  nav a, .nav-link, header a {
    transition: opacity .18s ease, color .18s ease;
  }

  /* --- CTA boutons ---------------------------------------------- */
  .btn, .cta-btn, .cta-link, .button, [class*="btn-"], [class*="-btn"],
  .hero-cta, .bigcta a, .band-cta a {
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  }
  .btn:hover, .cta-btn:hover, .cta-link:hover, .button:hover,
  [class*="btn-"]:hover, [class*="-btn"]:hover,
  .hero-cta:hover, .bigcta a:hover, .band-cta a:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,.15);
  }

  /* --- Focus visible ring élégant ------------------------------- */
  :focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 3px;
    border-radius: 2px;
  }

}
/* End animation pass */

/* ── Template I : Ardoise Comptoir — boucherie-belcourt ─────────── */
@media (prefers-reduced-motion: no-preference) {

  /* 1. Chalkboard hero — entrée séquentielle au chargement */
  @keyframes chalk-in {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  .chalk-eyebrow { animation: chalk-in .5s  .10s ease both; }
  .chalk-hero    { animation: chalk-in .65s .30s ease both; }
  .chalk-tag     { animation: chalk-in .5s  .55s ease both; }
  .chalk-meta    { animation: chalk-in .5s  .75s ease both; }

  /* 2. Slate boards — hover lift + ombre renforcée */
  .slate {
    transition: transform .28s ease, box-shadow .28s ease;
  }
  .slate:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 44px rgba(0,0,0,.30), 0 6px 0 #3A2A1A;
  }

  /* 3. Counter-trio articles — hover lift */
  .counter-trio article {
    transition: transform .25s ease, box-shadow .25s ease;
  }
  .counter-trio article:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0,0,0,.22);
  }

  /* 4. Testimonials — hover lift + bordure rust */
  .testi figure {
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  }
  .testi figure:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    border-color: var(--rust);
  }

  /* 5. Masthead call button — transition manquante en base */
  .mh-call {
    transition: background .2s ease, color .2s ease;
  }

  /* 6. Bigfoot phone — transition hover + pulse doux */
  .bf-phone {
    transition: color .2s ease;
  }
  @keyframes bf-pulse {
    0%, 100% { border-color: var(--rust); }
    50%       { border-color: var(--gold); }
  }
  .bf-phone { animation: bf-pulse 3.5s ease-in-out infinite; }

  /* 7. QA summary — couleur au survol */
  .qa summary { transition: color .2s ease; }
  .qa summary:hover { color: var(--rust); }
}
/* End template-I pass */
