/* =========================================================
   OSCAR — bar à cocktails & tapas, Béziers
   DA sur-mesure : vert botanique + ivoire + laiton + argile
   ========================================================= */

:root{
  --forest:#16331f;       /* vert profond — fonds sombres */
  --forest-2:#1d3b1c;     /* vert logo */
  --green-3:#2c5236;      /* vert clair (dégradés/hover) */
  --sage:#93a48d;
  --cream:#f6efe2;        /* ivoire — fonds clairs */
  --cream-2:#efe5d3;
  --paper:#fbf7ee;
  --brass:#c6a05b;        /* or/laiton — accent */
  --brass-2:#b08a45;
  --brass-deep:#8a6c33;
  --clay:#b0653c;         /* terracotta — accent chaud */
  --ink:#13241a;          /* texte foncé (vert-noir) */
  --ink-soft:#3c4a40;

  --wrap:1180px;
  --pad:clamp(20px,5vw,40px);
  --r:18px;
  --r-lg:26px;

  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Outfit",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --shadow:0 18px 50px -24px rgba(10,26,16,.55);
  --shadow-sm:0 10px 28px -18px rgba(10,26,16,.5);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  font-size:clamp(15.5px,1.1vw,16.5px);line-height:1.65;font-weight:300;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.05;margin:0;letter-spacing:.005em}
p{margin:0 0 1em}
.wrap{width:min(100% - 2*var(--pad),var(--wrap));margin-inline:auto}
section[id]{scroll-margin-top:74px}
body{padding-bottom:74px} /* place pour le dock mobile */
.skip{position:absolute;left:-999px;top:0;background:var(--brass);color:var(--ink);padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}
.muted{color:var(--sage)}

/* ---------- typographic helpers ---------- */
.eyebrow{
  font-family:var(--sans);font-weight:500;font-size:.74rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--brass-deep);margin:0 0 .9rem;
}
.eyebrow--light{color:var(--brass)}
.on-green{color:var(--cream)}
.lead{font-size:1.16em;color:var(--ink-soft);font-weight:400}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--brass);--fg:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-weight:500;font-size:.92rem;letter-spacing:.02em;
  padding:.92em 1.5em;border-radius:999px;border:1px solid transparent;
  background:var(--bg);color:var(--fg);text-decoration:none;cursor:pointer;
  transition:transform .35s var(--ease),background .3s,color .3s,box-shadow .3s;
  will-change:transform;line-height:1;
}
.btn:hover{transform:translateY(-2px)}
.btn--brass{background:linear-gradient(135deg,var(--brass),var(--brass-2));color:#231a08;box-shadow:0 12px 28px -14px rgba(176,138,69,.8)}
.btn--brass:hover{box-shadow:0 16px 34px -12px rgba(176,138,69,.95)}
.btn--outline{background:transparent;border-color:rgba(246,239,226,.55);color:var(--cream)}
.btn--outline:hover{background:rgba(246,239,226,.1);border-color:var(--cream)}
.btn--outline-light{background:transparent;border-color:var(--brass);color:var(--brass)}
.btn--outline-light:hover{background:var(--brass);color:#231a08}
.btn--ghost{background:rgba(20,36,26,.06);color:var(--ink);border-color:rgba(20,36,26,.16)}
.btn--ghost:hover{background:rgba(20,36,26,.1)}
.btn--full{width:100%}
.btn--sm{padding:.7em 1.2em;font-size:.84rem}

.link-underline{
  display:inline-block;font-weight:500;color:var(--brass-deep);text-decoration:none;
  letter-spacing:.02em;padding-bottom:3px;border-bottom:1px solid currentColor;
  transition:color .3s,letter-spacing .3s
}
.link-underline:hover{color:var(--clay);letter-spacing:.05em}

.ico{width:1.15em;height:1.15em;flex:none;fill:none;color:var(--brass)}

/* =========================================================
   HEADER
   ========================================================= */
.hdr{position:fixed;inset:0 0 auto;z-index:90;transition:background .4s var(--ease),box-shadow .4s,backdrop-filter .4s}
.hdr__in{display:flex;align-items:center;gap:1rem;width:min(100% - 2*var(--pad),1320px);margin-inline:auto;padding:.85rem 0}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;margin-right:auto}
.brand__seal{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--brass);object-fit:cover;background:var(--forest-2)}
.brand__wm{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--cream);letter-spacing:.14em;text-transform:uppercase;transition:color .4s}
.nav{display:none}
.hdr__cta{display:none}
.burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid rgba(246,239,226,.4);border-radius:12px;background:rgba(22,51,31,.25);backdrop-filter:blur(6px);cursor:pointer;transition:border-color .3s}
.burger span{display:block;height:1.6px;width:20px;margin-inline:auto;background:var(--cream);transition:.35s var(--ease)}
/* scrolled state */
.hdr.is-stuck{background:rgba(246,239,226,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(20,36,26,.08),0 12px 30px -22px rgba(10,26,16,.5)}
.hdr.is-stuck .brand__wm{color:var(--forest)}
.hdr.is-stuck .burger{border-color:rgba(20,36,26,.2);background:rgba(20,36,26,.04)}
.hdr.is-stuck .burger span{background:var(--forest)}

/* ---------- drawer ---------- */
.drawer{position:fixed;inset:0;z-index:120;visibility:hidden;pointer-events:none}
.drawer::before{content:"";position:absolute;inset:0;background:rgba(11,24,15,.55);opacity:0;transition:opacity .4s}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(86%,360px);background:var(--forest);
  padding:1.4rem 1.6rem;display:flex;flex-direction:column;transform:translateX(102%);transition:transform .45s var(--ease);
  box-shadow:-30px 0 60px -30px rgba(0,0,0,.6)}
