/* ============================================================
   LA LÉGENDE RESTO AFRO — CHEZ AMANDINE
   Design tokens + system
   ============================================================ */
:root{
  --vert:#0f5b3b;            /* vert forêt */
  --vert-deep:#0a3d28;       /* dark green sections */
  --vert-ink:#072018;        /* near-black green */
  --rouge:#b83624;           /* rouge brique */
  --rouge-deep:#8f2417;
  --or:#f4b83f;              /* or */
  --or-soft:#e9c977;
  --creme:#fbf6ee;           /* papier crème */
  --creme-2:#f3ead9;
  --espresso:#201914;        /* texte */
  --espresso-soft:#4a3f36;

  --maxw:1320px;
  --pad: clamp(20px, 5vw, 88px);

  --serif:"Playfair Display", Georgia, serif;
  --serif-alt:"Cormorant Garamond", Georgia, serif;
  --script:"Dancing Script", cursive;
  --sans:"Inter", system-ui, sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--creme);
  color:var(--espresso);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
::selection{background:var(--or);color:var(--espresso)}

/* hide native cursor only when custom is active (pointer devices) */
@media (hover:hover) and (pointer:fine){
  body.cursor-on, body.cursor-on a, body.cursor-on button{cursor:none}
}

/* ---------- wax pattern texture ---------- */
.wax{
  background-image:
    radial-gradient(currentColor 1.1px, transparent 1.2px),
    radial-gradient(currentColor 1.1px, transparent 1.2px);
  background-size:26px 26px;
  background-position:0 0,13px 13px;
}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
#cursor{
  position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  width:34px;height:34px;border:1.5px solid var(--or);border-radius:50%;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s,opacity .3s;
  mix-blend-mode:difference;display:none;
}
#cursor.on-dark{mix-blend-mode:difference}
#cursor .dot{
  position:absolute;inset:0;display:grid;place-items:center;
  font-size:15px;opacity:0;transform:scale(.4);transition:opacity .25s,transform .25s;
}
#cursor.link{width:56px;height:56px;background:var(--or);border-color:transparent;mix-blend-mode:normal}
#cursor.link .dot{opacity:1;transform:scale(1)}
#cursor-follow{
  position:fixed;top:0;left:0;z-index:9998;pointer-events:none;
  width:7px;height:7px;background:var(--or);border-radius:50%;
  transform:translate(-50%,-50%);display:none;mix-blend-mode:difference;
}
@media (hover:hover) and (pointer:fine){
  #cursor,#cursor-follow{display:block}
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  mix-blend-mode:difference;color:#fff;
  transition:padding .4s var(--ease);
}
.nav .brand{font-family:var(--serif);font-style:italic;font-weight:700;font-size:21px;letter-spacing:.01em;line-height:1}
.nav .brand small{display:block;font-family:var(--sans);font-style:normal;font-weight:600;font-size:8.5px;letter-spacing:.42em;text-transform:uppercase;margin-top:3px;opacity:.85}
.nav nav{display:flex;gap:30px}
.nav nav a{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;position:relative;padding:4px 0}
.nav nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:currentColor;transition:width .4s var(--ease)}
.nav nav a:hover::after{width:100%}
.nav .nav-cta{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid currentColor;padding:9px 16px;border-radius:999px}
@media (max-width:860px){
  .nav nav{display:none}
  .nav{padding:14px var(--pad)}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--vert-ink)}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg figure{position:absolute;inset:0;opacity:0;transition:opacity 1.6s var(--ease)}
.hero__bg figure.active{opacity:1}
.hero__bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);will-change:transform;
  filter:saturate(.92) contrast(1.02);}
.hero.kb .hero__bg figure.active img{animation:kenburns 14s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.0)}to{transform:scale(1.12)}}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
   linear-gradient(180deg, rgba(7,32,24,.55) 0%, rgba(7,32,24,.15) 30%, rgba(7,32,24,.35) 62%, rgba(7,32,24,.92) 100%);}
.hero__grain{position:absolute;inset:0;z-index:2;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");}

.hero__inner{position:relative;z-index:3;padding:0 var(--pad) clamp(34px,6vh,72px);width:100%;color:var(--creme)}
.hero__eyebrow{display:flex;align-items:center;gap:14px;font-size:11.5px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--or);margin-bottom:clamp(14px,2.4vh,26px)}
.hero__eyebrow .ln{width:46px;height:1px;background:var(--or);opacity:.7}
.hero__title{font-family:var(--serif);font-style:italic;font-weight:700;line-height:.86;letter-spacing:-.015em;
  font-size:clamp(4.4rem,16vw,13rem);margin:0}
