/* =========================================================================
   Andrea's Bistro & Grill — Genève · depuis 1928
   Design system — refined, minimal, glassmorphism
   Brand green sampled from logo: #486830
   ========================================================================= */

:root{
  /* --- Brand greens --- */
  --green-900:#243418;
  --green-800:#2d4020;
  --green-700:#39512a;
  --green:#486830;          /* primary — sampled from logo */
  --green-600:#4f7135;
  --green-500:#5f8343;
  --green-300:#93aa73;
  --green-100:#e4ead9;

  /* --- Neutrals / paper --- */
  --ink:#20241a;
  --ink-soft:#3a3f30;
  --muted:#6d7162;
  --cream:#f7f3ea;
  --paper:#fbf9f3;
  --ivory:#fffdf8;
  --sand:#efe7d6;
  --line:rgba(72,104,48,.16);
  --line-strong:rgba(72,104,48,.32);

  /* --- Accent --- */
  --terracotta:#b56a41;
  --gold:#b79a52;

  /* --- Glass --- */
  --glass-light:rgba(255,253,248,.62);
  --glass-light-2:rgba(255,253,248,.78);
  --glass-dark:rgba(28,34,20,.34);
  --glass-border:rgba(255,255,255,.55);
  --glass-border-dark:rgba(255,255,255,.14);
  --blur:18px;

  /* --- Shadows --- */
  --sh-sm:0 2px 10px rgba(36,52,24,.06);
  --sh-md:0 14px 40px -18px rgba(36,52,24,.28);
  --sh-lg:0 30px 70px -30px rgba(36,52,24,.42);
  --sh-glass:0 8px 32px rgba(28,34,20,.12);

  /* --- Type --- */
  --serif:"Cormorant Garamond","Cormorant",Georgia,"Times New Roman",serif;
  --sans:"Jost","Century Gothic","Segoe UI",system-ui,sans-serif;

  /* --- Rhythm --- */
  --nav-h:76px;
  --pad-x:clamp(1.25rem,5vw,5.5rem);
  --sec-y:clamp(5rem,10vw,9rem);
  --maxw:1240px;
  --radius:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset-ish ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--green);color:var(--ivory)}
:focus-visible{outline:2px solid var(--green-600);outline-offset:3px;border-radius:3px}

/* ---------- typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;margin:0;color:var(--green-900);letter-spacing:.005em}
.kicker{
  font-family:var(--sans);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--green-600);
  display:inline-flex;align-items:center;gap:.7em;
  margin:0 0 1.1rem;
}
.kicker::before,.kicker.center::after{
  content:"";width:34px;height:1px;background:var(--line-strong);display:inline-block;
}
.kicker.center{justify-content:center}
.kicker.light{color:var(--green-100)}
.kicker.light::before,.kicker.light.center::after{background:rgba(255,255,255,.4)}

.display{font-size:clamp(2.6rem,6.4vw,5.2rem);font-weight:500;line-height:1.02}
.h2{font-size:clamp(2rem,4.4vw,3.4rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--ink-soft);font-weight:300;max-width:60ch}
.serif-it{font-family:var(--serif);font-style:italic}
.muted{color:var(--muted)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--sec-y)}
.center{text-align:center}
.eyebrow-block{max-width:64ch}

/* greyhound rule */
.rule{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin:1.4rem 0}
.rule::before,.rule::after{content:"";height:1px;width:min(90px,18vw);background:var(--line-strong)}
.rule img{width:60px;opacity:.9}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--green);--fg:var(--ivory);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--sans);font-weight:400;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;
  padding:1.02em 1.9em;border-radius:100px;
  background:var(--bg);color:var(--fg);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .3s,color .3s;
  position:relative;isolation:isolate;box-shadow:var(--sh-md);
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn:active{transform:translateY(0)}
.btn.ghost{--bg:transparent;--fg:var(--green-900);box-shadow:inset 0 0 0 1px var(--line-strong)}
.btn.ghost:hover{--bg:var(--green);--fg:var(--ivory);box-shadow:var(--sh-md)}
.btn.glass{
  --fg:var(--ivory);
  background:var(--glass-dark);
  -webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));
  box-shadow:inset 0 0 0 1px var(--glass-border-dark),var(--sh-glass);
}
.btn.glass:hover{background:rgba(72,104,48,.72)}
.btn.small{padding:.7em 1.3em;font-size:.72rem}
.btn.block{width:100%}
.btn[disabled]{opacity:.5;pointer-events:none}