.drawer.open{visibility:visible;pointer-events:auto}
.drawer.open::before{opacity:1}
.drawer.open .drawer__panel{transform:none}
.drawer__close{align-self:flex-end;font-size:2rem;line-height:1;background:none;border:none;color:var(--cream);cursor:pointer;width:44px;height:44px}
.drawer__seal{width:64px;height:64px;border-radius:50%;border:1.5px solid var(--brass);margin:.2rem 0 1.4rem}
.drawer__nav{display:flex;flex-direction:column;gap:.2rem}
.drawer__nav a{font-family:var(--serif);font-size:1.85rem;color:var(--cream);text-decoration:none;padding:.35rem 0;border-bottom:1px solid rgba(246,239,226,.1);transition:color .3s,padding-left .3s}
.drawer__nav a:hover{color:var(--brass);padding-left:.4rem}
.drawer__foot{margin-top:auto;display:flex;flex-direction:column;gap:.6rem;padding-top:1.4rem}
.drawer__foot p{color:var(--sage);font-size:.82rem;text-align:center;margin:.2rem 0 0;letter-spacing:.04em}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:6.5rem 0 4rem}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(72% 52% at 50% 50%,rgba(10,22,14,.52),transparent 72%),
    linear-gradient(180deg,rgba(13,28,18,.6) 0%,rgba(13,28,18,.38) 40%,rgba(13,28,18,.58) 74%,rgba(11,24,15,.93) 100%)}
.hero__content{position:relative;z-index:2;width:min(100% - 2*var(--pad),760px);color:var(--cream)}
.hero__seal{width:84px;height:84px;border-radius:50%;border:1.5px solid var(--brass);margin:0 auto 1.4rem;box-shadow:0 10px 30px -12px rgba(0,0,0,.6);animation:floatSeal 7s ease-in-out infinite}
@keyframes floatSeal{50%{transform:translateY(-7px)}}
.hero__title{
  font-size:clamp(3.4rem,15.5vw,5.7rem);font-weight:600;letter-spacing:.01em;line-height:.98;
  margin:0 0 1.1rem;text-shadow:0 14px 44px rgba(0,0,0,.55);
  display:flex;flex-direction:column;align-items:center;gap:.02em}
.hero__title .dot{display:block;color:var(--brass);font-style:italic;font-size:.42em;line-height:.4;opacity:.92}
.hero__title .hw{display:block}
.hero__sub{font-size:clamp(1.02rem,2.5vw,1.22rem);max-width:33ch;margin:0 auto 1.8rem;color:rgba(246,239,226,.92);font-weight:300}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
.hero__meta{margin:1.6rem 0 0;font-size:.84rem;letter-spacing:.06em;color:rgba(246,239,226,.82);display:inline-flex;align-items:center;gap:.5em;flex-wrap:wrap;justify-content:center}
.hero__meta a{color:var(--brass);text-decoration:none;font-weight:500}
.hero__scroll{position:absolute;left:50%;bottom:1.3rem;transform:translateX(-50%);z-index:3;color:var(--cream);
  width:42px;height:42px;border:1px solid rgba(246,239,226,.4);border-radius:50%;display:grid;place-items:center;text-decoration:none;
  animation:bob 2.4s ease-in-out infinite;transition:background .3s}