.hero__title .word{display:inline-block;overflow:hidden;vertical-align:top}
.hero__title .char{display:inline-block;will-change:transform}
.js .hero__title .char{animation:charUp 1s cubic-bezier(.22,1,.36,1) backwards}
@keyframes charUp{from{transform:translateY(112%)}to{transform:translateY(0)}}
.hero__script{font-family:var(--script);font-weight:700;color:var(--or);font-size:clamp(1.7rem,5.4vw,3.4rem);line-height:1;margin-top:.1em}
.js .hero__script{animation:fadeUp .9s var(--ease) .68s backwards}
.js .hero__eyebrow{animation:fadeUp .9s var(--ease) .5s backwards}
.js .hero__lede{animation:fadeUp .9s var(--ease) .58s backwards}
.js .hero__actions{animation:fadeUp .9s var(--ease) .66s backwards}
.js .hero__facts{animation:fadeUp .9s var(--ease) .76s backwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero__row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:26px;margin-top:clamp(20px,3.6vh,40px)}
.hero__lede{max-width:40ch;font-size:clamp(15px,1.5vw,17px);line-height:1.6;color:rgba(251,246,238,.82)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}

.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.06em;font-size:13.5px;text-transform:uppercase;
  padding:16px 26px;border-radius:999px;transition:transform .35s var(--ease),background .35s,color .35s,box-shadow .35s;will-change:transform;position:relative}
.btn svg{width:17px;height:17px}
.btn--gold{background:var(--or);color:var(--espresso);box-shadow:0 10px 34px -12px rgba(244,184,63,.8)}
.btn--gold:hover{background:#ffce5f;box-shadow:0 14px 40px -10px rgba(244,184,63,.9)}
.btn--ghost{border:1px solid rgba(251,246,238,.5);color:var(--creme)}
.btn--ghost:hover{background:rgba(251,246,238,.12);border-color:var(--creme)}
.btn--green{background:var(--vert);color:var(--creme)}
.btn--green:hover{background:var(--vert-deep)}
.mag{will-change:transform}

.hero__facts{display:flex;flex-wrap:wrap;gap:22px 30px;margin-top:clamp(22px,3.4vh,38px);padding-top:22px;border-top:1px solid rgba(251,246,238,.16)}
.hero__facts span{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;letter-spacing:.06em;color:rgba(251,246,238,.78)}
.hero__facts svg{width:16px;height:16px;color:var(--or)}

.hero__cue{position:absolute;right:var(--pad);bottom:clamp(34px,6vh,72px);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--creme)}
.hero__cue .txt{writing-mode:vertical-rl;font-size:10px;letter-spacing:.32em;text-transform:uppercase;opacity:.7}
.hero__cue .track{width:1px;height:64px;background:rgba(251,246,238,.25);position:relative;overflow:hidden}
.hero__cue .track i{position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--or);animation:cueFill 2.2s var(--ease) infinite}
@keyframes cueFill{0%{top:-100%}60%,100%{top:100%}}
.hero__dots{position:absolute;left:var(--pad);bottom:clamp(34px,6vh,72px);z-index:3;display:flex;gap:9px}
.hero__dots button{width:30px;height:3px;border-radius:2px;background:rgba(251,246,238,.3);transition:background .4s}
.hero__dots button.active{background:var(--or)}
@media (max-width:680px){
  .hero__cue{display:none}
  .hero__facts span{font-size:11.5px}
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--vert-deep);color:var(--creme);padding:clamp(26px,4vw,46px) 0;overflow:hidden;position:relative;border-top:1px solid rgba(244,184,63,.18);border-bottom:1px solid rgba(244,184,63,.18)}
.marquee__track{display:flex;gap:0;width:max-content;animation:scrollX 32s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes scrollX{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee__item{display:inline-flex;align-items:center;gap:clamp(28px,4vw,64px);padding:0 clamp(14px,2vw,32px)}
.marquee__item .dish{font-family:var(--serif);font-style:italic;font-weight:700;font-size:clamp(2.6rem,6vw,5.2rem);line-height:1;
  color:transparent;-webkit-text-stroke:1.2px var(--or-soft);text-stroke:1.2px var(--or-soft);transition:color .4s,-webkit-text-stroke-color .4s;white-space:nowrap;cursor:pointer}
.marquee__item .dish:hover{color:var(--or)}
.marquee__item .star{color:var(--rouge);font-size:1.4rem;transform:translateY(-.4em)}
.dish-tip{position:fixed;z-index:300;pointer-events:none;background:var(--creme);color:var(--espresso);border-radius:14px;padding:12px 16px;
  box-shadow:0 22px 50px -18px rgba(7,32,24,.6);opacity:0;transform:translate(-50%,8px) scale(.9);transition:opacity .25s,transform .35s var(--ease);min-width:160px}
.dish-tip.show{opacity:1;transform:translate(-50%,0) scale(1)}
.dish-tip .n{font-family:var(--serif);font-style:italic;font-weight:700;font-size:18px}
.dish-tip .p{font-weight:800;font-variant-numeric:tabular-nums;color:var(--rouge);margin-top:2px}
.dish-tip .c{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--vert);font-weight:700;margin-bottom:2px}

/* ============================================================
   SECTION primitives
   ============================================================ */
section{position:relative}
.sec-pad{padding:clamp(72px,11vw,150px) var(--pad)}
.wrap{max-width:var(--maxw);margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:11.5px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--rouge);margin-bottom:20px}
.eyebrow .ln{width:34px;height:1px;background:currentColor}
.eyebrow.on-gold{color:var(--or)}
.h2{font-family:var(--serif);font-weight:700;line-height:.98;letter-spacing:-.01em;font-size:clamp(2.4rem,6vw,4.6rem)}
.h2 em{font-style:italic}
.reveal-line{overflow:hidden}
.reveal-word{display:inline-block;overflow:hidden;vertical-align:top}
.reveal-word > span{display:inline-block;will-change:transform}
.js .reveal-word > span{transform:translateY(110%)}

