/* =========================================================================
   CHEZ YVETTE — Bistrot parisien, 47-49 av. Trudaine 75009
   Refonte "Anvers + bascule nuit" (éditorial mode + section nocturne).
   Base ivoire, Bodoni Moda en display, Neue Haas en corps, Sharp Grotesk
   en surtitres. Orange = accent rare. Section "Le soir" sombre + grain.
   ========================================================================= */

/* ------------------------------ FONTS ------------------------------ */
@font-face{font-family:"Bodoni Moda";src:url("assets/fonts/BodoniModa-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Bodoni Moda";src:url("assets/fonts/BodoniModa-400-italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Bodoni Moda";src:url("assets/fonts/BodoniModa-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Bodoni Moda";src:url("assets/fonts/BodoniModa-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas";src:url("assets/fonts/NeueHaasDisplayLight.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas";src:url("assets/fonts/NeueHaasDisplayRoman.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas";src:url("assets/fonts/NeueHaasDisplayMediu.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Sharp Grotesk";src:url("assets/fonts/SharpGroteskSmBold20.otf") format("opentype");font-weight:600;font-style:normal;font-display:swap}

/* ------------------------------ TOKENS ------------------------------ */
:root{
  --ivoire:#EFE9DD;
  --ivoire-2:#F4EFE6;
  --paper:#F6F1E8;
  --ink:#17160F;
  --ink-2:#3a362b;
  --ink-soft:#6b6553;
  --orange:#D9410A;
  --orange-bright:#FF4903;
  --nuit:#141C15;
  --nuit-2:#1c2a1e;
  --vert:#223822;
  --cream:#EFE9DD;
  --cream-soft:rgba(239,233,221,.62);
  --line:rgba(23,22,15,.14);
  --line-2:rgba(23,22,15,.08);
  --line-cream:rgba(239,233,221,.16);

  --display:"Bodoni Moda",Georgia,"Times New Roman",serif;
  --body:"Neue Haas","Helvetica Neue",Arial,system-ui,sans-serif;
  --ui:"Sharp Grotesk","Helvetica Neue",Arial,sans-serif;

  --wrap:1200px;
  --measure:64ch;
  --pad:clamp(24px,5vw,52px);
  --gutter:clamp(48px,9vw,140px);
}

/* ------------------------------ RESET ------------------------------ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html.js body{scroll-behavior:smooth}
body{font-family:var(--body);font-weight:400;color:var(--ink);background:var(--ivoire);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
a,button,summary{-webkit-tap-highlight-color:transparent}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.02;letter-spacing:-.015em;text-wrap:balance}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px}
::selection{background:var(--orange);color:#fff}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--ivoire);padding:10px 16px;z-index:200;font-family:var(--ui)}
.skip:focus{left:8px;top:8px}
.container{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.ci dd a,.footer__nap a,.qf dd a,.faq__a a{overflow-wrap:anywhere}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ------------------------------ TYPO HELPERS ------------------------------ */
.eyebrow{font-family:var(--ui);text-transform:uppercase;letter-spacing:.26em;font-size:.68rem;color:var(--ink-soft);display:inline-block}
.eyebrow--orange{color:var(--orange)}
.eyebrow--cream{color:var(--cream-soft)}
.display-xl{font-family:var(--display);font-size:clamp(3.2rem,11vw,9rem);line-height:.92;letter-spacing:-.03em}
.h2{font-family:var(--display);font-size:clamp(2rem,5.5vw,4rem);line-height:1;letter-spacing:-.02em}
.h3{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.1rem)}
.lead{font-size:clamp(1.15rem,2.2vw,1.4rem);line-height:1.5;font-weight:300;max-width:34ch}
.italic{font-style:italic}
.accent{color:var(--orange)}

/* rule w/ orange tick */
.rule{position:relative;height:1px;background:var(--line);margin:0}
.rule::before{content:"";position:absolute;left:0;top:-1px;width:44px;height:3px;background:var(--orange)}

/* ------------------------------ BUTTONS / LINKS ------------------------------ */
.btn{display:inline-flex;align-items:center;gap:.7em;font-family:var(--ui);text-transform:uppercase;
  letter-spacing:.16em;font-size:.72rem;padding:.95em 1.6em;border:1px solid var(--ink);color:var(--ink);
  background:transparent;border-radius:1px;transition:background .3s,color .3s,border-color .3s;cursor:pointer}
.btn:hover{background:var(--ink);color:var(--ivoire)}
.btn--solid{background:var(--orange);border-color:var(--orange);color:#fff}
.btn--solid:hover{background:var(--orange-bright);border-color:var(--orange-bright);color:#fff}
.btn--cream{border-color:var(--cream-soft);color:var(--cream)}
.btn--cream:hover{background:var(--cream);color:var(--nuit)}
.link-u{display:inline-flex;align-items:center;min-height:44px;font-family:var(--ui);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;
  padding-bottom:3px;background-image:linear-gradient(var(--orange),var(--orange));
  background-size:0% 1.5px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .35s}
.link-u:hover{background-size:100% 1.5px}

/* ------------------------------ NAV ------------------------------ */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;padding:22px 0;transition:padding .35s,background .35s,box-shadow .35s;mix-blend-mode:normal}
.nav__in{display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav__brand{font-family:var(--display);font-size:1.3rem;letter-spacing:-.01em;display:flex;align-items:center;gap:11px}
.nav__brand img{height:26px;width:auto}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a:not(.btn){font-family:var(--ui);text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;color:var(--ink-2);transition:color .25s}
.nav__links a:not(.btn):hover{color:var(--orange)}
.nav.scrolled{background:rgba(239,233,221,.9);backdrop-filter:blur(10px);padding:13px 0;box-shadow:0 1px 0 var(--line)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:1.5px;background:var(--ink);transition:.3s}

/* ------------------------------ HERO ------------------------------ */
.hero{padding-block:clamp(130px,20vh,220px) clamp(60px,9vw,110px)}
.hero__grid{display:grid;gap:clamp(28px,5vw,56px);grid-template-columns:1fr;align-items:end}
.hero__head{max-width:min(540px,100%)}
.hero__logo{margin:0;line-height:0}
.hero__logo img{width:100%;max-width:520px;height:auto;display:block}
.hero__eyebrow{display:block;margin-bottom:clamp(18px,3vw,30px)}
.hero__title{font-size:clamp(3.4rem,13vw,10.5rem);line-height:.9;letter-spacing:-.035em}
.hero__title .l2{display:block;font-style:italic;color:var(--orange)}
.hero__baseline{font-weight:300;font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.5;color:var(--ink-2);max-width:32ch;margin-top:clamp(20px,3vw,32px)}
.hero__cta{margin-top:clamp(24px,3.5vw,38px);display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero__media{position:relative}
.hero__media img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.92) contrast(1.02)}
.hero__cap{font-family:var(--ui);text-transform:uppercase;letter-spacing:.2em;font-size:.6rem;color:var(--ink-soft);margin-top:12px;display:flex;justify-content:space-between}
@media(min-width:900px){
  .hero__grid{grid-template-columns:1.35fr .85fr}
  .hero__media{margin-bottom:8px}
}

/* quick-answer (GEO) */
.quickfacts{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(26px,4vw,40px) 0;margin-top:clamp(40px,6vw,72px)}
.quickfacts__grid{display:grid;gap:22px 40px;grid-template-columns:repeat(2,1fr)}
.qf{display:flex;flex-direction:column;gap:4px}
.qf dt{font-family:var(--ui);text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:var(--orange)}
.qf dd{font-size:.95rem;color:var(--ink-2)}
.qf dd a:hover{color:var(--orange)}
@media(min-width:760px){.quickfacts__grid{grid-template-columns:repeat(4,1fr)}}

/* ------------------------------ SECTION SHELL ------------------------------ */
.section{padding-block:var(--gutter)}
.section__head{display:grid;gap:18px;margin-bottom:clamp(36px,5vw,64px);max-width:var(--measure)}
.section__head .rule{margin-top:6px}

/* ------------------------------ HISTOIRE ------------------------------ */
.hist{display:grid;gap:clamp(30px,5vw,64px);grid-template-columns:1fr;align-items:center}
.hist__body p{max-width:52ch;margin-top:1.1em;color:var(--ink-2)}
.hist__body p.first{font-family:var(--display);font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.28;color:var(--ink);max-width:24ch;margin-top:0}
.hist__sign{font-family:var(--display);font-style:italic;font-size:1.3rem;color:var(--orange);margin-top:1.4em}
.hist__media figure{overflow:hidden}
.hist__media img{width:100%;aspect-ratio:3/4;object-fit:cover}
.hist__media figcaption{font-family:var(--ui);text-transform:uppercase;letter-spacing:.2em;font-size:.6rem;color:var(--ink-soft);margin-top:10px}
@media(min-width:820px){.hist{grid-template-columns:1.1fr .9fr}}

/* ------------------------------ CARTE (menu éditorial) ------------------------------ */
.menu{max-width:680px;margin-inline:auto}
.menu__intro{text-align:center;margin-bottom:clamp(30px,5vw,56px)}
.menu__intro .h2{margin:14px 0}
.menu__note{font-size:.9rem;color:var(--ink-soft);font-style:italic}
.menu__cat{margin-top:clamp(38px,5vw,58px)}
.menu__cat-h{display:flex;align-items:baseline;gap:16px;margin-bottom:20px}
.menu__cat-h h3{font-family:var(--ui);text-transform:uppercase;letter-spacing:.24em;font-size:.76rem;color:var(--ink);font-weight:600}
.menu__cat-h::after{content:"";flex:1;height:1px;background:var(--line);align-self:center}
.mi{display:grid;grid-template-columns:1fr auto;gap:6px 20px;align-items:baseline;padding:15px 0;border-top:1px solid var(--line-2)}
.mi:first-of-type{border-top:0}
.mi__name{font-family:var(--display);font-size:1.14rem;color:var(--ink);line-height:1.25}
.mi__en{display:block;font-family:var(--body);font-weight:300;font-style:italic;font-size:.8rem;color:var(--ink-soft);margin-top:3px;letter-spacing:.01em}
.mi__price{font-family:var(--body);font-weight:400;font-size:1rem;color:var(--ink-2);font-variant-numeric:tabular-nums}
.menu__ardoise{margin-top:clamp(38px,5vw,58px);text-align:center;padding:clamp(28px,4vw,44px);border:1px solid var(--line)}
.menu__ardoise h3{font-family:var(--display);font-style:italic;font-size:1.7rem;color:var(--orange)}
.menu__ardoise p{color:var(--ink-2);max-width:46ch;margin:12px auto 0}
.menu__cta{text-align:center;margin-top:clamp(40px,5vw,60px)}

/* ------------------------------ GALERIE (magazine bento) ------------------------------ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(8px,1.2vw,14px);grid-auto-flow:dense}
.gal figure{position:relative;overflow:hidden;grid-column:span 1;aspect-ratio:1/1;background:var(--ivoire-2);cursor:pointer}
.gal figure.tall{grid-row:span 2;aspect-ratio:3/4}
.gal figure.wide{grid-column:span 2;aspect-ratio:16/10}
.gal figure.big{grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1),filter .7s;filter:saturate(.9)}
.gal figure:hover img{transform:scale(1.05);filter:saturate(1.05)}
.gal figcaption{position:absolute;left:0;bottom:0;padding:12px 14px;font-family:var(--ui);text-transform:uppercase;
  letter-spacing:.18em;font-size:.6rem;color:#fff;background:linear-gradient(0deg,rgba(20,20,15,.72),transparent);
  width:100%;opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}
.gal figure:hover figcaption{opacity:1;transform:none}
@media(max-width:720px){
  .gal{grid-template-columns:repeat(2,1fr)}
  .gal figure,.gal figure.wide,.gal figure.big{grid-column:span 1;grid-row:auto;aspect-ratio:1/1}
  .gal figure.wide{grid-column:span 2;aspect-ratio:16/10}
  .gal figcaption{opacity:1;transform:none}
}

/* ------------------------------ LE SOIR (bascule nuit) ------------------------------ */
.soir{position:relative;background:var(--nuit);color:var(--cream);overflow:hidden}
.soir::before{content:"";position:absolute;inset:0;z-index:0;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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E")}
.soir__in{position:relative;z-index:1}
.soir__grid{display:grid;gap:clamp(30px,5vw,60px);grid-template-columns:1fr;align-items:center}
.soir h2{color:var(--cream)}
.soir h2 em{color:var(--orange-bright);font-style:italic}
.soir__body p{color:var(--cream-soft);max-width:46ch;margin-top:1.1em;font-weight:300}
.soir__media{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.soir__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/4;filter:saturate(.95) brightness(.94)}
.soir__media figure:first-child{margin-top:34px}
.soir__cta{margin-top:clamp(26px,3.5vw,40px)}
@media(min-width:860px){.soir__grid{grid-template-columns:.95fr 1.05fr}}

/* ------------------------------ GROUPES ------------------------------ */
.groupes{background:var(--ivoire-2)}
.groupes__grid{display:grid;gap:clamp(28px,5vw,60px);grid-template-columns:1fr;align-items:center}
.groupes__media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.groupes__body p{color:var(--ink-2);max-width:48ch;margin-top:1.1em}
.groupes__cta{margin-top:26px;display:flex;gap:16px;flex-wrap:wrap}
@media(min-width:820px){.groupes__grid{grid-template-columns:1fr 1fr}}

/* ------------------------------ FAQ ------------------------------ */
.faq__grid{display:grid;gap:0}
.faq__item{border-top:1px solid var(--line)}
.faq__item:last-child{border-bottom:1px solid var(--line)}
.faq__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:24px 4px;display:flex;justify-content:space-between;gap:24px;align-items:baseline;font-family:var(--display);font-size:clamp(1.15rem,2.2vw,1.5rem);color:var(--ink)}
.faq__q .plus{font-family:var(--body);font-weight:300;color:var(--orange);flex:0 0 auto;transition:transform .35s}
.faq__item[open] .plus{transform:rotate(45deg)}
.faq__a{padding:0 0 26px;max-width:60ch;color:var(--ink-2)}
.faq details{border:0}
summary{list-style:none}
summary::-webkit-details-marker{display:none}

/* ------------------------------ CONTACT ------------------------------ */
.contact__grid{display:grid;gap:clamp(30px,5vw,60px);grid-template-columns:1fr}
.contact__list{display:grid;gap:22px;margin-top:8px}
.ci{display:grid;gap:3px;border-top:1px solid var(--line-2);padding-top:18px}
.ci:first-child{border-top:0;padding-top:0}
.ci dt{font-family:var(--ui);text-transform:uppercase;letter-spacing:.2em;font-size:.6rem;color:var(--orange)}
.ci dd{font-family:var(--display);font-size:1.2rem;color:var(--ink)}
.ci dd a:hover{color:var(--orange)}
.ci dd small{display:block;font-family:var(--body);font-size:.82rem;color:var(--ink-soft);margin-top:3px;font-style:italic}
.map{margin-top:24px;width:100%;height:340px;border:1px solid var(--line);filter:grayscale(.3) contrast(1.05)}
.quartier{margin-top:clamp(28px,4vw,44px);max-width:56ch;color:var(--ink-soft);font-size:.92rem}
@media(min-width:820px){.contact__grid{grid-template-columns:1fr 1fr}}

/* ------------------------------ FOOTER ------------------------------ */
.footer{background:var(--nuit);color:var(--cream);padding:clamp(56px,8vw,90px) 0 34px}
.footer__grid{display:grid;gap:36px;grid-template-columns:1fr}
.footer__brand{font-family:var(--display);font-size:2rem}
.footer__brand span{font-style:italic;color:var(--orange-bright)}
.footer__nap{color:var(--cream-soft);margin-top:14px;font-size:.92rem;line-height:1.7}
.footer__nap a:hover{color:var(--cream)}
.footer__col h4{font-family:var(--ui);text-transform:uppercase;letter-spacing:.2em;font-size:.62rem;color:var(--cream-soft);font-weight:600;margin-bottom:14px}
.footer__col ul{display:grid;gap:9px}
.footer__col a{font-size:.92rem;color:var(--cream);opacity:.85;transition:opacity .25s,color .25s}
.footer__col a:hover{opacity:1;color:var(--orange-bright)}
.footer__meta{border-top:1px solid var(--line-cream);margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--ui);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;color:var(--cream-soft)}
.footer__meta a{color:var(--cream-soft)}
.footer__meta a:hover{color:var(--orange-bright)}
@media(min-width:760px){.footer__grid{grid-template-columns:2fr 1fr 1fr}}

/* ------------------------------ FLOATING CTA ------------------------------ */
.float{position:fixed;right:20px;bottom:20px;z-index:90;opacity:0;transform:translateY(16px);pointer-events:none;transition:opacity .35s,transform .35s}
.float.show{opacity:1;transform:none;pointer-events:auto}

/* Barre "Réserver" persistante — mobile uniquement */
.mrsv{display:none}
@media(max-width:820px){
  .float{display:none!important}
  .nav.open ~ .mrsv{display:none}
  .mrsv{position:fixed;left:0;right:0;bottom:0;z-index:96;display:flex;
    padding:10px clamp(14px,4vw,20px) calc(10px + env(safe-area-inset-bottom));
    background:rgba(239,233,221,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    border-top:1px solid var(--line)}
  .mrsv .btn{flex:1;justify-content:center;padding:1.1em 1.4em;font-size:.74rem}
  body{padding-bottom:78px}
  .nav__links a:not(.btn){padding:12px 0}
  .hero__logo img{max-width:min(440px,92%)}
  .soir__media{grid-template-columns:1fr;max-width:360px;margin-inline:auto}
  .soir__media figure:first-child{margin-top:0}
}

/* ------------------------------ LIGHTBOX ------------------------------ */
.lb{position:fixed;inset:0;z-index:300;background:rgba(20,20,15,.94);display:none;align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lb__close,.lb__nav{position:absolute;background:none;border:0;color:var(--cream);cursor:pointer;font-family:var(--body);font-size:2rem;padding:16px;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.lb__close{top:8px;right:12px}
.lb__nav{top:50%;transform:translateY(-50%);font-size:2.4rem}
.lb__nav--prev{left:12px}.lb__nav--next{right:12px}
.lb__cap{position:absolute;bottom:18px;left:0;width:100%;text-align:center;font-family:var(--ui);text-transform:uppercase;letter-spacing:.2em;font-size:.62rem;color:var(--cream-soft)}

/* ------------------------------ REVEAL ------------------------------ */
.js [data-rv]{opacity:0;transform:translateY(22px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.js [data-rv].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .js [data-rv]{opacity:1!important;transform:none!important}
  html.js body{scroll-behavior:auto}
  .gal img,.gal figcaption,.btn,.link-u,.nav,.faq__item .plus{transition:none!important}
}

/* ------------------------------ RESPONSIVE NAV ------------------------------ */
@media(max-width:820px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);background:var(--nuit);color:var(--cream);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:28px;padding:44px;transform:translateX(101%);
    transition:transform .4s cubic-bezier(.4,0,.1,1)}
  .nav__links a:not(.btn){color:var(--cream);font-size:.8rem}
  .nav.open .nav__links{transform:none}
  .nav__toggle{display:flex}
  .nav.open .nav__toggle span{background:var(--ink)}
  .nav.open .nav__toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav.open .nav__toggle span:nth-child(2){opacity:0}
  .nav.open .nav__toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}