.link-underline{position:relative;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;color:var(--green-700)}
.link-underline::after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.link-underline:hover::after{transform:scaleX(1)}

/* =========================================================================
   NAVBAR
   ========================================================================= */
.nav{
  position:fixed;inset:0 0 auto 0;height:var(--nav-h);z-index:100;
  display:flex;align-items:center;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),height .4s var(--ease);
}
.nav__inner{max-width:var(--maxw);margin-inline:auto;width:100%;padding-inline:var(--pad-x);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}
.nav__logo{display:flex;align-items:center;justify-self:start}
.nav__right{justify-self:end;display:flex;align-items:center;gap:.6rem}
.nav__logo img{height:38px;width:auto;transition:filter .5s var(--ease),height .4s var(--ease)}
.nav__links{display:flex;align-items:center;gap:2.1rem}
.nav__links a{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;color:var(--ivory);
  position:relative;transition:color .3s;opacity:.92}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:center;transition:transform .4s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after,.nav__links a.active::after{transform:scaleX(1)}
.nav__links .btn{display:none}/* the in-drawer Réserver button — desktop uses nav__cta instead */
.nav__cta{margin-left:.5rem}
.nav__burger{display:none;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;
  background:var(--glass-dark);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 0 0 1px var(--glass-border-dark)}
.nav__burger span{display:block;width:19px;height:1.5px;background:var(--ivory);position:relative;transition:.35s var(--ease)}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:19px;height:1.5px;background:var(--ivory);transition:.35s var(--ease)}
.nav__burger span::before{top:-6px}.nav__burger span::after{top:6px}

/* scrolled state */
.nav.scrolled{
  height:64px;
  background:var(--glass-light-2);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(1.3);backdrop-filter:blur(var(--blur)) saturate(1.3);
  box-shadow:0 1px 0 var(--line),var(--sh-glass);
}
.nav.scrolled .nav__links a{color:var(--ink-soft)}
.nav.scrolled .nav__logo img{filter:none}
.nav.scrolled .nav__burger{background:var(--glass-light);box-shadow:inset 0 0 0 1px var(--line)}
.nav.scrolled .nav__burger span,.nav.scrolled .nav__burger span::before,.nav.scrolled .nav__burger span::after{background:var(--green-800)}
/* logo tint: cream on hero (top), green when scrolled — handled by swapping src via JS is heavy; use two imgs */
.nav__logo .logo-cream{display:block}
.nav__logo .logo-green{display:none}
.nav.scrolled .nav__logo .logo-cream{display:none}
.nav.scrolled .nav__logo .logo-green{display:block}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(120% 90% at 50% 15%,rgba(28,34,20,.15),transparent 55%),
    linear-gradient(180deg,rgba(28,34,20,.42) 0%,rgba(28,34,20,.28) 38%,rgba(28,34,20,.52) 100%);
}
.hero__inner{position:relative;padding:calc(var(--nav-h) + 2rem) var(--pad-x) 6rem;max-width:960px}
.hero__logo{width:min(340px,64vw);margin:0 auto 1.6rem;filter:drop-shadow(0 6px 24px rgba(0,0,0,.35))}
.hero__tagline{color:var(--ivory);font-weight:500;text-shadow:0 3px 30px rgba(0,0,0,.35)}
.hero__tagline em{font-style:italic;color:#f4ecd8}
.hero__sub{color:rgba(255,253,248,.9);font-size:clamp(1rem,1.5vw,1.2rem);margin:1.4rem auto 2.4rem;max-width:44ch;font-weight:300}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:1.7rem;left:50%;transform:translateX(-50%);color:rgba(255,253,248,.8);
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.hero__scroll .line{width:1px;height:44px;background:linear-gradient(rgba(255,253,248,.7),transparent);position:relative;overflow:hidden}
.hero__scroll .line::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:var(--ivory);animation:scrolldot 2.4s var(--ease) infinite}
@keyframes scrolldot{0%{top:-50%}60%,100%{top:100%}}
.hero__info{position:absolute;bottom:1.7rem;right:var(--pad-x);color:rgba(255,253,248,.82);font-size:.74rem;letter-spacing:.05em;text-align:right;line-height:1.7;display:none}
.hero__info b{font-weight:400;letter-spacing:.14em;text-transform:uppercase;font-size:.68rem}