/* ============================================================
   HISTOIRE — sticky split
   ============================================================ */
.story{background:var(--creme-2)}
.story__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:start}
.story__media{position:sticky;top:0;height:100svh;display:flex;align-items:center}
.story__frame{position:relative;width:100%;aspect-ratio:4/5;border-radius:8px;overflow:hidden;box-shadow:0 40px 90px -40px rgba(7,32,24,.55)}
.story__frame figure{position:absolute;inset:0;opacity:0;transition:opacity 1.2s var(--ease)}
.story__frame figure.active{opacity:1}
.story__frame img{width:100%;height:100%;object-fit:cover}
.story__frame .tag{position:absolute;left:18px;bottom:18px;z-index:2;background:rgba(7,32,24,.6);backdrop-filter:blur(6px);color:var(--creme);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:8px 14px;border-radius:999px;border:1px solid rgba(244,184,63,.4)}
.story__copy{padding:clamp(60px,14vh,150px) 0}
.story__copy .lead{font-family:var(--serif-alt);font-style:italic;font-weight:500;font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.35;color:var(--vert);margin:22px 0 40px}
.story__block{margin:46px 0;font-size:17px;line-height:1.72;color:var(--espresso-soft);max-width:46ch}
.story__block h3{font-family:var(--serif);font-weight:700;font-size:1.6rem;color:var(--espresso);margin-bottom:12px}
.story__sign{font-family:var(--script);font-size:2.4rem;color:var(--rouge);margin-top:10px}
@media (max-width:860px){
  .story__grid{grid-template-columns:1fr;gap:0}
  .story__media{position:relative;height:auto;top:auto}
  .story__frame{aspect-ratio:4/3}
  .story__copy{padding:48px 0 0}
  .story__block{margin:34px 0}
}

/* ============================================================
   CARTE — bento
   ============================================================ */
.carte{background:var(--vert-ink);color:var(--creme)}
.carte__head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:48px}
.carte__head .h2{color:var(--creme)}
.carte__note{max-width:34ch;font-size:14.5px;line-height:1.6;color:rgba(251,246,238,.66)}
.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(168px,auto);gap:16px}
.bento__card{position:relative;border-radius:14px;overflow:hidden;padding:26px;display:flex;flex-direction:column;justify-content:space-between;
  background:var(--vert-deep);border:1px solid rgba(244,184,63,.16);cursor:pointer;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;will-change:transform}