.hero__scroll:hover{background:rgba(246,239,226,.14)}
@keyframes bob{50%{transform:translate(-50%,6px)}}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{background:var(--forest-2);color:var(--cream);overflow:hidden;border-block:1px solid rgba(198,160,91,.2);padding:.85rem 0}
.marquee__row{display:flex;align-items:center;gap:2rem;width:max-content;animation:slide 28s linear infinite;font-family:var(--serif);font-size:1.35rem;font-style:italic;color:var(--cream)}
.marquee__row span{white-space:nowrap;opacity:.92}
.marquee .mq{width:18px;height:18px;color:var(--brass);fill:none;flex:none}
@keyframes slide{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__row{animation:none}}

/* =========================================================
   L'ESPRIT
   ========================================================= */
.esprit{padding:clamp(4rem,9vw,7rem) 0;background:
  radial-gradient(80% 60% at 100% 0,rgba(147,164,141,.14),transparent 60%),var(--cream)}
.esprit__grid{display:grid;gap:clamp(2rem,5vw,4rem)}
.esprit__media{position:relative}
.frame{overflow:hidden;border-radius:var(--r-lg);box-shadow:var(--shadow)}
.frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.frame:hover img{transform:scale(1.05)}
.frame--arch{border-top-left-radius:160px;border-top-right-radius:160px;aspect-ratio:4/4.6;border:1px solid rgba(198,160,91,.35)}
.frame--small{position:absolute;width:46%;right:-6px;bottom:-26px;aspect-ratio:1;border:5px solid var(--cream);border-radius:var(--r);box-shadow:var(--shadow)}
.esprit__txt h2{font-size:clamp(2rem,5.4vw,3.1rem);margin:.2rem 0 1rem;color:var(--forest)}
.virtues{list-style:none;padding:0;margin:1.8rem 0;display:flex;flex-direction:column;gap:1rem}
.virtues li{display:flex;gap:.9rem;align-items:flex-start}
.virtues .ico{margin-top:.25em;width:1.4em;height:1.4em}
.virtues b{font-weight:500;color:var(--forest);font-size:1.05rem}
.virtues span{font-size:.95rem;color:var(--ink-soft);line-height:1.5}

/* =========================================================
   LA CARTE  (fond vert)
   ========================================================= */
.carte{position:relative;background:
  radial-gradient(90% 70% at 10% -10%,rgba(44,82,54,.6),transparent 55%),
  linear-gradient(180deg,var(--forest) 0%,var(--forest-2) 100%);
  color:var(--cream);padding:clamp(3rem,7vw,5.5rem) 0 clamp(4rem,9vw,7rem)}
.ornament{display:flex;justify-content:center;padding:1.2rem 0 .6rem}
.ornament .sprig{width:160px;height:54px;color:var(--brass);fill:none}
.section-head{text-align:center;max-width:680px}
.section-head h2{font-size:clamp(2.1rem,6vw,3.4rem);color:var(--forest)}
.section-head h2.on-green{color:var(--cream)}
.section-head__sub{margin:.8rem auto 0;max-width:50ch;color:var(--ink-soft)}
.carte .section-head__sub{color:rgba(246,239,226,.78)}

.carte__grid{display:grid;gap:1.4rem;margin-top:clamp(2rem,5vw,3.2rem)}
.dish{background:rgba(246,239,226,.05);border:1px solid rgba(198,160,91,.22);border-radius:var(--r-lg);overflow:hidden;
  transition:transform .5s var(--ease),border-color .4s,background .4s}
.dish:hover{transform:translateY(-6px);border-color:rgba(198,160,91,.6);background:rgba(246,239,226,.08)}
.dish__img{aspect-ratio:4/3.2;overflow:hidden}
.dish__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.dish:hover .dish__img img{transform:scale(1.06)}
.dish__body{padding:1.3rem 1.4rem 1.6rem}
.dish__body h3{font-size:1.6rem;color:var(--cream);margin-bottom:.4rem}
.dish__body p{color:rgba(246,239,226,.78);font-size:.95rem;margin:0}