/* =========================================================================
   MAISON (about)
   ========================================================================= */
.maison{background:linear-gradient(180deg,var(--paper),var(--cream))}
.maison__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.maison__text p{margin:0 0 1.15rem;color:var(--ink-soft)}
.maison__quote{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.4vw,2rem);color:var(--green-800);
  line-height:1.3;margin:2rem 0 0;padding-left:1.4rem;border-left:2px solid var(--green-500)}
.maison__figure{position:relative}
.maison__figure .frame{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-lg)}
.maison__figure img{width:100%;aspect-ratio:4/5;object-fit:cover}
.maison__figure .badge{
  position:absolute;right:-22px;bottom:-22px;width:132px;height:132px;border-radius:50%;
  background:var(--glass-light-2);-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));
  box-shadow:var(--sh-md),inset 0 0 0 1px var(--glass-border);
  display:grid;place-items:center;text-align:center}
.maison__figure .badge img{width:64px;height:auto;aspect-ratio:auto}
.stats{display:flex;gap:2.4rem;margin-top:2.4rem;flex-wrap:wrap}
.stat .n{font-family:var(--serif);font-size:2.5rem;color:var(--green);line-height:1}
.stat .l{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.35rem}

/* =========================================================================
   SIGNATURE (truffle poster)
   ========================================================================= */
.signature{position:relative;background:var(--green-900);color:var(--cream);overflow:hidden}
.signature::before{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 120% at 85% 10%,rgba(95,131,67,.35),transparent 60%),
  radial-gradient(60% 90% at 0% 100%,rgba(181,106,65,.18),transparent 55%)}
.signature__grid{position:relative;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.signature__poster{border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-lg);transform:rotate(-1.4deg);
  border:6px solid rgba(255,253,248,.9)}
.signature__poster img{width:100%}
.signature h2{color:var(--ivory)}
.signature__text p{color:rgba(247,243,234,.82)}
.signature__cite{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,2.6vw,2.2rem);color:#f0e6cf;line-height:1.28;margin:0 0 1.6rem}

/* =========================================================================
   MENU
   ========================================================================= */
.menu{background:var(--ivory)}
.menu__tabs{display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap;margin:2.2rem auto 3rem;
  padding:.4rem;border-radius:100px;background:var(--cream);box-shadow:inset 0 0 0 1px var(--line);width:max-content;max-width:100%}
.menu__tab{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;color:var(--muted);
  padding:.72em 1.5em;border-radius:100px;transition:color .3s,background .4s var(--ease),box-shadow .4s;white-space:nowrap}
.menu__tab.active{color:var(--green-900);background:var(--ivory);box-shadow:var(--sh-sm)}
.menu__panel{display:none;animation:fade .6s var(--ease)}
.menu__panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.menu__cols{columns:2;column-gap:clamp(2rem,5vw,5rem)}
.menu__group{break-inside:avoid;margin-bottom:2.6rem}
.menu__group h3{font-size:1.9rem;color:var(--green-800);display:flex;align-items:baseline;gap:.8rem;margin-bottom:.2rem}
.menu__group h3 .sup{font-family:var(--sans);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:400}
.menu__group .grpline{height:1px;background:var(--line);margin:.7rem 0 1.1rem}
.menu__item{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem;padding:.5rem 0;border-bottom:1px dotted transparent;transition:border-color .3s}
.menu__item:hover{border-color:var(--line)}
.menu__item .name{font-size:1.02rem;color:var(--ink);font-weight:400}
.menu__item .name small{display:block;font-size:.82rem;color:var(--muted);font-weight:300;letter-spacing:.01em;margin-top:.1rem}
.menu__item .dots{flex:1;border-bottom:1px dotted var(--line-strong);transform:translateY(-4px);margin:0 .2rem;min-width:16px}
.menu__item .price{font-family:var(--serif);font-size:1.15rem;color:var(--green);white-space:nowrap;font-weight:500}
.menu__note{font-size:.78rem;color:var(--muted);text-align:center;margin-top:1.4rem;font-style:italic}
.menu__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.6rem}
.menu__tag{display:inline-block;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta);
  border:1px solid currentColor;border-radius:100px;padding:.2em .6em;margin-left:.5rem;vertical-align:middle;font-weight:400}