.bento__card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -28px rgba(0,0,0,.7);border-color:rgba(244,184,63,.5)}
.bento__card .wax{position:absolute;inset:0;color:rgba(244,184,63,.10);pointer-events:none}
.bento__card .ic{font-family:var(--serif);font-style:italic;font-size:2.2rem;color:var(--or);transition:transform .5s var(--ease);transform-origin:left center;line-height:1}
.bento__card:hover .ic{transform:scale(1.25) rotate(4deg)}
.bento__top{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1}
.bento__count{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(251,246,238,.55);border:1px solid rgba(251,246,238,.2);padding:5px 10px;border-radius:999px}
.bento__card h3{font-family:var(--serif);font-weight:700;font-size:clamp(1.5rem,2.4vw,2.2rem);position:relative;z-index:1;line-height:1}
.bento__card p{font-size:13.5px;color:rgba(251,246,238,.66);position:relative;z-index:1;margin-top:6px}
.bento__open{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--or);position:relative;z-index:1;margin-top:14px}
.bento__open svg{width:15px;height:15px;transition:transform .4s var(--ease)}
.bento__card:hover .bento__open svg{transform:translate(4px,-4px)}
.bento__card.is-red{background:linear-gradient(150deg,var(--rouge),var(--rouge-deep))}
.bento__card.is-gold{background:linear-gradient(150deg,#caa23a,#9c7a1f)}
.bento__card.is-gold .ic,.bento__card.is-gold .bento__open,.bento__card.is-red .ic,.bento__card.is-red .bento__open{color:var(--creme)}
.bento__card.is-gold h3,.bento__card.is-gold p,.bento__card.is-red h3,.bento__card.is-red p{color:var(--creme)}
/* spans */
.b-plats{grid-column:span 3;grid-row:span 2}
.b-grill{grid-column:span 3}
.b-acc{grid-column:span 2}
.b-bois{grid-column:span 2}
.b-dim{grid-column:span 2}
@media (max-width:860px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .b-plats{grid-column:span 2;grid-row:span 1}
  .b-grill,.b-acc,.b-bois,.b-dim{grid-column:span 1}
}
@media (max-width:520px){
  .bento{grid-template-columns:1fr}
  .b-plats,.b-grill,.b-acc,.b-bois,.b-dim{grid-column:span 1}
}

/* drawer */
.drawer-veil{position:fixed;inset:0;z-index:400;background:rgba(7,32,24,.55);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .45s}
.drawer-veil.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;z-index:401;width:min(480px,92vw);background:var(--creme);color:var(--espresso);
  transform:translateX(102%);transition:transform .55s var(--ease);display:flex;flex-direction:column;box-shadow:-30px 0 80px -30px rgba(0,0,0,.5)}
.drawer.open{transform:translateX(0)}
.drawer__head{padding:26px 28px 20px;border-bottom:1px solid rgba(32,25,20,.1);display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.drawer__head .eyebrow{margin:0 0 8px}
.drawer__head h3{font-family:var(--serif);font-weight:700;font-size:2rem;line-height:1}
.drawer__close{width:42px;height:42px;border-radius:50%;border:1px solid rgba(32,25,20,.18);display:grid;place-items:center;flex:none;transition:background .3s,transform .3s}
.drawer__close:hover{background:var(--espresso);color:var(--creme);transform:rotate(90deg)}
.drawer__body{overflow-y:auto;padding:8px 28px 120px;flex:1}
.drawer__row{display:flex;align-items:center;gap:14px;padding:15px 0;border-bottom:1px solid rgba(32,25,20,.08)}
.drawer__row .info{flex:1;min-width:0}
.drawer__row .nm{font-family:var(--serif-alt);font-weight:600;font-size:18px;line-height:1.2}
.drawer__row .chef{display:inline-block;margin-left:8px;font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--rouge);border:1px solid var(--rouge);border-radius:999px;padding:2px 7px;vertical-align:middle}
.drawer__row .pr{font-weight:800;font-variant-numeric:tabular-nums;font-size:16px;white-space:nowrap}
.drawer__row .add{width:38px;height:38px;border-radius:50%;background:var(--vert);color:var(--creme);display:grid;place-items:center;flex:none;transition:transform .3s,background .3s}
.drawer__row .add:hover{transform:scale(1.12);background:var(--vert-deep)}
.drawer__row .add svg{width:18px;height:18px}
/* Inline stepper inside drawer */
.drawer__stepper{display:flex;align-items:center;gap:8px;flex:none}
.drawer__stepper .ds-minus,.drawer__stepper .ds-plus{
  width:36px;height:36px;border-radius:50%;display:grid;place-items:center;
  border:0;cursor:pointer;transition:transform .2s,background .2s
}
.drawer__stepper .ds-minus{background:rgba(32,25,20,.1);color:var(--espresso)}
.drawer__stepper .ds-minus:hover{background:rgba(184,54,36,.15);color:var(--rouge)}
.drawer__stepper .ds-plus{background:var(--vert);color:#fff}
.drawer__stepper .ds-plus:hover{background:var(--vert-deep);transform:scale(1.1)}
.drawer__stepper svg{width:17px;height:17px}
.drawer__stepper .ds-qty{
  min-width:28px;text-align:center;font-size:17px;font-weight:900;
  font-variant-numeric:tabular-nums;color:var(--vert)
}
/* Flash animation when row is added */
@keyframes rowAdded{0%{background:rgba(15,91,59,.12)}100%{background:transparent}}
.drawer__row.added{animation:rowAdded .6s ease}
.drawer__foot{
  position:absolute;left:0;right:0;bottom:0;
  padding:14px 28px 20px;
  background:linear-gradient(180deg,transparent,var(--creme) 22%)
}
.drawer__cart-summary{
  margin-bottom:12px;padding:12px 14px;border-radius:14px;
  background:rgba(15,91,59,.08);border:1px solid rgba(15,91,59,.2)
}
.drawer__cart-summary[hidden]{display:none}
.dcs-title{
  display:flex;align-items:center;gap:7px;margin-bottom:8px;
  font-size:11.5px;font-weight:900;letter-spacing:.07em;text-transform:uppercase;
  color:var(--vert-deep)
}
.dcs-items{
  list-style:none;margin:0;padding:0;display:grid;gap:5px;max-height:110px;overflow-y:auto;scrollbar-width:none
}
.dcs-items::-webkit-scrollbar{display:none}
.dcs-items li{
  display:flex;align-items:baseline;gap:8px;
  font-size:13.5px;font-weight:600;color:var(--espresso);line-height:1.3
}
.dcs-qty{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:24px;height:22px;padding:0 6px;border-radius:6px;
  background:var(--vert);color:#fff;font-size:11px;font-weight:900;flex:none
}
.dcs-name{min-width:0}
.drawer__foot .btn{width:100%;justify-content:center}

/* order bar */
.orderbar{position:fixed;left:50%;bottom:22px;z-index:350;transform:translate(-50%,140%);transition:transform .55s var(--ease);
  display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:14px;
  background:#fffaef;color:var(--espresso);padding:14px 14px 14px 22px;border-radius:20px;
  border:1px solid rgba(244,184,63,.5);
  box-shadow:0 28px 60px -16px rgba(7,32,24,.55),0 0 0 4px rgba(244,184,63,.15);
  width:min(calc(100vw - 24px),640px)}
.orderbar.show{transform:translate(-50%,0)}
.orderbar .meta{min-width:0;cursor:pointer}
.orderbar .meta strong{display:block;font-size:17px;font-family:var(--serif);font-style:italic;color:var(--vert-deep);margin-bottom:3px}
.orderbar .meta span{font-size:13.5px;color:var(--espresso);line-height:1.5;font-weight:600;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.orderbar.expanded .meta span{-webkit-line-clamp:unset;display:block;white-space:pre-line}
.orderbar .go{display:inline-flex;align-items:center;gap:9px;background:var(--vert);color:#fff;font-weight:800;font-size:13.5px;letter-spacing:.04em;padding:13px 20px;border-radius:14px;text-transform:uppercase;text-decoration:none;
  box-shadow:0 8px 18px rgba(15,91,59,.35)}
.orderbar .go:hover{background:var(--vert-deep)}
.orderbar .clr{width:38px;height:38px;border-radius:12px;border:1px solid rgba(7,32,24,.18);background:#fff;display:grid;place-items:center;flex:none;color:var(--espresso);cursor:pointer}
.orderbar .clr:hover{background:rgba(184,54,36,.08);color:var(--rouge);border-color:rgba(184,54,36,.3)}
.orderbar .go svg{width:17px;height:17px}
.orderbar .clr svg{width:17px;height:17px}
@media(max-width:520px){
  .orderbar{grid-template-columns:1fr auto;grid-template-rows:auto auto;padding:13px 14px 14px 18px;gap:10px 12px}
  .orderbar .go{grid-column:1/-1;justify-content:center;width:100%;padding:14px}
  .orderbar .clr{grid-row:1;grid-column:2}
  .orderbar .meta{grid-row:1;grid-column:1}
}

/* ============================================================
   SIGNATURE — cinema carousel
   ============================================================ */
.signature{background:var(--creme);overflow:hidden}
.signature__head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:18px;padding:0 var(--pad);margin-bottom:38px}
.sig-scroller{display:flex;gap:clamp(16px,2vw,28px);overflow-x:auto;scroll-snap-type:x mandatory;padding:0 var(--pad) 8px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.sig-scroller::-webkit-scrollbar{display:none}
.sig-card{scroll-snap-align:center;flex:0 0 min(86vw,1040px);display:grid;grid-template-columns:0.92fr 1.08fr;gap:0;border-radius:16px;overflow:hidden;min-height:min(78vh,640px);background:var(--vert-deep);color:var(--creme)}
.sig-card.alt{background:linear-gradient(160deg,var(--rouge),var(--rouge-deep))}
.sig-card__visual{position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:30px}
.sig-card__visual .wax{position:absolute;inset:0;color:rgba(244,184,63,.12)}
.sig-card__num{position:relative;font-family:var(--serif);font-style:italic;font-weight:700;font-size:clamp(7rem,16vw,15rem);line-height:.8;color:rgba(244,184,63,.22)}
.sig-card__big{position:absolute;top:26px;left:30px;right:30px;font-family:var(--serif);font-style:italic;font-weight:700;
  font-size:clamp(2.2rem,4vw,3.6rem);line-height:.95;color:var(--or);
  transition:clip-path 1s var(--ease)}
.js .sig-card__big{clip-path:inset(100% 0 0 0)}
.sig-card.in .sig-card__big{clip-path:inset(0 0 0 0)}
.sig-card__body{padding:clamp(30px,4vw,56px);display:flex;flex-direction:column;justify-content:center;gap:18px}
.sig-card__cat{font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--or)}
.sig-card.alt .sig-card__cat{color:var(--creme)}
.sig-card__name{font-family:var(--serif);font-weight:700;font-size:clamp(2.6rem,5vw,4.4rem);line-height:.96}
.sig-card__desc{font-size:16px;line-height:1.65;color:rgba(251,246,238,.8);max-width:42ch}
.sig-card__price{font-weight:800;font-variant-numeric:tabular-nums;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--or)}
.sig-card.alt .sig-card__price{color:var(--creme)}
.sig-card__price small{font-size:.5em;font-weight:600;letter-spacing:.1em;text-transform:uppercase;opacity:.7;margin-left:8px}
.sig-progress{height:3px;background:rgba(32,25,20,.12);max-width:var(--maxw);margin:34px auto 0;width:calc(100% - var(--pad)*2);border-radius:2px;overflow:hidden}
.sig-progress i{display:block;height:100%;width:16%;background:var(--rouge);border-radius:2px;transition:transform .3s var(--ease),width .3s}
@media (max-width:760px){
  .sig-card{grid-template-columns:1fr;min-height:auto;flex:0 0 86vw}
  .sig-card__visual{min-height:200px}
  .sig-card__big{position:static;clip-path:none;margin-bottom:8px}
  .sig-card__num{font-size:7rem}
}

/* ============================================================
   AMBIANCE — gallery
   ============================================================ */
.gal-filters{
  display:flex;flex-wrap:wrap;gap:8px;margin:0 0 26px;
}
.gal-chip{
  display:inline-flex;align-items:center;
  padding:9px 16px;border-radius:999px;
  background:rgba(251,246,238,.08);border:1px solid rgba(251,246,238,.2);
  color:var(--creme);font-size:13px;font-weight:700;letter-spacing:.04em;
  cursor:pointer;transition:all .2s var(--ease,cubic-bezier(.22,1,.36,1))
}
.gal-chip:hover{background:rgba(251,246,238,.15);border-color:rgba(244,184,63,.4)}
.gal-chip.active{background:var(--or);color:var(--espresso-ink,#072018);border-color:var(--or);
  box-shadow:0 4px 12px rgba(244,184,63,.35)}
.masonry figure[hidden]{display:none!important}
.masonry figure video{width:100%;height:100%;object-fit:cover;display:block}
.masonry figure[data-cat="videos"]::before{
  content:"▶";position:absolute;top:14px;right:14px;z-index:2;
  display:grid;place-items:center;width:40px;height:40px;border-radius:50%;
  background:rgba(0,0,0,.55);color:var(--or);font-size:13px;backdrop-filter:blur(8px);
  pointer-events:none
}
.ambiance{background:var(--vert-ink);color:var(--creme)}
.ambiance__head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:42px}
.ambiance__head .h2{color:var(--creme)}
.masonry{columns:3;column-gap:16px}
.masonry figure{break-inside:avoid;margin-bottom:16px;position:relative;border-radius:12px;overflow:hidden;cursor:pointer}
.masonry img{width:100%;transition:transform .8s var(--ease),filter .6s}
.masonry figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,32,24,.7));opacity:0;transition:opacity .5s}
.masonry figure figcaption{position:absolute;left:16px;bottom:14px;z-index:2;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--creme);
  opacity:0;transform:translateY(8px);transition:opacity .5s,transform .5s}
