/* ░░░░░░░░░░ COMME IL FAUT ░░░░░░░░░░ */
:root{
  --ink:#15120d;
  --ink-2:#241f17;
  --ivory:#f7f2e9;
  --cream:#efe7d7;
  --paper:#fbf8f1;
  --gold:#b08d4e;
  --gold-2:#c9a86a;
  --muted:#7a6f5d;
  --line:rgba(21,18,13,.12);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost', system-ui, sans-serif;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip;
}
#navSentinel{position:absolute;top:0;left:0;width:1px;height:64px;pointer-events:none;opacity:0}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* ── typography ── */
.kicker{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;font-weight:400;color:var(--gold);margin-bottom:1rem}
.kicker--light{color:var(--gold-2)}
.h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.1rem,4.6vw,3.7rem);line-height:1.04;letter-spacing:.01em;color:var(--ink)}
.h2--light{color:var(--ivory)}
.section{padding:clamp(74px,11vw,154px) 0}
.section--alt{background:var(--ivory)}
.section__head{max-width:660px;margin:0 auto clamp(42px,6vw,74px);text-align:center}
.section__sub{color:var(--muted);font-size:1.06rem;margin-top:1.2rem}

/* ── ornament (line · diamond · line) ── */
.ornament{display:flex;align-items:center;justify-content:center;gap:14px;margin:1.2rem auto;width:fit-content}
.ornament span{display:block;width:46px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.ornament span:last-child{background:linear-gradient(90deg,var(--gold),transparent)}
.ornament i{width:6px;height:6px;border:1px solid var(--gold);transform:rotate(45deg);display:block}
.ornament--light span{background:linear-gradient(90deg,transparent,var(--gold-2))}
.ornament--light span:last-child{background:linear-gradient(90deg,var(--gold-2),transparent)}
.ornament--light i{border-color:var(--gold-2)}

/* ── buttons / links ── */
.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;font-weight:400;padding:1.1em 2.3em;border:1px solid transparent;cursor:pointer;transition:all .4s var(--ease);white-space:nowrap}
.btn--solid{background:var(--gold);color:#fff}
.btn--solid:hover{background:var(--ink);color:var(--ivory)}
.btn--outline{border-color:rgba(247,242,233,.5);color:var(--ivory)}
.btn--outline:hover{background:var(--ivory);color:var(--ink);border-color:var(--ivory)}
.btn--outline.btn--dark{border-color:var(--line);color:var(--ink)}
.btn--outline.btn--dark:hover{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.btn--ghost{border-color:rgba(247,242,233,.38);color:var(--ivory);font-size:.66rem;padding:.85em 1.6em}
.btn--ghost.btn--dark{border-color:var(--line);color:var(--ink)}
.btn--ghost.btn--dark:hover{background:var(--cream)}
.link-underline{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ivory);position:relative;padding:1.1em 0}
.link-underline::after{content:"";position:absolute;left:0;bottom:.7em;width:100%;height:1px;background:var(--gold-2);transform:scaleX(.6);transform-origin:left;transition:transform .4s var(--ease)}
.link-underline:hover::after{transform:scaleX(1)}

/* ── reveal anim ── */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ░░ PRELOADER ░░ */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;transition:opacity .9s var(--ease),visibility .9s var(--ease)}
.preloader.done{opacity:0;visibility:hidden}
.pl__inner{text-align:center;opacity:0;transform:translateY(12px);animation:plIn 1.1s var(--ease) .15s forwards}
.pl__kicker{font-family:var(--serif);font-style:italic;font-size:1.05rem;letter-spacing:.14em;color:var(--gold-2);margin-bottom:1rem}
.pl__name{font-family:var(--serif);font-weight:500;color:var(--ivory);font-size:clamp(2.6rem,6vw,4.6rem);line-height:1;letter-spacing:.04em}
.pl__sub{font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(247,242,233,.55);margin-top:1.1rem}
.pl__bar{width:170px;height:1px;background:rgba(201,168,106,.22);margin:2.2rem auto 0;overflow:hidden;position:relative}
.pl__bar::after{content:"";position:absolute;left:0;top:0;height:100%;width:100%;background:linear-gradient(90deg,transparent,var(--gold-2),transparent);transform:translateX(-100%);animation:plBar 1.5s var(--ease) infinite}
@keyframes plIn{to{opacity:1;transform:none}}
@keyframes plBar{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.pl__orn{margin:1.4rem auto .2rem}
body.loading{overflow:hidden}

/* ░░ NAV ░░ */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .5s var(--ease),box-shadow .5s var(--ease)}
.nav__inner{max-width:1360px;margin:0 auto;padding:22px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;transition:padding .5s var(--ease)}
.nav__brand{display:flex;flex-direction:column;line-height:1}
.nav__brand-name{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.02em;color:#fff;transition:color .5s}
.nav__brand-sub{font-size:.56rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold-2);margin-top:5px}
.nav__links{display:flex;gap:30px}
.nav__links a{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.82);font-weight:300;position:relative;padding:4px 0;transition:color .35s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold-2);transition:width .35s var(--ease)}
.nav__links a:hover{color:#fff}
.nav__links a:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:20px}
.lang{display:flex;align-items:center;gap:6px;font-size:.72rem;letter-spacing:.12em}
.lang button{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;padding:2px;transition:color .3s}
.lang button.is-active{color:var(--gold-2)}
.lang span{color:rgba(255,255,255,.35)}
.nav__reserve{color:#fff}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:1.5px;background:#fff;transition:transform .35s var(--ease),opacity .25s var(--ease),background .3s}
.nav__burger.is-open span{background:var(--ivory)}
.nav__burger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav.scrolled .nav__burger.is-open span{background:var(--ivory)}
.nav__drawer-cta{display:none}
body.nav-open{overflow:hidden}
.nav.scrolled{background:var(--paper);box-shadow:0 1px 0 var(--line)}
.nav.scrolled .nav__inner{padding:14px 32px}
.nav.scrolled .nav__brand-name{color:var(--ink)}
.nav.scrolled .nav__links a{color:var(--ink-2)}
.nav.scrolled .lang button{color:var(--muted)}
.nav.scrolled .lang button.is-active{color:var(--gold)}
.nav.scrolled .lang span{color:var(--line)}
.nav.scrolled .nav__reserve{color:var(--ink);border-color:var(--line)}
.nav.scrolled .nav__reserve:hover{background:var(--ink);color:var(--ivory)}
.nav.scrolled .nav__burger span{background:var(--ink)}

/* ░░ HERO ░░ */
.hero{position:relative;height:100vh;min-height:660px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:#0c0a07}
.hero__bg{position:absolute;inset:-6% 0;background:url('../img/terrace/terrace-2.jpg') center 42%/cover no-repeat;filter:brightness(.66) contrast(1.02) saturate(.96);will-change:transform;transform:scale(1.05)}
.hero__veil{position:absolute;inset:0;background:
  radial-gradient(125% 95% at 50% 40%,rgba(12,10,7,.12) 0%,rgba(12,10,7,.5) 66%,rgba(12,10,7,.84) 100%),
  linear-gradient(180deg,rgba(12,10,7,.55) 0%,rgba(12,10,7,.16) 32%,rgba(12,10,7,.6) 100%)}
.hero__frame{position:absolute;inset:22px;border:1px solid rgba(201,168,106,.34);pointer-events:none;z-index:2}
.hero__content{position:relative;z-index:3;color:#fff;padding:0 28px;max-width:880px}
.hero__kicker{font-family:var(--serif);font-style:italic;font-size:1.25rem;letter-spacing:.12em;color:var(--gold-2)}
.hero__title{font-family:var(--serif);font-weight:500;color:#fff;font-size:clamp(3.2rem,8.4vw,7rem);line-height:1;letter-spacing:.02em;margin:.18em 0 .28em;text-shadow:0 2px 50px rgba(0,0,0,.4)}
.hero__sub{font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:1.6rem}
.hero__tag{font-family:var(--serif);font-size:clamp(1.25rem,2.1vw,1.6rem);font-weight:300;color:rgba(255,255,255,.9);max-width:620px;margin:0 auto 2.6rem;line-height:1.5}
.hero__cta{display:flex;gap:30px;justify-content:center;align-items:center;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;width:24px;height:40px;border:1px solid rgba(255,255,255,.5);border-radius:14px;display:flex;justify-content:center}
.hero__scroll span{width:3px;height:8px;background:var(--gold-2);border-radius:2px;margin-top:7px;animation:scroll 1.8s var(--ease) infinite}
@keyframes scroll{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(10px)}}

/* ░░ ABOUT ░░ */
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.about__text p{color:var(--muted);font-size:1.08rem;margin-top:1.3rem;max-width:30em}
.about__facts{display:flex;gap:38px;margin-top:2.6rem;flex-wrap:wrap}
.about__facts .num{font-family:var(--serif);font-size:2.5rem;color:var(--gold);display:block;line-height:1}
.about__facts .lbl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.about__media{position:relative}
.about__media img{width:100%;height:clamp(420px,52vw,600px);object-fit:cover;filter:saturate(1.02)}
.about__badge{position:absolute;bottom:-26px;left:-26px;background:var(--paper);padding:22px 30px;text-align:center;box-shadow:0 24px 60px -30px rgba(21,18,13,.4)}
.about__badge-fr{font-family:var(--serif);font-style:italic;font-size:1.55rem;color:var(--ink);display:block}
.about__badge-en{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-top:4px;display:block}

/* ░░ TERRACE ░░ */
.terrace{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:#0c0a07}
.terrace__bg{position:absolute;inset:-8% 0;background:url('../img/terrace/terrace-1.jpg') center 50%/cover no-repeat;filter:brightness(.6) contrast(1.04) saturate(.92);will-change:transform;transform:scale(1.05)}
.terrace__veil{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,6,4,.88) 0%,rgba(8,6,4,.55) 50%,rgba(8,6,4,.12) 100%)}
.terrace__inner{position:relative;z-index:2;width:100%}
.terrace__card{max-width:600px;border-left:1px solid rgba(201,168,106,.4);padding-left:clamp(24px,4vw,48px)}
.terrace__lead{font-family:var(--serif);font-size:clamp(1.2rem,2vw,1.5rem);font-weight:300;color:rgba(247,242,233,.92);margin:1.4rem 0 2.4rem;line-height:1.55}

/* ░░ MENU BROWSER ░░ */
.menu__tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;position:sticky;top:64px;z-index:30;background:var(--ivory);padding:18px 0;margin-bottom:clamp(26px,3vw,40px);box-shadow:0 1px 0 var(--line),0 14px 18px -16px rgba(21,18,13,.25)}
.menu__tab{font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;background:none;border:1px solid var(--line);color:var(--muted);padding:.82em 1.5em;cursor:pointer;transition:all .35s var(--ease)}
.menu__tab:hover{color:var(--ink);border-color:var(--ink)}
.menu__tab.is-active{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.menu__grid{max-width:1080px;margin:0 auto}
.mcat{margin-bottom:clamp(40px,5vw,64px)}
.mcat__title{text-align:center;font-family:var(--serif);font-weight:500;font-size:1.5rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:1.8rem;display:flex;align-items:center;justify-content:center;gap:20px}
.mcat__title::before,.mcat__title::after{content:"";height:1px;width:48px;background:var(--line)}
.mcat__title span{font-size:1.1rem}
.mcat__items{display:grid;grid-template-columns:1fr 1fr;gap:6px 54px}
.mitem{padding:14px 0;border-bottom:1px solid var(--line)}
.mitem__top{display:flex;align-items:baseline;gap:10px}
.mitem__name{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);line-height:1.2}
.mitem__weight{font-size:.7rem;font-family:var(--sans);color:var(--muted);opacity:.85;margin-left:8px;letter-spacing:.04em}
.mitem__dots{flex:1;border-bottom:1px dotted rgba(21,18,13,.28);transform:translateY(-4px);min-width:14px}
.mitem__price{font-family:var(--serif);font-size:1.28rem;font-weight:600;color:var(--gold);white-space:nowrap}
.mitem__desc{color:var(--muted);font-size:.88rem;margin-top:.3rem;max-width:90%}
.menu__note{text-align:center;font-style:italic;font-family:var(--serif);font-size:1rem;color:var(--muted);margin-top:clamp(30px,4vw,44px);opacity:.85}
.menu__more{text-align:center;margin-top:1.8rem}

/* ░░ CAKES ░░ */
.cakes__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px}
.cake{background:var(--paper);border:1px solid var(--line);overflow:hidden;cursor:pointer;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.cake:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(21,18,13,.5)}
.cake:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.cake__img{height:280px;background-size:cover;background-position:center;background-repeat:no-repeat;transition:transform .7s var(--ease)}
.cake:hover .cake__img{transform:scale(1.04)}
.cake__body{padding:22px 24px 26px}
.cake__top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.cake__name{font-family:var(--serif);font-size:1.45rem;font-weight:600;color:var(--ink);line-height:1.12}
.cake__price{font-family:var(--serif);font-size:1.2rem;font-weight:600;color:var(--gold);white-space:nowrap}
.cake__sub{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.cake__desc{color:var(--muted);font-size:.9rem;margin-top:.9rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cake__more{display:inline-block;margin-top:1rem;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);transition:letter-spacing .3s}
.cake:hover .cake__more{letter-spacing:.26em}
.cakes__custom{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center;margin-top:clamp(50px,7vw,90px);background:var(--ivory);border:1px solid var(--line)}
.cakes__custom-text{padding:clamp(34px,5vw,64px)}
.cakes__custom-text h3{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:500;margin-bottom:1.1rem}
.cakes__custom-text p{color:var(--muted);margin-bottom:1.8rem;max-width:32em}
.cakes__custom-media{height:100%;min-height:320px}
.cakes__custom-media img{width:100%;height:100%;object-fit:cover}

/* ░░ CAKE MODAL ░░ */
.cm{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.cm.open{opacity:1;pointer-events:auto}
.cm__overlay{position:absolute;inset:0;background:rgba(12,10,7,.62);backdrop-filter:blur(4px)}
.cm__dialog{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;max-width:880px;width:100%;max-height:88vh;background:var(--paper);overflow:hidden;box-shadow:0 40px 100px -40px rgba(0,0,0,.6);transform:translateY(20px) scale(.98);transition:transform .5s var(--ease)}
.cm.open .cm__dialog{transform:none}
.cm__img{background-size:cover;background-position:center;background-repeat:no-repeat;min-height:320px}
.cm__x{position:absolute;top:14px;right:16px;z-index:3;background:rgba(251,248,241,.9);border:none;width:38px;height:38px;border-radius:50%;font-size:1.4rem;line-height:1;color:var(--ink);cursor:pointer;transition:background .3s}
.cm__x:hover{background:var(--gold);color:#fff}
.cm__content{padding:clamp(28px,4vw,46px);overflow-y:auto}
.cm__name{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;line-height:1.08;margin-top:.2rem}
.cm__meta{display:flex;align-items:center;gap:12px;margin:.7rem 0 1.2rem;font-size:1rem;color:var(--muted)}
.cm__price{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--gold)}
.cm__dot{color:var(--line)}
.cm__desc{color:var(--ink-2);font-size:1rem;line-height:1.6}
.cm__block{margin-top:1.6rem}
.cm__label{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.7rem}
.cm__layers{list-style:none}
.cm__layers li{position:relative;padding-left:18px;color:var(--ink-2);font-size:.95rem;padding-bottom:.4rem}
.cm__layers li::before{content:"";position:absolute;left:0;top:.6em;width:5px;height:5px;background:var(--gold);transform:rotate(45deg)}
.cm__algs{display:flex;flex-wrap:wrap;gap:8px}
.cm__alg{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:5px 12px;border-radius:40px}
.cm__content .btn{margin-top:1.8rem}

/* ░░ EVENTS ░░ */
.events__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:26px}
.ecard{background:var(--paper);border:1px solid var(--line);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.ecard:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(21,18,13,.5)}
.ecard__img{height:240px;background-size:cover;background-position:center}
.ecard__body{padding:26px 28px 30px}
.ecard__body h3{font-family:var(--serif);font-size:1.55rem;font-weight:600;margin-bottom:.7rem}
.ecard__body p{color:var(--muted);font-size:.95rem}
.events__cta{text-align:center;margin-top:clamp(44px,6vw,70px)}
.events__cta p{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink);margin-bottom:1.6rem}