/* =========================================================================
   GALERIE
   ========================================================================= */
.galerie{background:linear-gradient(180deg,var(--cream),var(--paper))}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:2.5rem}
.gal figure{margin:0;overflow:hidden;border-radius:14px;position:relative;box-shadow:var(--sh-sm);cursor:zoom-in;aspect-ratio:4/3}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.gal figure::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(28,34,20,.28),transparent 50%);opacity:0;transition:opacity .5s}
.gal figure:hover img{transform:scale(1.06)}
.gal figure:hover::after{opacity:1}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;display:none;place-items:center;padding:5vw;
  background:rgba(20,24,16,.82);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.lightbox.open{display:grid;animation:fade .3s}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:var(--sh-lg)}
.lightbox__close{position:absolute;top:4vw;right:4vw;width:48px;height:48px;border-radius:50%;color:var(--ivory);
  background:var(--glass-dark);box-shadow:inset 0 0 0 1px var(--glass-border-dark);font-size:1.4rem}

/* =========================================================================
   RESERVATIONS
   ========================================================================= */
.reserve{position:relative;color:var(--cream);overflow:hidden;background:var(--green-900)}
.reserve__media{position:absolute;inset:0;z-index:0}
.reserve__media video,.reserve__media img{width:100%;height:100%;object-fit:cover;opacity:.32}
.reserve::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(36,52,24,.7),rgba(36,52,24,.82))}
.reserve__grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.reserve h2{color:var(--ivory)}
.reserve__text p{color:rgba(247,243,234,.82)}
.reserve__contacts{margin-top:2rem;display:flex;flex-direction:column;gap:.6rem}
.reserve__contacts a,.reserve__contacts span{color:var(--cream);display:flex;align-items:center;gap:.8rem;font-size:.98rem}
.reserve__contacts svg{width:18px;height:18px;stroke:var(--green-300);flex:none}

/* booking card */
.book{
  background:var(--glass-light);
  -webkit-backdrop-filter:blur(calc(var(--blur) + 6px)) saturate(1.4);backdrop-filter:blur(calc(var(--blur) + 6px)) saturate(1.4);
  border:1px solid var(--glass-border);border-radius:20px;padding:clamp(1.6rem,3vw,2.4rem);
  box-shadow:var(--sh-lg);color:var(--ink)}
.book__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.3rem}
.book__head h3{font-size:1.7rem;color:var(--green-900)}
.book__steps{display:flex;gap:.4rem}
.book__steps i{width:8px;height:8px;border-radius:50%;background:var(--line-strong);transition:.4s var(--ease)}
.book__steps i.on{background:var(--green);transform:scale(1.2)}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-700);margin-bottom:.45rem;font-weight:500}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:.98rem;font-weight:300;color:var(--ink);
  background:rgba(255,255,255,.6);border:1px solid var(--line-strong);border-radius:10px;padding:.85em 1em;
  transition:border-color .3s,box-shadow .3s,background .3s}