.masonry figure:hover img{transform:scale(1.06)}
.masonry figure:hover::after{opacity:1}
.masonry figure:hover figcaption{opacity:1;transform:translateY(0)}
.masonry.focusing figure:not(:hover) img{filter:grayscale(1) brightness(.7)}

/* Menu original — style "carte papier encadrée" */
.masonry figure[data-cat="menu"]{
  background:var(--creme-2);
  box-shadow:0 8px 32px rgba(7,32,24,.22),0 0 0 6px #fffaef,0 0 0 7px rgba(15,91,59,.25);
  transform:rotate(var(--r,-.5deg));
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)
}
.masonry figure[data-cat="menu"]:nth-child(2n){--r:.7deg}
.masonry figure[data-cat="menu"]:nth-child(3n){--r:-.3deg}
.masonry figure[data-cat="menu"]:hover{
  transform:rotate(0deg) scale(1.03);
  box-shadow:0 20px 50px rgba(7,32,24,.35),0 0 0 6px #fffaef,0 0 0 7px rgba(15,91,59,.45)
}
.masonry figure[data-cat="menu"] img{
  filter:contrast(1.08) saturate(1.05);
  object-fit:contain;background:#fffaef;padding:6px
}
.masonry figure[data-cat="menu"]::before{
  content:"📋";position:absolute;top:10px;right:10px;z-index:3;
  font-size:20px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));pointer-events:none
}
.masonry figure[data-cat="menu"]::after{
  background:linear-gradient(180deg,transparent 40%,rgba(15,91,59,.85))
}
.masonry figure[data-cat="menu"] figcaption{
  font-size:14px;font-weight:800;font-style:normal;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(15,91,59,.92);padding:8px 14px;left:0;right:0;bottom:0;border-radius:0;
  opacity:1;transform:none;text-align:center
}