/* ░░ REVIEWS ░░ */
.reviews__scroll{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:6px 0 28px;scrollbar-width:thin;scrollbar-color:var(--gold) transparent}
.reviews__scroll::-webkit-scrollbar{height:3px}
.reviews__scroll::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}
.reviews__scroll::-webkit-scrollbar-track{background:var(--line)}
.reviews__track{display:flex;gap:24px;padding:0 max(32px,calc((100vw - var(--maxw))/2 + 32px));width:max-content}
.rcard{flex:0 0 auto;width:min(380px,80vw);scroll-snap-align:center;background:var(--paper);border:1px solid var(--line);padding:38px 34px;position:relative}
.rcard__quote{font-family:var(--serif);font-size:4rem;line-height:.6;color:var(--cream);position:absolute;top:26px;left:26px}
.rcard__text{font-family:var(--serif);font-size:1.34rem;font-style:italic;line-height:1.42;color:var(--ink-2);position:relative;z-index:1;margin-bottom:1.6rem;min-height:5.5em}
.rcard__meta{display:flex;align-items:center;justify-content:space-between}
.rcard__author{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.rcard__stars{color:var(--gold-2);font-size:.8rem;letter-spacing:1px}
.reviews__links{display:flex;gap:14px;justify-content:center;margin-top:clamp(30px,4vw,48px);flex-wrap:wrap}

/* ░░ VISIT ░░ */
.visit__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,80px);align-items:center}
.visit__list{list-style:none;margin:2rem 0 2.6rem}
.visit__list li{display:flex;flex-direction:column;gap:4px;padding:18px 0;border-bottom:1px solid var(--line)}
.visit__lbl{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.visit__list span,.visit__list a{color:var(--ink-2);font-size:1.02rem}
.visit__list a:hover{color:var(--gold)}
.visit__link{transition:color .3s}
.visit__map{height:clamp(360px,46vw,520px);border:1px solid var(--line);overflow:hidden}
.visit__map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}