.signatures{display:grid;gap:1.4rem;margin-top:2.4rem}
.sig{background:rgba(13,28,18,.4);border:1px solid rgba(198,160,91,.22);border-radius:var(--r-lg);padding:1.6rem 1.7rem}
.sig__head{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.9rem;border-bottom:1px solid rgba(198,160,91,.25)}
.sig__head h3{font-size:1.5rem;color:var(--brass)}
.sig__head .ico{width:1.3em;height:1.3em}
.sig ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}
.sig li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;border-bottom:1px dotted rgba(246,239,226,.16);padding-bottom:.55rem}
.sig li:last-child{border-bottom:none;padding-bottom:0}
.sig li span{font-family:var(--serif);font-size:1.22rem;color:var(--cream)}
.sig li i{font-size:.82rem;color:var(--sage);text-align:right;font-style:italic;flex:none;max-width:50%}
.signatures__note{grid-column:1/-1;text-align:center;color:var(--sage);font-style:italic;font-family:var(--serif);font-size:1.1rem;margin:.4rem 0 0}
.carte__cta{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:2.6rem}

/* =========================================================
   GALERIE
   ========================================================= */
.galerie{padding:clamp(4rem,9vw,7rem) 0;background:var(--paper)}
.gal{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;margin-top:clamp(2rem,5vw,3rem)}
.gal__item{position:relative;border:none;padding:0;margin:0;cursor:pointer;border-radius:14px;overflow:hidden;background:var(--cream-2);aspect-ratio:1;box-shadow:var(--shadow-sm)}
.gal__item img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.gal__item::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(13,28,18,.32),transparent 55%);opacity:0;transition:opacity .4s}
.gal__item:hover img{transform:scale(1.07)}
.gal__item:hover::after{opacity:1}
.gal--tall{grid-row:span 2;aspect-ratio:auto}
.gal--wide{grid-column:span 2;aspect-ratio:16/10}

/* =========================================================
   AVIS (fond vert)
   ========================================================= */
.avis{position:relative;background:linear-gradient(180deg,var(--forest-2),var(--forest));color:var(--cream);padding:clamp(3rem,7vw,5rem) 0 clamp(4rem,9vw,6.5rem)}
.ornament--light .sprig{color:var(--brass)}
.avis__grid{display:grid;gap:1.2rem;margin-top:clamp(2rem,5vw,3rem)}
.avis__card{margin:0;background:rgba(246,239,226,.05);border:1px solid rgba(198,160,91,.22);border-radius:var(--r-lg);padding:1.8rem}
.stars{color:var(--brass);letter-spacing:.18em;margin-bottom:.8rem;font-size:1rem}
.avis__card p{font-family:var(--serif);font-style:italic;font-size:1.3rem;line-height:1.45;color:var(--cream);margin:0 0 1rem}
.avis__card cite{font-style:normal;font-weight:500;color:var(--brass);letter-spacing:.04em;font-size:.92rem}
.avis__note{text-align:center;color:var(--sage);font-size:.8rem;margin-top:1.6rem;font-style:italic}

/* =========================================================
   INFOS
   ========================================================= */