@media (max-width:860px){.masonry{columns:2}}
@media (max-width:520px){.masonry{columns:1}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:500;background:rgba(7,32,24,.94);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .4s;padding:5vh 6vw}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:100%;max-height:90vh;border-radius:8px;box-shadow:0 40px 100px -30px #000;transform:scale(.94);transition:transform .5s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lightbox__cap{position:absolute;bottom:4vh;left:0;right:0;text-align:center;color:var(--creme);font-family:var(--serif);font-style:italic;font-size:18px}
.lightbox__btn{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:1px solid rgba(251,246,238,.3);
  color:var(--creme);display:grid;place-items:center;transition:background .3s}
.lightbox__btn:hover{background:rgba(251,246,238,.14)}
.lightbox__btn.prev{left:3vw}.lightbox__btn.next{right:3vw}
.lightbox__close{position:absolute;top:4vh;right:5vw;width:48px;height:48px;border-radius:50%;border:1px solid rgba(251,246,238,.3);color:var(--creme);display:grid;place-items:center}
.lightbox__btn svg,.lightbox__close svg{width:22px;height:22px}
@media (max-width:680px){.lightbox__btn{display:none}}

/* ============================================================
   RESERVATION
   ============================================================ */
.reserve{background:var(--vert);color:var(--creme);position:relative;overflow:hidden}
.reserve .wax{position:absolute;inset:0;color:rgba(244,184,63,.08);pointer-events:none}
.reserve__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,90px);align-items:center;position:relative;z-index:1}
.reserve__intro .h2{color:var(--creme)}
.reserve__intro p{font-size:16px;line-height:1.7;color:rgba(251,246,238,.8);max-width:40ch;margin-top:20px}
.reserve__intro .hours{margin-top:32px;display:flex;flex-direction:column;gap:10px;font-size:14px}
.reserve__intro .hours div{display:flex;justify-content:space-between;max-width:300px;padding:8px 0;border-bottom:1px solid rgba(251,246,238,.15)}
.reserve__intro .hours .off{opacity:.45}
.card-glass{background:rgba(251,246,238,.1);backdrop-filter:blur(16px);border:1px solid rgba(251,246,238,.22);border-radius:20px;padding:clamp(26px,3vw,40px);
  box-shadow:0 40px 90px -40px rgba(0,0,0,.6)}