/* ░░ GALLERY ░░ */
.gallery{padding:clamp(74px,11vw,154px) 0}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gtile{position:relative;overflow:hidden;display:block;background:var(--cream)}
.gtile img,.gtile .gtile__bg{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.gtile__bg{background-size:cover;background-position:center}
.gtile--tall{grid-row:span 2}
.gtile--wide{grid-column:span 2}
.gtile__ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,10,7,0) 40%,rgba(12,10,7,.55) 100%);opacity:0;transition:opacity .5s var(--ease);display:flex;align-items:flex-end;padding:18px}
.gtile__ov svg{width:22px;height:22px;fill:#fff}
.gtile:hover .gtile__bg,.gtile:hover img{transform:scale(1.07)}
.gtile:hover .gtile__ov{opacity:1}
.gallery__cta{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:clamp(36px,5vw,56px)}
.gallery__handle{display:inline-flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.5rem;color:var(--ink);transition:color .3s}
.gallery__handle:hover{color:var(--gold)}
.gallery__handle svg{width:24px;height:24px;fill:currentColor}

/* ░░ FOOTER ░░ */
.footer{background:var(--ink);color:var(--ivory);padding:64px 0 30px}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid rgba(247,242,233,.12)}
.footer__name{font-family:var(--serif);font-size:1.8rem;font-weight:600;display:block}
.footer__sub{font-size:.74rem;letter-spacing:.08em;color:rgba(247,242,233,.55);margin-top:5px;display:block}
.footer__nav{display:flex;gap:26px;flex-wrap:wrap}
.footer__nav a{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(247,242,233,.7);transition:color .3s}
.footer__nav a:hover{color:var(--gold-2)}
.footer__legal{display:flex;align-items:center;justify-content:flex-end;gap:20px;margin-top:26px;font-size:.74rem;color:rgba(247,242,233,.45);letter-spacing:.03em}
.westtech{display:inline-flex;align-items:center;gap:.5rem;background:rgba(55,48,231,.1);border:1px solid rgba(55,48,231,.22);border-radius:50px;padding:.38rem .9rem .38rem .5rem;transition:background .3s}
.westtech:hover{background:rgba(55,48,231,.18)}
.westtech svg{flex:0 0 auto}
.westtech__grey{color:#9a96a8;font-size:.82rem}
.westtech__indigo{color:#6366f1;font-size:.82rem;font-weight:500}

/* ░░ RESPONSIVE ░░ */
@media(max-width:980px){
  .about__grid,.visit__grid,.cakes__custom{grid-template-columns:1fr}
  .about__media{order:-1}
  .cakes__custom-media{min-height:260px}
  .mcat__items{grid-template-columns:1fr;gap:2px 0}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .gtile--wide{grid-column:span 2}
  .cm__dialog{grid-template-columns:1fr;max-height:90vh;overflow-y:auto}
  .cm__img{min-height:240px}
  .nav__links{position:fixed;inset:0;width:100%;height:100%;height:100dvh;background:var(--ink);flex-direction:column;justify-content:center;align-items:center;gap:26px;padding:90px 40px 60px;transform:translateX(100%);transition:transform .5s var(--ease);z-index:55;overflow-y:auto}
  .nav__links.open{transform:none}
  .nav__links a{color:var(--ivory);font-size:1.1rem;letter-spacing:.22em;opacity:.92}
  .nav__links a::after{display:none}
  .nav.scrolled .nav__links a{color:var(--ivory)}
  .nav__drawer-cta{display:inline-flex!important;margin-top:14px;color:#fff;border-color:rgba(201,168,106,.6)!important;font-size:.74rem!important;padding:1em 2.4em!important}
  .nav__burger{display:flex;z-index:60}
  .nav__reserve{display:none}
}
@media(max-width:640px){
  .container{padding:0 20px}
  .nav__inner{padding:16px 20px}
  .kicker{letter-spacing:.22em;font-size:.64rem}
  .hero__frame{inset:14px}
  .hero__tag{font-size:1.15rem}
  .menu__tabs{top:60px;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;padding:13px 20px;margin-left:-20px;margin-right:-20px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .menu__tabs::-webkit-scrollbar{display:none}
  .menu__tab{flex:0 0 auto;font-size:.66rem;padding:.7em 1.1em;letter-spacing:.1em}
  .about__badge{left:0;bottom:-20px}
  .hero__cta{flex-direction:column;gap:18px}
  .footer__legal{justify-content:flex-start}
  .gallery__grid{grid-auto-rows:140px}
}
@media(hover:none){.hero__bg,.terrace__bg{background-attachment:scroll}}