.field textarea{resize:vertical;min-height:72px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(72,104,48,.14);background:#fff}
.field.row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.field.row.three{grid-template-columns:1fr 1fr 1fr}
.chiprow{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-size:.82rem;padding:.55em 1em;border-radius:100px;background:rgba(255,255,255,.55);
  box-shadow:inset 0 0 0 1px var(--line-strong);transition:.3s var(--ease);font-weight:400;color:var(--ink-soft)}
.chip:hover{box-shadow:inset 0 0 0 1px var(--green-500)}
.chip.sel{background:var(--green);color:var(--ivory);box-shadow:none}
.chip[disabled]{opacity:.35;pointer-events:none;text-decoration:line-through}
.book__msg{font-size:.8rem;color:var(--terracotta);min-height:1.1em;margin:.2rem 0 .4rem}
.book__foot{font-size:.72rem;color:var(--muted);text-align:center;margin-top:1rem;line-height:1.5}
.book__foot a{color:var(--green-700);text-decoration:underline}

/* confirmation */
.book__confirm{text-align:center;padding:1rem 0}
.book__confirm .tick{width:74px;height:74px;border-radius:50%;margin:0 auto 1.2rem;display:grid;place-items:center;
  background:var(--green);box-shadow:var(--sh-md);animation:pop .5s var(--ease)}
.book__confirm .tick svg{width:34px;height:34px;stroke:#fff;stroke-width:2.5;fill:none}
@keyframes pop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
.book__confirm h3{font-size:2rem;color:var(--green-900);margin-bottom:.5rem}
.book__code{font-family:var(--serif);font-size:1.4rem;letter-spacing:.14em;color:var(--terracotta);margin:1rem 0;
  padding:.5rem 1rem;border:1px dashed var(--line-strong);border-radius:10px;display:inline-block}
.step{display:none}.step.active{display:block;animation:fade .5s var(--ease)}

/* =========================================================================
   CONTACT / FOOTER
   ========================================================================= */
.contact{background:var(--ivory)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.info-list{list-style:none;margin:1.5rem 0 0;padding:0;display:grid;gap:1.3rem}
.info-list li{display:flex;gap:1rem;align-items:flex-start}
.info-list .ic{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;background:var(--cream);box-shadow:inset 0 0 0 1px var(--line)}
.info-list .ic svg{width:19px;height:19px;stroke:var(--green);fill:none;stroke-width:1.6}
.info-list .k{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.15rem}
.info-list .v{font-size:1.02rem;color:var(--ink)}
.info-list .v a:hover{color:var(--green)}
.hours{list-style:none;margin:.6rem 0 0;padding:0;width:100%}
.hours li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
.hours .day{color:var(--ink);white-space:nowrap}
.hours .hrs{display:flex;flex-wrap:wrap;gap:.1rem .55rem;justify-content:flex-end;text-align:right;color:var(--ink-soft)}
.hours .hrs b{font-weight:300;white-space:nowrap}
.hours .closed{color:var(--muted)}
.hours li.today .day{color:var(--green-800);font-weight:400}
.hours li.today .day::after{content:"aujourd’hui";display:inline-block;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--green-600);background:var(--green-100);border-radius:100px;padding:.15em .55em;margin-left:.5rem;vertical-align:middle}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-md);border:1px solid var(--line);min-height:280px;height:100%}
.map-embed iframe{width:100%;height:100%;min-height:280px;border:0;filter:grayscale(.2) contrast(1.02)}

.footer{background:var(--green-900);color:var(--cream);padding:clamp(3.5rem,7vw,5.5rem) 0 2rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;align-items:start}
.footer__brand img{width:190px;margin-bottom:1.2rem}
.footer__brand p{color:rgba(247,243,234,.65);font-size:.92rem;max-width:34ch}
.footer h4{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green-300);font-family:var(--sans);font-weight:500;margin-bottom:1.1rem}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.footer a{color:rgba(247,243,234,.8);font-size:.95rem;transition:color .3s}
.footer a:hover{color:var(--ivory)}
.footer__social{display:flex;gap:.7rem;margin-top:1.2rem}
.footer__social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);transition:.3s}
.footer__social a:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.footer__social svg{width:18px;height:18px;fill:var(--cream)}
.footer__bar{margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.78rem;color:rgba(247,243,234,.55)}
.footer__bar a{color:rgba(247,243,234,.7)}
.demo-badge{display:inline-flex;align-items:center;gap:.5em;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--green-300);border:1px solid rgba(147,170,115,.4);border-radius:100px;padding:.15em .6em;margin-left:.4em}
.footer__credit a{color:var(--green-300);text-decoration:none;position:relative}
.footer__credit a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.footer__credit a:hover::after{transform:scaleX(1)}
.footer__panel{display:inline-flex;align-items:center;gap:.5em;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cream)!important;border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:.45em .95em;transition:.3s var(--ease)}
.footer__panel:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.4)}
.footer__panel svg{width:15px;height:15px}

/* =========================================================================
   CHATBOT
   ========================================================================= */
.cbot{position:fixed;right:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);z-index:150;font-family:var(--sans)}
.cbot__toggle{width:62px;height:62px;border-radius:50%;background:var(--green);box-shadow:var(--sh-lg);
  display:grid;place-items:center;position:relative;transition:transform .4s var(--ease)}