.field{margin-bottom:24px}
.field > label{display:block;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-bottom:12px}
.stepper{display:flex;align-items:center;gap:18px}
.stepper button{width:46px;height:46px;border-radius:50%;border:1px solid rgba(251,246,238,.35);display:grid;place-items:center;transition:background .3s,transform .2s}
.stepper button:hover{background:rgba(251,246,238,.14)}
.stepper button:active{transform:scale(.9)}
.stepper button svg{width:18px;height:18px}
.stepper .num{font-family:var(--serif);font-size:2.4rem;font-weight:700;min-width:60px;text-align:center;position:relative;height:2.6rem;overflow:hidden}
.stepper .num span{display:block;transition:transform .4s var(--ease)}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{padding:10px 16px;border-radius:999px;border:1px solid rgba(251,246,238,.3);font-size:13px;font-weight:600;transition:background .3s,color .3s,border-color .3s}
.chip:hover{border-color:var(--or)}
.chip.active{background:var(--or);color:var(--espresso);border-color:var(--or)}
.chip.sep{background:none;border:none;color:rgba(251,246,238,.4);pointer-events:none;font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:10px 2px}
.field input[type=date]{width:100%;background:rgba(251,246,238,.12);border:1px solid rgba(251,246,238,.25);color:var(--creme);padding:13px 16px;border-radius:12px;font:inherit;font-size:15px;color-scheme:dark}
.btn--pulse{width:100%;justify-content:center;margin-top:8px}
.btn--pulse.armed{animation:goldPulse 2s var(--ease) infinite}
@keyframes goldPulse{0%,100%{box-shadow:0 0 0 0 rgba(244,184,63,.55)}50%{box-shadow:0 0 0 16px rgba(244,184,63,0)}}
.reserve__sum{margin-top:16px;font-size:13px;color:rgba(251,246,238,.7);text-align:center;line-height:1.5}
@media (max-width:860px){.reserve__grid{grid-template-columns:1fr;gap:40px}}

/* ============================================================
   INFOS
   ============================================================ */
.infos{background:var(--creme)}
.infos__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.info-card{position:relative;background:var(--creme-2);border:1px solid rgba(32,25,20,.08);border-radius:16px;padding:30px;overflow:hidden}
.info-card .mi{width:48px;height:48px;border-radius:12px;background:var(--vert);color:var(--creme);display:grid;place-items:center;margin-bottom:22px;transition:transform .25s var(--ease);will-change:transform}
.info-card .mi svg{width:22px;height:22px}
.info-card h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;margin-bottom:8px}
.info-card p{font-size:15px;color:var(--espresso-soft);line-height:1.6}
.info-card .live{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:12.5px;font-weight:700}
.info-card .live .led{width:9px;height:9px;border-radius:50%;background:var(--vert);box-shadow:0 0 0 0 rgba(15,91,59,.5);animation:led 2s infinite}
.info-card .live.off .led{background:var(--rouge);animation:none}
@keyframes led{0%{box-shadow:0 0 0 0 rgba(15,91,59,.55)}70%{box-shadow:0 0 0 8px rgba(15,91,59,0)}100%{box-shadow:0 0 0 0 rgba(15,91,59,0)}}
.info-card a.link{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--rouge)}
.info-card a.link svg{width:15px;height:15px;transition:transform .35s var(--ease)}
.info-card a.link:hover svg{transform:translate(3px,-3px)}
.info-card .map{position:absolute;inset:auto 0 0 0;height:0}
.minimap{margin-top:18px;border-radius:12px;overflow:hidden;border:1px solid rgba(32,25,20,.1);aspect-ratio:16/10}
.minimap iframe{width:100%;height:100%;border:0;filter:saturate(.9)}
@media (max-width:860px){.infos__grid{grid-template-columns:1fr}}

