/* ============================================================
   La Cantine de Lulu — feuille de style
   Palette ardoise / crème / terracotta / laiton vintage
   ============================================================ */
:root{
  --ardoise:#23211e;
  --ardoise-2:#2c2925;
  --ardoise-3:#38332d;
  --cream:#f7f2e8;
  --cream-2:#efe6d6;
  --paper:#fbf8f1;
  --terracotta:#c4502e;
  --terracotta-d:#a23d20;
  --gold:#c39a4e;
  --gold-d:#a07e36;
  --ink:#2a2622;
  --muted:#7a7065;
  --line:rgba(42,38,34,.12);
  --shadow:0 18px 50px -22px rgba(35,33,30,.55);
  --radius:16px;
  --maxw:1180px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"DM Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --script:"Sacramento",cursive;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}

/* ===== INTRO (animation d'ouverture) ===== */
.intro{position:fixed;inset:0;z-index:9999;background:var(--ardoise);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:1;transition:opacity .6s ease;cursor:pointer}
.intro.hide{opacity:0;pointer-events:none}
.intro__logo{width:min(80vmin,600px);height:auto;border-radius:20px;opacity:0;animation:introFade 2s ease .55s forwards}
.intro__text{font-family:var(--script);color:var(--gold);font-size:clamp(1.9rem,6.4vw,3.4rem);line-height:1;text-align:center;opacity:0;animation:introFade .6s ease .15s forwards;text-shadow:0 2px 12px rgba(0,0,0,.4)}
@keyframes introFade{to{opacity:1}}
body.intro-lock{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  .intro__logo,.intro__text{animation-duration:.01ms}
}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.1;color:var(--ink)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section--tight{padding:64px 0}
.eyebrow{
  font-family:var(--script);
  font-size:2rem;
  color:var(--terracotta);
  font-weight:400;
  display:block;
  line-height:1;
}
.section-title{
  font-size:clamp(2rem,4.6vw,3.2rem);
  margin:.15em 0 .35em;
  letter-spacing:.3px;
}
.lead{font-size:1.08rem;color:var(--muted);max-width:62ch}
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:.97rem;
  padding:.85em 1.6em;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--terracotta);color:#fff;box-shadow:0 12px 26px -12px rgba(196,80,46,.8)}