.cbot__toggle:hover{transform:scale(1.06)}
.cbot__toggle svg{width:27px;height:27px;fill:none;stroke:var(--ivory);stroke-width:1.6}
.cbot__toggle .dot{position:absolute;top:4px;right:4px;width:12px;height:12px;border-radius:50%;background:var(--terracotta);box-shadow:0 0 0 3px var(--green)}
.cbot__toggle .close-ic{display:none}
.cbot.open .cbot__toggle .open-ic{display:none}
.cbot.open .cbot__toggle .close-ic{display:block}
.cbot.open .cbot__toggle .dot{display:none}

.cbot__panel{
  position:absolute;bottom:76px;right:0;width:min(380px,calc(100vw - 2rem));height:min(560px,70vh);
  display:flex;flex-direction:column;overflow:hidden;border-radius:20px;
  background:var(--glass-light-2);-webkit-backdrop-filter:blur(calc(var(--blur) + 8px)) saturate(1.4);backdrop-filter:blur(calc(var(--blur) + 8px)) saturate(1.4);
  border:1px solid var(--glass-border);box-shadow:var(--sh-lg);
  transform-origin:bottom right;transform:scale(.86) translateY(14px);opacity:0;pointer-events:none;
  transition:transform .45s var(--ease),opacity .35s var(--ease)}
.cbot.open .cbot__panel{transform:none;opacity:1;pointer-events:auto}
.cbot__head{display:flex;align-items:center;gap:.8rem;padding:1rem 1.1rem;background:var(--green);color:var(--ivory)}
.cbot__head .av{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;flex:none}
.cbot__head .av img{width:30px}
.cbot__head .t{font-family:var(--serif);font-size:1.2rem;line-height:1.1}
.cbot__head .s{font-size:.68rem;letter-spacing:.06em;opacity:.85;display:flex;align-items:center;gap:.4em}
.cbot__head .s::before{content:"";width:7px;height:7px;border-radius:50%;background:#8fd07a;box-shadow:0 0 0 2px rgba(143,208,122,.35)}
.cbot__body{flex:1;overflow-y:auto;padding:1.1rem;display:flex;flex-direction:column;gap:.7rem;scroll-behavior:smooth}
.cbot__body::-webkit-scrollbar{width:6px}.cbot__body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}
.msg{max-width:84%;padding:.7rem .95rem;border-radius:16px;font-size:.9rem;line-height:1.5;white-space:pre-line;animation:fade .35s var(--ease)}
.msg.bot{align-self:flex-start;background:rgba(255,255,255,.72);color:var(--ink);border-bottom-left-radius:5px;box-shadow:var(--sh-sm)}
.msg.user{align-self:flex-end;background:var(--green);color:var(--ivory);border-bottom-right-radius:5px}
.msg a{color:var(--green-700);text-decoration:underline}
.msg.user a{color:#eafbe0}
.typing{align-self:flex-start;display:flex;gap:4px;padding:.85rem 1rem;background:rgba(255,255,255,.72);border-radius:16px;border-bottom-left-radius:5px}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--green-300);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.cbot__chips{display:flex;gap:.45rem;flex-wrap:wrap;padding:.2rem 1.1rem .4rem}
.cbot__chips button{font-size:.76rem;padding:.5em .9em;border-radius:100px;background:rgba(255,255,255,.6);
  box-shadow:inset 0 0 0 1px var(--line-strong);color:var(--green-800);transition:.25s;font-weight:400}
.cbot__chips button:hover{background:var(--green);color:var(--ivory);box-shadow:none}
.cbot__input{display:flex;gap:.5rem;padding:.8rem 1rem 1rem;border-top:1px solid var(--line)}
.cbot__input input{flex:1;border:1px solid var(--line-strong);border-radius:100px;padding:.7em 1em;font-family:var(--sans);font-size:.9rem;background:rgba(255,255,255,.7)}
.cbot__input input:focus{outline:none;border-color:var(--green)}
.cbot__input button{width:44px;height:44px;border-radius:50%;background:var(--green);display:grid;place-items:center;flex:none;transition:.3s}
.cbot__input button:hover{background:var(--green-700)}
.cbot__input button svg{width:19px;height:19px;stroke:var(--ivory);fill:none;stroke-width:1.8}