/* RESEAUX */
.google-review-cta{
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  margin-top:32px;padding:22px 24px;border-radius:22px;
  background:linear-gradient(135deg,#fff 0%,#fffaef 100%);
  border:1px solid rgba(244,184,63,.5);
  box-shadow:0 12px 30px -8px rgba(7,32,24,.18),0 0 0 4px rgba(244,184,63,.12);
  text-decoration:none;color:var(--espresso);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease)
}
.google-review-cta:hover{transform:translateY(-2px);box-shadow:0 18px 38px -8px rgba(7,32,24,.25),0 0 0 4px rgba(244,184,63,.18)}
.google-review-cta .grc-icon{
  display:grid;place-items:center;width:56px;height:56px;border-radius:16px;
  background:#fff;border:1px solid rgba(7,32,24,.08);box-shadow:0 4px 10px rgba(7,32,24,.06)
}
.google-review-cta .grc-text strong{
  display:block;font-family:var(--serif);font-style:italic;font-weight:700;
  font-size:21px;color:var(--vert-deep);margin-bottom:4px;line-height:1.15
}
.google-review-cta .grc-text span{font-size:14px;color:var(--espresso-soft);font-weight:600;line-height:1.4}
.google-review-cta .grc-go{
  display:grid;place-items:center;width:46px;height:46px;border-radius:50%;
  background:var(--vert);color:#fff;box-shadow:0 6px 14px rgba(15,91,59,.35)
}
@media(max-width:540px){
  .google-review-cta{grid-template-columns:auto 1fr;gap:14px;padding:18px}
  .google-review-cta .grc-go{grid-column:1/-1;justify-self:end;margin-top:4px}
  .google-review-cta .grc-text strong{font-size:18px}
}
.socials{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;perspective:1200px}
.social-tile{position:relative;border-radius:16px;overflow:hidden;padding:30px;min-height:180px;display:flex;flex-direction:column;justify-content:space-between;
  color:var(--creme);transition:transform .5s var(--ease),box-shadow .5s;transform-style:preserve-3d;will-change:transform}
.social-tile.fb{background:linear-gradient(150deg,#1f5a8f,#0f3a63)}
.social-tile.ig{background:linear-gradient(150deg,#b83624,#7a2a8f)}
.social-tile.tt{background:linear-gradient(150deg,#0a3d28,#072018)}
.social-tile:hover{box-shadow:0 40px 80px -34px rgba(0,0,0,.6)}
.social-tile .ic{width:44px;height:44px;transition:transform .5s var(--ease)}
.social-tile:hover .ic{transform:scale(1.3)}
.social-tile .ic svg{width:44px;height:44px}
.social-tile .lbl{font-family:var(--serif);font-weight:700;font-size:1.5rem}
.social-tile .hd{font-size:13px;color:rgba(251,246,238,.75);margin-top:2px}
.social-tile .go{position:absolute;top:26px;right:26px;opacity:.8}
.social-tile .go svg{width:20px;height:20px}
@media (max-width:760px){.socials{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--vert-ink);color:var(--creme);padding-top:clamp(60px,8vw,110px);overflow:hidden}
.footer__outline{font-family:var(--serif);font-style:italic;font-weight:700;line-height:.8;text-align:center;
  font-size:clamp(3.6rem,18.5vw,17rem);color:transparent;-webkit-text-stroke:1.4px rgba(244,184,63,.55);white-space:nowrap;padding:0 10px;letter-spacing:-.01em}
.footer__bar{max-width:var(--maxw);margin:0 auto;padding:40px var(--pad);display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;
  border-top:1px solid rgba(251,246,238,.12);margin-top:clamp(20px,3vw,40px)}
.footer__col{font-size:12.5px;letter-spacing:.04em;color:rgba(251,246,238,.62);line-height:1.9}
.footer__col strong{display:block;font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--or);margin-bottom:8px}
.footer__col a:hover{color:var(--creme)}
.footer__legal{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(251,246,238,.4)}

/* ============================================================
   reveal util
   ============================================================ */
.fade-up{transition:opacity .9s var(--ease),transform .9s var(--ease)}
.js .fade-up{opacity:0;transform:translateY(28px)}
.fade-up.in{opacity:1;transform:none}

/* gold leaf easter egg */
.leaf{position:fixed;top:-40px;z-index:600;pointer-events:none;font-size:22px;will-change:transform;color:var(--or)}

/* ============================================================
   reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .hero__title .char{transform:none !important}
  .hero__script{opacity:1 !important;transform:none !important}
  .reveal-word>span{transform:none !important}
  .sig-card__big{clip-path:none !important}
  .fade-up{opacity:1 !important;transform:none !important}
  .marquee__track{animation:none !important}
}