.infos{padding:clamp(4rem,9vw,7rem) 0;background:var(--cream)}
.infos__grid{display:grid;gap:clamp(1.6rem,4vw,3rem);align-items:stretch}
.infos__txt h2{font-size:clamp(2rem,5.4vw,3rem);color:var(--forest);margin:.2rem 0 1.4rem}
.infos__list{list-style:none;padding:0;margin:0 0 1.8rem;display:flex;flex-direction:column;gap:1.1rem}
.infos__list li{display:flex;gap:.9rem;align-items:flex-start}
.infos__list .ico{margin-top:.2em;width:1.4em;height:1.4em}
.infos__list b{font-weight:500;color:var(--forest)}
.infos__list a{color:var(--clay);text-decoration:none;font-weight:500}
.infos__list a:hover{text-decoration:underline}
.infos__cta{display:flex;flex-wrap:wrap;gap:.7rem}
.infos__map{position:relative;display:block;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(198,160,91,.4);box-shadow:var(--shadow);min-height:300px;background:var(--cream-2);text-decoration:none}
.infos__map img{width:100%;height:100%;min-height:300px;object-fit:cover;display:block;transition:transform 1s var(--ease),filter .4s;filter:saturate(.96)}
.infos__map:hover img{transform:scale(1.04)}
.infos__pin{position:absolute;left:14px;top:14px;display:inline-flex;align-items:center;gap:.4em;background:rgba(22,51,31,.94);color:var(--cream);font-size:.82rem;font-weight:500;letter-spacing:.02em;padding:.55em 1em;border-radius:999px;border:1px solid rgba(198,160,91,.45)}
.infos__pin .ico{width:1em;height:1em}
.infos__maplink{position:absolute;right:14px;bottom:14px;background:linear-gradient(135deg,var(--brass),var(--brass-2));color:#231a08;font-size:.82rem;font-weight:600;letter-spacing:.02em;padding:.6em 1.1em;border-radius:999px;box-shadow:0 8px 20px -10px rgba(0,0,0,.5);transition:transform .3s}
.infos__map:hover .infos__maplink{transform:translateY(-2px)}
.infos__attrib{position:absolute;left:0;bottom:0;background:rgba(251,247,238,.78);color:#46514a;font-size:.62rem;letter-spacing:.01em;padding:.18em .5em;border-radius:0 8px 0 0}

/* =========================================================
   RESERVER
   ========================================================= */
.reserver{position:relative;color:var(--cream);padding:clamp(4rem,9vw,7rem) 0;
  background:linear-gradient(180deg,rgba(13,28,18,.8),rgba(13,28,18,.88)),url("../img/champagne.jpg") center/cover scroll}
.reserver__in{display:grid;gap:clamp(2rem,5vw,3.4rem);position:relative;z-index:1}
.reserver__seal{width:74px;height:74px;border-radius:50%;border:1.5px solid var(--brass);margin-bottom:1rem}
.reserver__head h2{font-size:clamp(2.1rem,6vw,3.2rem)}
.reserver__sub{color:rgba(246,239,226,.85);max-width:42ch;margin-bottom:1.6rem}
.reserver__quick{display:flex;flex-wrap:wrap;gap:.8rem}
.rform{background:rgba(246,239,226,.97);color:var(--ink);border-radius:var(--r-lg);padding:clamp(1.4rem,4vw,2.2rem);box-shadow:var(--shadow)}
.rform__row{display:grid;gap:1rem;margin-bottom:1rem}
.rform label{display:flex;flex-direction:column;gap:.4rem;font-size:.82rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
.rform input,.rform select,.rform textarea{
  font-family:var(--sans);font-size:1rem;font-weight:300;color:var(--ink);
  padding:.8em .9em;border:1px solid rgba(20,36,26,.2);border-radius:12px;background:#fff;width:100%;transition:border-color .3s,box-shadow .3s}
.rform input:focus,.rform select:focus,.rform textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(198,160,91,.2)}
.rform textarea{resize:vertical;margin-bottom:1.1rem}
.rform .btn--full{margin-top:.3rem}
.rform__hint{font-size:.78rem;color:var(--sage);text-align:center;margin:.9rem 0 0;font-style:italic;text-transform:none;letter-spacing:0}
.rform__hint.ok{color:var(--green-3);font-weight:500;font-style:normal}

/* =========================================================
   FOOTER
   ========================================================= */
.ft{background:var(--forest);color:var(--cream);padding:clamp(3rem,6vw,4.5rem) 0 0}
.ft__in{display:grid;gap:2rem}
.ft__brand img{width:72px;height:72px;border-radius:50%;border:1.5px solid var(--brass)}
.ft__tag{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--brass);margin:.7rem 0 .2rem}
.ft__small{color:var(--sage);font-size:.85rem;letter-spacing:.04em;margin:0}
.ft__col h4{font-family:var(--sans);font-weight:500;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass);margin:0 0 .8rem}
.ft__col p{color:rgba(246,239,226,.82);font-size:.95rem;margin:0 0 .6rem;line-height:1.6}
.ft__col a{color:rgba(246,239,226,.82);text-decoration:none}
.ft__col a:hover{color:var(--brass)}
.ft__bar{margin-top:2.6rem;border-top:1px solid rgba(246,239,226,.12);padding:1.3rem var(--pad);display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;justify-content:space-between;align-items:center}
.ft__bar p{margin:0;font-size:.8rem;color:var(--sage)}
.ft__credit a{color:var(--brass);text-decoration:none}

/* =========================================================
   DOCK mobile
   ========================================================= */
.dock{position:fixed;left:0;right:0;bottom:0;z-index:80;display:flex;gap:.5rem;padding:.55rem .7rem calc(.55rem + env(safe-area-inset-bottom));
  background:rgba(13,28,18,.92);backdrop-filter:blur(12px);border-top:1px solid rgba(198,160,91,.25)}
.dock__btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--cream);
  font-size:.72rem;font-weight:500;letter-spacing:.03em;padding:.45rem .3rem;border-radius:12px;transition:background .3s}