.btn--primary:hover{background:var(--terracotta-d);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--cream);border-color:rgba(247,242,232,.5)}
.btn--ghost:hover{background:rgba(247,242,232,.12);border-color:var(--cream)}
.btn--dark{background:var(--ardoise);color:var(--cream)}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
.btn--gold{background:var(--gold);color:var(--ardoise)}
.btn--gold:hover{background:var(--gold-d);transform:translateY(-2px)}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;
}
.nav.scrolled{background:rgba(35,33,30,.62);box-shadow:0 8px 30px -16px rgba(0,0,0,.5);padding:10px 24px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(247,242,232,.1)}
.nav__brand{display:flex;align-items:center;line-height:0}
.nav__brand img{height:124px;width:auto;display:block;border-radius:14px;box-shadow:0 12px 30px -12px rgba(0,0,0,.6);transition:height .3s ease}
.nav.scrolled .nav__brand img{height:86px;border-radius:11px}
.nav__links{display:flex;align-items:center;gap:28px}
.nav__links a{color:rgba(247,242,232,.85);font-weight:500;font-size:.95rem;transition:color .2s}
.nav__links a:hover{color:#fff}
.nav__cta{display:flex;align-items:center;gap:12px}
.nav__tel{white-space:nowrap}
.nav__burger{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav__burger span{display:block;width:26px;height:2px;background:var(--cream);margin:5px 0;border-radius:2px;transition:transform .3s ease,opacity .2s ease}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== BANDEAUX (promo / événement) ===== */
.banners{position:fixed;top:0;left:0;right:0;z-index:90}
.banner{display:none;align-items:center;justify-content:center;gap:10px;padding:9px 18px;font-size:.92rem;font-weight:600;text-align:center;position:relative;overflow:hidden}
.banner.show{display:flex;animation:slidedown .5s ease}
.banner--promo{background:linear-gradient(90deg,var(--gold),#d9b765);color:var(--ardoise)}
.banner--event{background:linear-gradient(90deg,var(--terracotta),#d6633f);color:#fff}
.banner__dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
@keyframes slidedown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
body.has-banner .nav{transition:none}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:var(--cream);overflow:hidden}
body.has-banner .hero{align-items:flex-start}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 36%}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(35,33,30,.72) 0%,rgba(35,33,30,.5) 45%,rgba(35,33,30,.82) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;padding:120px 0 80px}
.hero__kicker{font-family:var(--script);font-size:clamp(1.9rem,4.4vw,2.9rem);color:#e7c074;font-weight:400;line-height:1;margin-bottom:.05em;text-shadow:0 1px 2px rgba(0,0,0,.9),0 2px 7px rgba(0,0,0,.75),0 4px 22px rgba(0,0,0,.6)}
.hero h1{font-size:clamp(2.8rem,8vw,5.6rem);color:#fff;font-weight:700;letter-spacing:.5px;line-height:.98;margin:.1em 0 .35em}
.hero__sub{font-size:clamp(1.05rem,2.4vw,1.35rem);max-width:54ch;color:rgba(247,242,232,.92);font-weight:300}
.hero__tags{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 34px}
.hero__tag{font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:.45em 1em;border:1px solid rgba(247,242,232,.4);border-radius:999px;color:rgba(247,242,232,.92)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(247,242,232,.7);font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.hero__scroll::after{content:"";width:1px;height:34px;background:rgba(247,242,232,.5);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}100%{transform:scaleY(.2);transform-origin:bottom}}

/* ===== À PROPOS ===== */
.about{background:var(--cream)}
.about__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.about__imgs{position:relative}
.about__imgs img{border-radius:var(--radius);box-shadow:var(--shadow)}
.about__imgs .img-main{aspect-ratio:4/5;object-fit:cover}
.about__imgs .img-float{position:absolute;width:46%;aspect-ratio:1;object-fit:cover;right:-22px;bottom:-30px;border:6px solid var(--cream);border-radius:14px}
.about__imgs .badge{position:absolute;top:-22px;left:-22px;background:var(--ardoise);color:var(--cream);width:118px;height:118px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-family:var(--script);line-height:1.05;box-shadow:var(--shadow);transform:rotate(-8deg)}
.about__imgs .badge b{font-size:2.5rem;font-weight:400}
.about__imgs .badge span{font-size:1.15rem}
.about p+p{margin-top:1.1em}
.about__quote{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--terracotta);border-left:3px solid var(--gold);padding-left:18px;margin:26px 0}
.about__signs{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.chip{display:inline-flex;align-items:center;gap:.5em;font-size:.85rem;font-weight:600;background:#fff;border:1px solid var(--line);padding:.5em 1em;border-radius:999px;color:var(--ink)}
.chip svg{width:1.05em;height:1.05em;color:var(--terracotta)}

/* ===== SPÉCIALITÉS ===== */
.spec{background:var(--ardoise);color:var(--cream);position:relative}
.spec .section-title{color:#fff}
.spec .eyebrow{color:var(--gold)}
.spec__head{text-align:center;max-width:640px;margin:0 auto 56px}
.spec__head .lead{color:rgba(247,242,232,.72);margin:0 auto}
.spec__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.spec__card{position:relative;background:var(--ardoise-2);border:1px solid rgba(247,242,232,.08);border-radius:var(--radius);padding:30px 26px;overflow:hidden;transition:transform .28s cubic-bezier(.2,.7,.2,1),border-color .28s ease,box-shadow .28s ease}
/* liseré laiton qui se révèle au survol, façon néon vintage */
.spec__card::after{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid transparent;box-shadow:inset 0 0 0 0 rgba(195,154,78,0);transition:box-shadow .35s ease;pointer-events:none}
.spec__card:hover{transform:translateY(-7px) rotate(-.4deg);border-color:rgba(195,154,78,.55);box-shadow:0 24px 46px -26px rgba(0,0,0,.8)}
.spec__card:hover::after{box-shadow:inset 0 0 22px -6px rgba(195,154,78,.45)}
.spec__icon{width:50px;height:50px;border-radius:12px;background:rgba(195,154,78,.15);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:16px;transition:background .3s ease,color .3s ease,transform .35s cubic-bezier(.2,.7,.2,1)}
.spec__icon svg{width:26px;height:26px}
.spec__card:hover .spec__icon{background:var(--gold);color:var(--ardoise);transform:rotate(-8deg) scale(1.1)}
.spec__card h3{color:#fff;font-size:1.5rem;margin-bottom:.25em;transition:color .3s ease}
.spec__card:hover h3{color:var(--gold)}
.spec__card p{color:rgba(247,242,232,.66);font-size:.95rem}

/* ===== CARTE / MENU ===== */
.menu{background:var(--paper)}
.menu__head{text-align:center;max-width:640px;margin:0 auto 52px}
.menu__head .lead{margin:0 auto}
.menu__cats{display:grid;grid-template-columns:1fr 1fr;gap:38px 56px}
.menu__cat h3{font-size:1.9rem;color:var(--terracotta);margin-bottom:.5em;position:relative;padding-bottom:.3em}
.menu__cat h3::after{content:"";position:absolute;left:0;bottom:0;width:46px;height:2px;background:var(--gold)}
.menu__item{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px dashed var(--line)}
.menu__item:last-child{border-bottom:0}
.menu__item .mi-name{font-family:var(--serif);font-size:1.28rem;font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.menu__item .mi-desc{font-size:.9rem;color:var(--muted)}
.menu__item .mi-price{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--ink);white-space:nowrap}
.menu__item .mi-price::after{content:" €"}
.tag{font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.25em .6em;border-radius:999px;line-height:1}
.tag--veg{background:#e3efe0;color:#3f7a3a}
.tag--sansgluten{background:#f3e8d6;color:#9a6a1e}
.tag--nouveau{background:var(--terracotta);color:#fff}
/* mode menu du jour */
.menu-jour{max-width:560px;margin:0 auto;background:var(--ardoise);color:var(--cream);border-radius:var(--radius);padding:44px 40px;box-shadow:var(--shadow);text-align:center}
.menu-jour h3{color:var(--gold);font-family:var(--script);font-size:2.9rem;margin-bottom:.2em}
.menu-jour pre{font-family:var(--serif);font-size:1.3rem;white-space:pre-wrap;line-height:1.9;color:#fff;margin:0}
/* mode photo */
.menu-photo{text-align:center}
.menu-photo img{display:inline-block;max-height:80vh;border-radius:var(--radius);box-shadow:var(--shadow);margin:0 auto}
.menu-photo a.btn{margin-top:22px}
.menu__note{text-align:center;color:var(--muted);font-size:.9rem;margin-top:40px;font-style:italic}
.menu-subtitle{text-align:center;font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,3.6vw,2.7rem);color:var(--ink);margin:0 0 34px}
.menu-sep{height:54px;position:relative}
.menu-sep::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
/* Carrousel de photos de plats (ronds à bords adoucis, défilement continu) */
.food-carousel{position:relative;overflow:hidden;margin:6px 0 46px;padding:10px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.food-track{display:flex;gap:34px;width:max-content;animation:foodscroll 44s linear infinite}
.food-carousel:hover .food-track{animation-play-state:paused}
.food-bubble{flex:0 0 auto;text-align:center}
.food-bubble .fb-img{width:148px;height:148px;border-radius:50%;position:relative;margin:0 auto}
.food-bubble .fb-img::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(195,154,78,.35);pointer-events:none}
.food-bubble img{width:148px;height:148px;border-radius:50%;object-fit:cover;display:block;filter:saturate(1.06);transition:transform .5s ease;
  -webkit-mask-image:radial-gradient(circle at center,#000 60%,rgba(0,0,0,.35) 72%,transparent 80%);
  mask-image:radial-gradient(circle at center,#000 60%,rgba(0,0,0,.35) 72%,transparent 80%)}
.food-bubble:hover img{transform:scale(1.07)}
.food-bubble figcaption{font-family:var(--script);font-size:1.6rem;color:var(--terracotta);margin-top:6px;line-height:1}
@keyframes foodscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.food-track{animation:none}}
@media(max-width:760px){
  .food-bubble .fb-img,.food-bubble img{width:112px;height:112px}
  .food-track{gap:24px;animation-duration:34s}
}

/* ===== GALERIE ===== */
.gallery{background:var(--cream)}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;grid-auto-flow:dense}
.gallery__grid figure{overflow:hidden;border-radius:12px;cursor:pointer;margin:0;position:relative}
.gallery__grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery__grid figure:hover img{transform:scale(1.07)}
.gallery__grid .tall{grid-row:span 2}
.gallery__grid .wide{grid-column:span 2}

/* ===== RÉSERVATION ===== */
.reserve{background:var(--ardoise);color:var(--cream)}
.reserve__grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.reserve .eyebrow{color:var(--gold)}
.reserve .section-title{color:#fff}
.reserve__lead{color:rgba(247,242,232,.75);max-width:46ch;margin-bottom:24px}
.reserve__img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative}
.reserve__img img{width:100%;aspect-ratio:4/5;object-fit:cover}
.reserve__info{display:flex;gap:22px;flex-wrap:wrap;margin-top:20px}
.reserve__info a{display:inline-flex;align-items:center;gap:9px;color:var(--gold);font-weight:600}
.reserve__info svg{width:1.1em;height:1.1em}
.form{background:var(--ardoise-2);border:1px solid rgba(247,242,232,.1);border-radius:var(--radius);padding:32px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:rgba(247,242,232,.7);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;padding:.8em 1em;border-radius:10px;border:1px solid rgba(247,242,232,.18);
  background:rgba(247,242,232,.06);color:var(--cream);font-family:var(--sans);font-size:.97rem;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(247,242,232,.1)}
.field input::placeholder,.field textarea::placeholder{color:rgba(247,242,232,.4)}
.field select option{color:#000}
.form__msg{margin-top:8px;font-size:.92rem;min-height:1.2em;font-weight:600}
.form__msg.ok{color:#8fd08a}
.form__msg.err{color:#f0a08a}
.form__disabled{text-align:center;padding:30px;color:rgba(247,242,232,.8)}

/* ===== INFOS PRATIQUES ===== */
.infos{background:var(--paper)}
.infos__grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
.infos__grid>*{min-width:0}
.hours{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s ease,border-color .28s ease}
.hours:hover{transform:translateY(-4px);border-color:rgba(195,154,78,.5);box-shadow:0 28px 56px -28px rgba(35,33,30,.6)}
.hours h3{font-size:1.7rem;margin-bottom:.6em}
.hours__row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line)}
.hours__row:last-child{border-bottom:0}
.hours__row.today{font-weight:700;color:var(--terracotta)}
.hours__row .d{text-transform:capitalize}
.hours__row .h{display:flex;flex-direction:column;align-items:flex-end;text-align:right;line-height:1.35}
.hours__open{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-weight:600;font-size:.92rem;padding:.5em 1em;border-radius:999px}
.hours__open.open{background:#e3efe0;color:#3f7a3a}
.hours__open.closed{background:#f6e3df;color:var(--terracotta-d)}
.hours__open .pt{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 1.6s infinite}
.coord{display:flex;flex-direction:column;gap:18px}
.coord__item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;min-width:0;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.coord__item:hover{transform:translateY(-3px);border-color:rgba(196,80,46,.4);box-shadow:0 18px 36px -22px rgba(35,33,30,.5)}
.coord__item>div{min-width:0}
.coord__item .ci-ic{flex:0 0 auto;width:44px;height:44px;border-radius:11px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;color:var(--terracotta);transition:background .3s ease,color .3s ease,transform .35s cubic-bezier(.2,.7,.2,1)}
.coord__item:hover .ci-ic{background:var(--terracotta);color:#fff;transform:rotate(-8deg) scale(1.08)}
.coord__item .ci-ic svg{width:22px;height:22px}
.coord__item h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;font-weight:700}
.coord__item .ci-v{font-size:1.12rem;font-weight:600;color:var(--ink);overflow-wrap:anywhere}
.coord__item .ci-v a:hover{color:var(--terracotta)}
.map{margin-top:14px;border-radius:14px;overflow:hidden;border:1px solid var(--line);height:230px}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}

/* ===== FOOTER ===== */
.footer{background:var(--ardoise);color:rgba(247,242,232,.78);padding:64px 0 28px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(247,242,232,.12)}
.footer__logo{width:148px;height:148px;border-radius:14px;border:1px solid rgba(247,242,232,.14);margin-bottom:18px;display:block}
.footer h4{font-family:var(--sans);color:var(--cream);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;font-weight:700}
.footer a:hover{color:var(--gold)}
.footer__links{display:flex;flex-direction:column;gap:9px}
.footer__social{display:flex;gap:12px;margin-top:14px}
.footer__social a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(247,242,232,.25);display:flex;align-items:center;justify-content:center;transition:.2s}
.footer__social a:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff;transform:translateY(-2px)}
.footer__social svg{width:20px;height:20px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding-top:22px;font-size:.85rem;color:rgba(247,242,232,.55)}
.footer__bottom a{text-decoration:underline;text-underline-offset:3px}
.gear{background:none;border:0;color:rgba(247,242,232,.3);cursor:pointer;font-size:1.1rem;padding:4px;transition:.2s}
.gear:hover{color:var(--gold);transform:rotate(45deg)}

/* ===== BANDEAU COOKIES ===== */
.cookie{position:fixed;right:18px;bottom:18px;z-index:115;max-width:336px;background:var(--ardoise);color:rgba(247,242,232,.9);border:1px solid rgba(247,242,232,.14);border-radius:14px;padding:16px 18px;box-shadow:0 24px 50px -20px rgba(0,0,0,.6);font-size:.85rem;line-height:1.5;transform:translateY(20px);opacity:0;pointer-events:none;transition:opacity .4s ease,transform .4s ease}
.cookie.show{opacity:1;transform:none;pointer-events:auto}
.cookie a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
.cookie__btns{margin-top:12px}
.cookie .btn{padding:.55em 1.2em;font-size:.85rem}
@media(max-width:480px){.cookie{left:12px;right:12px;bottom:12px;max-width:none}}

/* ===== LIGHTBOX ===== */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(20,18,16,.92);display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.show{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px -20px #000}
.lightbox__close{position:absolute;top:22px;right:28px;background:none;border:0;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}

/* ===== MODALES (admin / mentions) ===== */
.modal{position:fixed;inset:0;z-index:130;background:rgba(20,18,16,.62);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;backdrop-filter:blur(3px)}
.modal.show{display:flex}
.modal__box{background:var(--paper);border-radius:18px;max-width:760px;width:100%;box-shadow:0 40px 90px -30px #000;overflow:hidden;animation:pop .25s ease}
@keyframes pop{from{transform:translateY(16px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;background:var(--ardoise);color:var(--cream)}
.modal__head h3{color:#fff;font-size:1.5rem}
.modal__head .x{background:none;border:0;color:var(--cream);font-size:1.8rem;cursor:pointer;line-height:1}
.modal__body{padding:28px;max-height:72vh;overflow-y:auto}
.modal__body h4{font-family:var(--sans);font-weight:700;margin:18px 0 6px;color:var(--ink)}
.modal__body p,.modal__body li{font-size:.94rem;color:#4a443d;margin-bottom:6px}
.modal__body ul{padding-left:20px}

/* ===== ADMIN ===== */
.admin-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px;border-bottom:1px solid var(--line);padding-bottom:14px}
.admin-tab{background:var(--cream-2);border:0;border-radius:999px;padding:.55em 1.1em;font-family:var(--sans);font-weight:600;font-size:.88rem;cursor:pointer;color:var(--ink);transition:.2s}
.admin-tab.active{background:var(--terracotta);color:#fff}
.admin-panel{display:none}
.admin-panel.active{display:block}
.admin-field{margin-bottom:16px}
.admin-field label{display:block;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px}
.admin-field input,.admin-field textarea,.admin-field select{
  width:100%;padding:.7em .9em;border:1px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:.95rem;background:#fff;color:var(--ink)
}
.admin-field input:focus,.admin-field textarea:focus,.admin-field select:focus{outline:none;border-color:var(--terracotta)}
.admin-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-weight:600}
.switch input{display:none}
.switch .track{width:44px;height:24px;background:#cdc4b4;border-radius:999px;position:relative;transition:.2s}
.switch .track::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s}
.switch input:checked+.track{background:var(--terracotta)}
.switch input:checked+.track::after{transform:translateX(20px)}
.admin-actions{display:flex;gap:12px;align-items:center;margin-top:22px;flex-wrap:wrap}
.admin-msg{font-weight:600;font-size:.92rem}
.admin-msg.ok{color:#3f7a3a}
.admin-msg.err{color:var(--terracotta-d)}
.admin-hint{font-size:.85rem;color:var(--muted);margin-bottom:14px}
.pin-wrap{text-align:center;padding:20px 0}
.pin-wrap input{font-size:1.6rem;letter-spacing:.5em;text-align:center;max-width:220px;margin:14px auto 0}
/* éditeur de carte */
.mcat{border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:14px;background:#fff}
.mcat__head{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.mcat__head input{font-weight:700}
.mitem{display:grid;grid-template-columns:1.3fr 1.6fr .6fr auto;gap:8px;margin-bottom:8px;align-items:center}
.mitem input{padding:.5em .7em;font-size:.88rem}
.icon-btn{background:var(--cream-2);border:0;border-radius:8px;width:34px;height:34px;cursor:pointer;font-size:1.1rem;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.icon-btn:hover{background:var(--terracotta);color:#fff}
.icon-btn--sm{width:28px;height:28px;font-size:.95rem}
/* réservations admin */
.resa-list{display:flex;flex-direction:column;gap:10px}
.resa-card{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff;display:grid;grid-template-columns:1fr auto;gap:8px}
.resa-card.attente{border-left:4px solid var(--gold)}
.resa-card.confirmee{border-left:4px solid #3f7a3a}
.resa-card.refusee{border-left:4px solid var(--terracotta);opacity:.7}
.resa-card .rc-when{font-family:var(--serif);font-size:1.25rem;font-weight:600}
.resa-card .rc-meta{font-size:.9rem;color:var(--muted)}
.resa-card .rc-msg{font-size:.9rem;margin-top:4px;font-style:italic;color:#4a443d}
.resa-card .rc-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.resa-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;padding:.25em .7em;border-radius:999px}
.resa-badge.attente{background:#f3e8d6;color:#9a6a1e}
.resa-badge.confirmee{background:#e3efe0;color:#3f7a3a}
.resa-badge.refusee{background:#f6e3df;color:var(--terracotta-d)}
.resa-empty{text-align:center;color:var(--muted);padding:30px;font-style:italic}
/* stats admin */
.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.stat-card{background:var(--ardoise);color:var(--cream);border-radius:12px;padding:16px;text-align:center}
.stat-card b{display:block;font-family:var(--serif);font-size:1.9rem;color:var(--gold)}
.stat-card span{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;opacity:.8}
.bars{display:flex;align-items:flex-end;gap:4px;height:110px;margin-top:10px}
.bars .bar{flex:1;background:var(--terracotta);border-radius:3px 3px 0 0;min-height:2px;opacity:.85}
.bars-label{font-size:.78rem;color:var(--muted);margin:14px 0 4px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .about__grid,.reserve__grid,.infos__grid{grid-template-columns:1fr;gap:40px}
  .about__imgs{max-width:440px;margin:0 auto}
  .spec__grid{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .section{padding:72px 0}
  .nav__links{position:fixed;inset:0 0 auto auto;top:0;right:0;height:100vh;width:min(80vw,320px);background:var(--ardoise);flex-direction:column;justify-content:center;gap:26px;transform:translateX(100%);transition:transform .35s ease;box-shadow:-20px 0 50px -20px #000;padding:40px}
  .nav__links.open{transform:none}
  .nav__links a{font-size:1.2rem}
  .nav__burger{display:block;z-index:81}
  /* Indicateur de défilement conservé mais abaissé et compacté pour ne pas chevaucher le bouton « Découvrir la carte » */
  .hero__scroll{bottom:8px;font-size:.7rem;gap:5px}
  .hero__scroll::after{height:22px}
  .nav__brand img{height:87px}
  .nav.scrolled .nav__brand img{height:73px}
  .hero__bg img{object-position:center 55%}
  .menu__cats{grid-template-columns:1fr;gap:30px}
  .gallery__grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .gallery__grid .wide{grid-column:span 2}
  .form__row{grid-template-columns:1fr}
  .stat-cards{grid-template-columns:1fr 1fr}
  .mitem{grid-template-columns:1fr 1fr;}
  .admin-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .spec__grid,.footer__grid{grid-template-columns:1fr}
  .hero h1{font-size:clamp(2.4rem,12vw,3.2rem)}
  .container{padding:0 18px}
  .nav__tel span{display:none}
  .nav__tel{padding:.7em .8em}
  .nav__brand img{height:76px}
  .resa-card{grid-template-columns:1fr}
  .resa-card .rc-actions{flex-direction:row;align-items:center}
}
