:root{
  --ink:#2A1410; --bg:#FBF3E7; --bg-alt:#F4E7D2;
  --red:#CE1A0C; --red-deep:#9C1107; --gold:#E2980F;
  --display:"Bricolage Grotesque",Georgia,serif;
  --body:"Manrope",system-ui,sans-serif;
  --m-fast:150ms; --m-base:260ms; --ease:cubic-bezier(.22,.61,.36,1);
  --wrap:1140px;
}
*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--display);line-height:1.04;font-weight:800}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.skip{position:absolute;left:-999px;top:0;background:var(--red);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:8px;top:8px}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:46px;padding:.8rem 1.4rem;border-radius:999px;font-family:var(--body);font-weight:700;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;transition:transform var(--m-fast) var(--ease),box-shadow var(--m-fast) var(--ease),background var(--m-fast)}
.btn--red{background:var(--red);color:#fff;box-shadow:0 10px 24px -10px rgba(206,26,12,.65)}
.btn--red:hover{background:var(--red-deep);transform:translateY(-2px)}
.btn--gold{background:var(--gold);color:#2A1410;box-shadow:0 10px 24px -12px rgba(226,152,15,.7)}
.btn--gold:hover{transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:80;display:flex;align-items:center;gap:1rem;padding:.6rem clamp(1rem,4vw,2.2rem);background:rgba(251,243,231,.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(42,20,16,.08)}
.nav__mark img{border-radius:8px}
.nav__links{margin-left:auto;display:flex;gap:1.4rem}
.nav__links a{text-decoration:none;font-weight:600;font-size:.92rem;color:var(--ink);opacity:.82}
.nav__links a:hover{opacity:1;color:var(--red)}
.nav__phone{margin-left:1rem;text-decoration:none;font-weight:700;font-size:.86rem;background:var(--red);color:#fff;padding:.5rem .95rem;border-radius:999px;white-space:nowrap}
@media(max-width:760px){.nav__links{display:none}.nav__phone{margin-left:auto}}

/* ---- hero (photo-forward, light veil) ---- */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;overflow:hidden;color:#fff;text-align:center}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.78)}
.hero__veil{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,8,6,.35) 0%,rgba(20,8,6,.12) 38%,rgba(20,8,6,.55) 100%)}
.hero__inner{width:100%;max-width:min(92vw,640px);padding:2rem 1.4rem;display:flex;flex-direction:column;align-items:center;gap:.85rem}
.hero__crown{width:62px;height:auto;color:var(--gold);fill:var(--gold);filter:drop-shadow(0 4px 10px rgba(0,0,0,.4))}
.hero__kicker{text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:700;opacity:.92}
.hero__title{font-size:clamp(3.2rem,13vw,6.4rem);text-shadow:0 4px 26px rgba(0,0,0,.4)}
.hero__title em{font-style:italic;color:var(--gold)}
.hero__tagline{font-size:clamp(.92rem,3.6vw,1.12rem);font-weight:500;opacity:.95}
.hero__status{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;min-height:1.6rem}
.st{font-size:.8rem;font-weight:700;padding:.32rem .8rem;border-radius:999px;display:inline-flex;align-items:center;gap:.4rem;background:rgba(0,0,0,.32);backdrop-filter:blur(4px)}
.st::before{content:"";width:8px;height:8px;border-radius:50%}
.st.is-open::before{background:#3ad17a}
.st.is-closed::before{background:var(--gold)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:.5rem}
@media(max-width:520px){.hero__cta{flex-direction:column;width:100%;max-width:20rem}.hero__cta .btn{width:100%}}

/* ---- marquee (force-animates under reduced-motion) ---- */
.strip{background:var(--red);color:#fff;overflow:hidden;border-top:3px solid var(--gold);border-bottom:3px solid var(--gold)}
.strip__track{display:flex;width:max-content;gap:1.6rem;padding:.85rem 0;white-space:nowrap;font-family:var(--display);font-weight:700;letter-spacing:.06em;font-size:1.02rem;animation:marquee 30s linear infinite;will-change:transform}
.strip .sep{color:var(--gold)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.strip__track{animation:marquee 30s linear infinite !important}}

/* ---- sections ---- */
section{padding:clamp(3.2rem,8vw,6rem) clamp(1rem,5vw,2rem)}
.sec__head{max-width:var(--wrap);margin:0 auto 2.4rem;text-align:center}
.sec__kicker{text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;font-weight:700;color:var(--red)}
.sec__title{font-size:clamp(1.9rem,5vw,3rem);margin-top:.5rem}
[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}

/* ---- spécialités ---- */
.specials{background:var(--bg)}
.specials__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.card{background:#fff;border:1px solid rgba(42,20,16,.08);border-radius:16px;overflow:hidden;box-shadow:0 16px 40px -28px rgba(42,20,16,.5);transition:transform var(--m-base) var(--ease),box-shadow var(--m-base)}
.card:hover{transform:translateY(-5px);box-shadow:0 22px 48px -24px rgba(206,26,12,.4)}
.card__media{aspect-ratio:4/3;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .card__media img{transform:scale(1.05)}
.card__body{padding:1.1rem 1.2rem 1.4rem}
.card__kicker{text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:700;color:var(--gold)}
.card__name{font-size:1.5rem;font-style:italic;margin:.2rem 0 .45rem;color:var(--red)}
.card__desc{font-size:.92rem;opacity:.82}
.specials__note{text-align:center;max-width:42rem;margin:2.4rem auto 0;font-size:.94rem;opacity:.7}

/* ---- carte gallery ---- */
.carte{background:var(--bg-alt)}
.carte__gallery{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.1rem}
.carte__card{font:inherit;color:inherit;border:0;background:none;padding:0;cursor:zoom-in;display:flex;flex-direction:column;gap:.5rem;text-align:center}
.carte__cover{display:block;border-radius:12px;overflow:hidden;border:1px solid rgba(42,20,16,.12);box-shadow:0 12px 30px -22px rgba(42,20,16,.6);transition:transform var(--m-base) var(--ease),box-shadow var(--m-base)}
.carte__card:hover .carte__cover{transform:translateY(-4px);box-shadow:0 18px 38px -20px rgba(206,26,12,.45)}
.carte__cover img{width:100%;height:auto;aspect-ratio:600/848;object-fit:cover}
.carte__cap{font-weight:600;font-size:.86rem;opacity:.8}
.carte__card:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:14px}
.carte__allergens{text-align:center;margin-top:1.8rem;font-size:.84rem;opacity:.6;font-style:italic}

/* ---- horaires ---- */
.hours{background:var(--ink);color:var(--bg);text-align:center}
.hours .sec__kicker{color:var(--gold)}
.hours__list{max-width:560px;margin:0 auto 1.6rem;text-align:left}
.hours__row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.7rem .2rem;border-bottom:1px dashed rgba(251,243,231,.22)}
.hours__row dt{font-family:var(--display);font-weight:700;font-size:1.05rem}
.hours__row dd{opacity:.82;font-size:.92rem;text-align:right}
.hours__row.is-today dt{color:var(--gold)}
.hours__row.is-today dt::before{content:"▸ "}
.hours__row.is-today dd{opacity:1;color:var(--bg)}
.hours__note{max-width:560px;margin:0 auto 1.6rem;font-size:.86rem;opacity:.66}

/* ---- find ---- */
.find{background:var(--bg)}
.find__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1.2fr .8fr;gap:1.6rem;align-items:stretch}
.find__map{border-radius:16px;overflow:hidden;min-height:340px;border:1px solid rgba(42,20,16,.1)}
.find__map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
.find__info{display:flex;flex-direction:column;gap:1.1rem;justify-content:center}
.find__info address{font-style:normal;line-height:1.7}
.find__info a{color:var(--red);text-decoration:none;font-weight:600}
.find__social{display:flex;gap:.6rem}
.find__social a{border:1.5px solid rgba(42,20,16,.18);border-radius:999px;padding:.45rem 1rem;font-size:.84rem;font-weight:600;text-decoration:none;color:var(--ink)}
.find__social a:hover{border-color:var(--red);color:var(--red)}
@media(max-width:760px){.find__grid{grid-template-columns:1fr}}

/* ---- footer ---- */
.foot{background:var(--ink);color:var(--bg);text-align:center;padding:3rem 1.5rem 2.4rem}
.foot__crown{width:54px;height:auto;color:var(--gold);margin:0 auto .6rem}
.foot__mark{font-family:var(--display);font-weight:800;font-size:1.7rem}
.foot__sub{opacity:.7;font-size:.88rem;margin-top:.2rem}
.foot__credit{margin-top:1.4rem;font-size:.82rem;opacity:.6}
.foot__credit a{color:var(--gold)}

/* ---- lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(20,8,6,.92);display:none;align-items:center;justify-content:center}
.lightbox[aria-hidden="false"]{display:flex}
body.lb-open{overflow:hidden}
.lb__stage{max-width:1000px;max-height:84vh;padding:0 1rem}
.lb__stage img{max-width:100%;max-height:84vh;border-radius:8px}
.lb__close,.lb__prev,.lb__next{position:absolute;background:rgba(255,255,255,.1);color:#fff;border:0;cursor:pointer;width:48px;height:48px;border-radius:50%;font-size:1.6rem;line-height:1;transition:background var(--m-fast)}
.lb__close:hover,.lb__prev:hover,.lb__next:hover{background:var(--gold);color:var(--ink)}
.lb__close{top:1rem;right:1rem}
.lb__prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb__next{right:1rem;top:50%;transform:translateY(-50%)}
.lb__info{position:absolute;bottom:1.2rem;left:0;right:0;display:flex;gap:1rem;justify-content:center;color:#fff;font-size:.86rem}
.lb__count{opacity:.7}
@media (prefers-reduced-motion: reduce){*{scroll-behavior:auto}[data-reveal]{opacity:1;transform:none;transition:none}}