.dock__btn:hover{background:rgba(246,239,226,.08)}
.dock__ic{font-size:1.05rem;line-height:1;color:var(--brass)}
.dock__btn--accent{background:linear-gradient(135deg,var(--brass),var(--brass-2));color:#231a08}
.dock__btn--accent .dock__ic{color:#231a08}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(11,22,14,.94);display:none;align-items:center;justify-content:center;padding:4vw}
.lightbox.open{display:flex;animation:lbIn .3s var(--ease)}
@keyframes lbIn{from{opacity:0}}
.lightbox__fig{margin:0;max-width:92vw;max-height:88vh;text-align:center}
.lightbox__fig img{max-width:92vw;max-height:78vh;width:auto;border-radius:12px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8)}
.lightbox__fig figcaption{color:var(--cream);font-family:var(--serif);font-style:italic;font-size:1.1rem;margin-top:1rem}
.lightbox__close{position:absolute;top:1rem;right:1.2rem;font-size:2.4rem;line-height:1;background:none;border:none;color:var(--cream);cursor:pointer;width:48px;height:48px}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:1px solid rgba(246,239,226,.35);background:rgba(246,239,226,.06);color:var(--cream);font-size:1.8rem;cursor:pointer;transition:background .3s}
.lightbox__nav:hover{background:rgba(246,239,226,.16)}
.lightbox__prev{left:2vw}.lightbox__next{right:2vw}

/* =========================================================
   REVEAL  (gated by html.js — voir note lea_charee)
   ========================================================= */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;transition:none}}

/* =========================================================
   RESPONSIVE  — ≥620 / ≥900 / ≥1080 (desktop tempéré)
   ========================================================= */
@media (min-width:620px){
  .gal{grid-template-columns:repeat(3,1fr);gap:.8rem}
  .rform__row{grid-template-columns:1fr 1fr}
  .ft__in{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .signatures{grid-template-columns:1fr 1fr}
}
@media (min-width:900px){
  .dock{display:none}
  body{padding-bottom:0 !important}
  .nav{display:flex;gap:2rem;align-items:center}
  .nav a{position:relative;text-decoration:none;color:var(--cream);font-size:.92rem;font-weight:400;letter-spacing:.04em;transition:color .3s;padding:.2rem 0}
  .nav a::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:0;background:var(--brass);transition:width .35s var(--ease)}
  .nav a:hover{color:var(--brass)}
  .nav a:hover::after{width:100%}
  .hdr.is-stuck .nav a{color:var(--forest)}
  .hdr.is-stuck .nav a:hover{color:var(--brass-deep)}
  .hdr__cta{display:inline-flex}
  .burger{display:none}
  .carte__grid{grid-template-columns:repeat(3,1fr)}
  .avis__grid{grid-template-columns:repeat(3,1fr)}
  .esprit__grid{grid-template-columns:1.02fr 1.1fr;align-items:center}
  .infos__grid{grid-template-columns:1fr 1.1fr}
  .reserver__in{grid-template-columns:1fr 1.05fr;align-items:center}
  .reserver__head{position:sticky}
}
/* desktop tempéré — ne pas surdimensionner (retour Nicolas) */
@media (min-width:1080px){
  .hero{min-height:90svh;padding:7rem 0 4.5rem}
  .hero__title{font-size:clamp(4rem,5.2vw,5.2rem)}
  .hero__seal{width:78px;height:78px}
  .hero__sub{font-size:1.16rem}
  .hero__bg img{object-position:center 42%}
  .frame--arch{aspect-ratio:4/4.4}
  .gal{grid-template-columns:repeat(4,1fr)}
  .gal--wide{grid-column:span 2}
}
@media (min-width:1080px){
  .reserver{background-attachment:fixed}
}

/* =========================================================
   MODE CAPTURE  (?cap) — captures pleine page headless fiables
   ========================================================= */
html.cap .reveal{opacity:1 !important;transform:none !important;transition:none !important}
html.cap .hero{min-height:760px}
html.cap *{animation:none !important}
html.cap .hero__seal{animation:none !important}