/* =========================================================================
   REVEAL animations
   ========================================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__scroll .line::after{animation:none}
  *{scroll-behavior:auto!important}
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:1024px){
  .hero__info{display:none}
}
@media (max-width:900px){
  /* menu becomes a fixed drawer (out of flow) → use flex so logo stays left & burger right */
  .nav__inner{display:flex;justify-content:space-between;align-items:center}
  .nav__right{justify-self:auto}
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(320px,84vw);height:100vh;flex-direction:column;justify-content:center;gap:2rem;
    background:var(--glass-light-2);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:var(--sh-lg);
    transform:translateX(100%);transition:transform .5s var(--ease);padding:2rem}
  .nav__links.open{transform:none}
  .nav__links a{color:var(--green-900);font-size:1rem}
  .nav__links .btn{display:inline-flex;color:var(--ivory)}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .nav.menu-open .nav__burger span{background:transparent}
  .nav.menu-open .nav__burger span::before{top:0;transform:rotate(45deg)}
  .nav.menu-open .nav__burger span::after{top:0;transform:rotate(-45deg)}
  .maison__grid,.signature__grid,.reserve__grid,.contact__grid{grid-template-columns:1fr}
  .signature__poster{transform:none;max-width:400px;margin-inline:auto}
  .maison__figure{max-width:440px;margin-inline:auto;width:100%}
  /* symmetry: centre the stacked text blocks on tablet/mobile */
  .maison__text,.signature__text,.reserve__text{text-align:center}
  .maison__text .kicker,.signature__text .kicker,.reserve__text .kicker{justify-content:center}
  .maison__text .lead,.signature__text p,.reserve__text p,.maison__text p{margin-inline:auto}
  .maison__quote{border-left:none;border-top:2px solid var(--green-500);padding:1.1rem 0 0;margin:2rem auto 0;max-width:44ch}
  .stats{justify-content:center}
  .reserve__contacts{align-items:center}
  .contact .info-list{max-width:460px;margin-inline:auto}
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}
@media (max-width:680px){
  .menu__cols{columns:1}
  .gal{grid-template-columns:repeat(2,1fr);gap:12px}
  .field.row,.field.row.three{grid-template-columns:1fr}
  .maison__figure .badge{right:6px;bottom:-14px;width:104px;height:104px}
  .maison__figure .badge img{width:52px}
  /* footer centred & symmetric */
  .footer__top{grid-template-columns:1fr;text-align:center;justify-items:center}
  .footer__brand p{margin-inline:auto}
  .footer__brand img{margin-inline:auto}
  .footer__social{justify-content:center}
  .footer__bar{justify-content:center;text-align:center;flex-direction:column;align-items:center;gap:.7rem}
  .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center;margin-inline:auto;max-width:420px}
  .stat .n{font-size:1.7rem}
  .stat .l{font-size:.6rem}
}
/* menu tabs: one clean row on small screens */
@media (max-width:600px){
  .menu__tabs{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem}
  .menu__tab{padding:.72em .3em;font-size:.66rem;letter-spacing:.08em;text-align:center}
}
/* hero fine-tuning on phones — compact, centred, no scroll-cue overlap */
@media (max-width:680px){
  .hero__inner{padding-top:calc(var(--nav-h) - 1rem);padding-bottom:6.5rem}
  .hero__logo{width:min(214px,50vw);margin-bottom:.8rem}
  .hero .kicker{margin-bottom:.6rem}
  .hero__tagline{font-size:clamp(2rem,8.2vw,2.6rem)}
  .hero__sub{font-size:.95rem;margin:.8rem auto 1.4rem;max-width:32ch}
  .hero__cta{gap:.6rem}
  .hero__scroll{display:none}          /* évite tout chevauchement avec les boutons */
}
@media (max-width:480px){
  .hero__inner{padding-left:1.1rem;padding-right:1.1rem}
  .hero__logo{width:min(196px,52vw)}
  .hero .kicker{letter-spacing:.16em;font-size:.58rem}
  .hero__tagline{font-size:clamp(1.9rem,8.6vw,2.4rem)}
  .hero__sub{font-size:.9rem;margin:.75rem auto 1.25rem}
  .hero__cta{flex-direction:column;align-items:center;gap:.55rem}
  .hero__cta .btn{width:100%;max-width:280px;padding:.9em 1.4em}
  .display{line-height:1.06}
}
