/* ============================================================
   IL GATTO NERO — Cernobbio, Lago di Como
   Noir luxury fine-dining. Bodoni Moda + Hanken Grotesk.
   Hand-written, offline-first, zero CDN.
   ============================================================ */

@font-face{font-family:'Bodoni Moda';font-style:normal;font-weight:400 700;font-display:swap;src:url('../fonts/bodoni.woff2') format('woff2')}
@font-face{font-family:'Bodoni Moda';font-style:italic;font-weight:400 600;font-display:swap;src:url('../fonts/bodoni-italic.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:300 800;font-display:swap;src:url('../fonts/hanken.woff2') format('woff2')}

:root{
  --noir:#0a0b0a;
  --noir-2:#0e100e;
  --panel:#131614;
  --panel-2:#181c19;
  --panel-3:#1e231f;
  --line:rgba(238,232,220,.12);
  --line-2:rgba(238,232,220,.22);
  --ivory:#efe9dd;
  --ivory-dim:#cdc7b9;
  --muted:#928c7e;
  --jade:#2fa282;
  --jade-2:#6fe0bb;
  --jade-deep:#123f31;
  --jade-soft:rgba(47,162,130,.14);
  --serif:'Bodoni Moda',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --maxw:1240px;
  --pad:clamp(20px,5vw,72px);
  --head-h:84px;
  --ease:cubic-bezier(.22,1,.36,1);
}

/* ---------- reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  overflow-x:clip;
  scroll-padding-top:var(--head-h);
}
body{
  font-family:var(--sans);
  background:var(--noir);
  color:var(--ivory);
  line-height:1.65;
  font-weight:400;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:.005em;overflow-wrap:break-word}
p,span,a,li,label{overflow-wrap:break-word}
::selection{background:var(--jade);color:var(--noir)}
:focus-visible{outline:2px solid var(--jade-2);outline-offset:3px}
[hidden]{display:none!important}

/* ---------- utility ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--jade-2);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--jade);opacity:.7}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--jade);opacity:.7}
.eyebrow.center{justify-content:center}
.sec{padding:clamp(64px,10vw,128px) 0;position:relative}
.sec-title{font-size:clamp(2rem,5.2vw,3.6rem);letter-spacing:-.01em}
.sec-title .it{font-style:italic;font-weight:400;color:var(--jade-2)}
.lead{color:var(--ivory-dim);font-size:clamp(1.02rem,1.6vw,1.18rem);font-weight:300;max-width:56ch}
.muted{color:var(--muted)}
.divider{height:1px;background:var(--line);border:0}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  padding:1.05em 1.9em;border-radius:2px;transition:.45s var(--ease);position:relative;white-space:nowrap;
}
.btn-primary{background:var(--jade);color:#06140f}
.btn-primary:hover{background:var(--jade-2);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line-2);color:var(--ivory)}
.btn-ghost:hover{border-color:var(--jade);color:var(--jade-2);background:var(--jade-soft)}
.btn-lg{padding:1.2em 2.4em}
.link-u{position:relative;color:var(--jade-2);font-weight:600;letter-spacing:.04em}
.link-u::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--jade);transform:scaleX(.4);transform-origin:left;transition:.4s var(--ease)}
.link-u:hover::after{transform:scaleX(1)}

/* ============================================================
   INTRO / PRELOADER — cat eyes opening in the dark
   ============================================================ */
#intro{position:fixed;inset:0;z-index:2000;background:#070807;display:grid;place-items:center;overflow:hidden}
#intro .intro-inner{display:flex;flex-direction:column;align-items:center;gap:26px;text-align:center}
.cat-eyes{width:148px;height:64px;filter:drop-shadow(0 0 22px rgba(111,224,187,.55))}
.cat-eyes .eye{transform-box:fill-box;transform-origin:center;animation:eyeOpen 1.05s var(--ease) .15s both}
.cat-eyes .eye.r{animation-delay:.28s}
.cat-eyes .pupil{animation:pupil 2.6s ease-in-out .9s both}
@keyframes eyeOpen{0%{transform:scaleY(.04)}60%{transform:scaleY(1.08)}100%{transform:scaleY(1)}}
@keyframes pupil{0%,44%{transform:scaleX(1)}50%{transform:scaleX(.18)}56%,100%{transform:scaleX(1)}}
#intro .intro-logo{height:160px;width:auto;opacity:0;animation:introLogo 1s var(--ease) 1.25s both}
@keyframes introLogo{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}
#intro .intro-cap{font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:var(--jade-2);opacity:0;animation:introCap .9s ease 1.7s both}
@keyframes introCap{from{opacity:0;letter-spacing:.5em}to{opacity:.95;letter-spacing:.34em}}
#intro.lift{transform:translateY(-100%);transition:transform 1s var(--ease)}
body.intro-lock{overflow:hidden;height:100vh}

/* ============================================================
   HEADER
   ============================================================ */
.head{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:.5s var(--ease)}
.head-in{display:flex;align-items:center;justify-content:space-between;gap:18px;height:var(--head-h);max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.head::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,8,7,.9),rgba(7,8,7,0));opacity:1;transition:.5s;pointer-events:none}
.head.solid{background:rgba(8,9,8,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.head.solid::before{opacity:0}
.brand{display:flex;align-items:center;gap:13px;z-index:2}
.brand img{height:72px;width:auto;object-fit:contain;transition:.5s var(--ease)}
.head.solid .brand img{height:58px}
.nav{display:flex;align-items:center;gap:34px}
.nav a{font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;font-weight:500;color:var(--ivory-dim);position:relative;padding:6px 0;transition:.3s}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--jade);transform:scaleX(0);transform-origin:right;transition:.4s var(--ease)}
.nav a:hover,.nav a.active{color:var(--ivory)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);transform-origin:left}
.head-actions{display:flex;align-items:center;gap:14px;z-index:2}

/* language button */
.lang-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:2px;padding:9px 13px;font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ivory-dim);transition:.35s}
.lang-btn:hover{border-color:var(--jade);color:var(--jade-2)}
.lang-btn svg{width:15px;height:15px}
.head .btn{padding:.85em 1.5em;font-size:.74rem}

.burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:2px;position:relative;flex:0 0 auto}
.burger span{position:absolute;left:11px;width:20px;height:1.6px;background:var(--ivory);transition:.35s var(--ease)}
.burger span:nth-child(1){top:15px}.burger span:nth-child(2){top:21px}.burger span:nth-child(3){top:27px}
.burger.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* mobile menu sheet */
.msheet{position:fixed;inset:0;z-index:990;background:rgba(7,8,7,.97);backdrop-filter:blur(8px);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;opacity:0;pointer-events:none;transition:.5s var(--ease)}
.msheet.open{opacity:1;pointer-events:auto}
.msheet a{font-family:var(--serif);font-size:2rem;color:var(--ivory);padding:10px 0;opacity:0;transform:translateY(16px);transition:.5s var(--ease)}
.msheet.open a{opacity:1;transform:none}
.msheet.open a:nth-child(1){transition-delay:.06s}.msheet.open a:nth-child(2){transition-delay:.12s}.msheet.open a:nth-child(3){transition-delay:.18s}.msheet.open a:nth-child(4){transition-delay:.24s}.msheet.open a:nth-child(5){transition-delay:.3s}
.msheet a .it{font-style:italic;color:var(--jade-2)}
.msheet .m-cta{margin-top:22px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s ease;background-size:cover;background-position:center;transform:scale(1.06)}
.hero-bg .slide.on{opacity:1;animation:kenburns 9s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.15)}}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,8,7,.55) 0%,rgba(7,8,7,.18) 35%,rgba(7,8,7,.72) 78%,rgba(7,8,7,.96) 100%)}
.hero-content{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(56px,9vh,104px)}
.hero h1{font-size:clamp(2.9rem,8.5vw,6.6rem);font-weight:500;letter-spacing:-.02em;line-height:.98}
.hero h1 .it{font-style:italic;font-weight:400;color:var(--ivory)}
.hero .h-sub{font-size:clamp(1rem,1.7vw,1.22rem);color:var(--ivory-dim);font-weight:300;max-width:46ch;margin-top:22px}
.hero .h-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-meta{position:absolute;top:calc(var(--head-h) + 14px);left:var(--pad);z-index:2;writing-mode:vertical-rl;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivory-dim);display:flex;align-items:center;gap:14px}
.hero-meta::after{content:"";height:60px;width:1px;background:var(--line-2)}
.hero-dots{position:absolute;right:var(--pad);bottom:clamp(56px,9vh,104px);z-index:3;display:flex;gap:10px}
.hero-dots button{width:26px;height:2px;background:var(--line-2);transition:.4s}
.hero-dots button.on{background:var(--jade-2);width:42px}
.scroll-cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:3;font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue i{width:1px;height:34px;background:linear-gradient(var(--jade),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ============================================================
   GENERIC PAGE HERO (inner pages)
   ============================================================ */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden}
.phero .pbg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);animation:kenburns 14s ease-out forwards}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,8,7,.5),rgba(7,8,7,.45) 50%,rgba(7,8,7,.95))}
.phero .pin{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(40px,7vh,72px)}
.phero h1{font-size:clamp(2.4rem,6.5vw,5rem);line-height:1}
.phero h1 .it{font-style:italic;color:var(--jade-2)}
.crumb{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory-dim);margin-bottom:18px}
.crumb a:hover{color:var(--jade-2)}
.crumb span{color:var(--muted)}

/* ============================================================
   INTRO STORY (home) — split
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,6vw,84px);align-items:center}
.split.rev{grid-template-columns:.95fr 1.05fr}
.split .s-media{position:relative}
.split .s-media .frame{aspect-ratio:4/5;position:relative;overflow:hidden;border:1px solid var(--line)}
.split .s-media .frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.split .s-media:hover .frame img{transform:scale(1.05)}
.split .s-media .tag{position:absolute;bottom:-1px;right:-1px;background:var(--noir);border:1px solid var(--line);padding:14px 20px;font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--jade-2)}
.split .s-media .badge-est{position:absolute;top:18px;left:18px;width:96px;height:96px;border:1px solid var(--jade);border-radius:50%;display:grid;place-items:center;text-align:center;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--jade-2);background:rgba(7,8,7,.5);backdrop-filter:blur(4px)}
.split .s-media .badge-est b{font-family:var(--serif);font-size:1.5rem;display:block;letter-spacing:0;color:var(--ivory)}
.s-body h2{font-size:clamp(1.9rem,4.4vw,3.2rem);margin:18px 0 22px}
.s-body p{color:var(--ivory-dim);font-weight:300;margin-bottom:18px}
.s-body p.pull{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--ivory);line-height:1.4}
.statgrid{display:flex;flex-wrap:wrap;gap:34px;margin:30px 0;border-top:1px solid var(--line);padding-top:26px}
.statgrid .st b{font-family:var(--serif);font-size:2.3rem;color:var(--jade-2);display:block;line-height:1}
.statgrid .st span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   FEATURE CARDS (experience)
   ============================================================ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.feat{background:var(--noir);padding:clamp(28px,3.5vw,46px) clamp(24px,3vw,38px);transition:.5s var(--ease);position:relative}
.feat:hover{background:var(--panel)}
.feat .num{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--jade);opacity:.7}
.feat h3{font-size:1.5rem;margin:18px 0 12px}
.feat p{color:var(--muted);font-weight:300;font-size:.96rem}
.feat .ic{width:34px;height:34px;color:var(--jade-2);margin-bottom:6px}

/* ============================================================
   SIGNATURE DISHES (home menu teaser)
   ============================================================ */
.dishes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.dish{position:relative;overflow:hidden;border:1px solid var(--line);background:var(--panel)}
.dish .di{aspect-ratio:3/4;position:relative;overflow:hidden}
.dish .di img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.dish:hover .di img{transform:scale(1.07)}
.dish .di::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(7,8,7,.85))}
.dish .dt{position:absolute;left:0;bottom:0;z-index:2;padding:22px 24px;width:100%}
.dish .dt .k{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--jade-2)}
.dish .dt h3{font-size:1.45rem;margin:8px 0 4px}
.dish .dt .pr{font-family:var(--serif);font-style:italic;color:var(--ivory-dim)}

/* ============================================================
   BAND (full-bleed quote with bg)
   ============================================================ */
.band{position:relative;padding:clamp(80px,14vw,180px) 0;overflow:hidden;text-align:center}
.band .bbg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.band::after{content:"";position:absolute;inset:0;background:rgba(6,7,6,.74)}
.band .bin{position:relative;z-index:2;max-width:900px;margin:0 auto;padding:0 var(--pad)}
.band q{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,4vw,2.8rem);line-height:1.3;display:block}
.band q::before{content:"“"}.band q::after{content:"”"}
.band .who{margin-top:24px;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--jade-2)}

/* ============================================================
   CAVIAR / LUXURY teaser
   ============================================================ */
.lux{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(24px,5vw,70px)}
.lux .lux-img{position:relative;aspect-ratio:1/1;overflow:hidden;border:1px solid var(--line);background:#000}
.lux .lux-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.lux ul.caviar{margin-top:24px;border-top:1px solid var(--line)}
.lux ul.caviar li{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--line);align-items:baseline}
.lux ul.caviar li .nm{font-family:var(--serif);font-size:1.12rem}
.lux ul.caviar li .nm small{display:block;font-family:var(--sans);font-size:.74rem;color:var(--muted);letter-spacing:.04em;margin-top:2px}
.lux ul.caviar li .pr{font-family:var(--serif);font-style:italic;color:var(--jade-2);white-space:nowrap}

/* ============================================================
   MARQUEE (reviews + ribbon)
   ============================================================ */
.ribbon{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:22px 0;background:var(--noir-2)}
.ribbon .rtrack{display:flex;gap:0;width:max-content;animation:scrollx 38s linear infinite}
.ribbon .rtrack span{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,3vw,2.1rem);color:var(--ivory);padding:0 30px;display:inline-flex;align-items:center;gap:30px;white-space:nowrap}
.ribbon .rtrack span::after{content:"✦";color:var(--jade);font-style:normal;font-size:.7em}
.ribbon:hover .rtrack{animation-play-state:paused}

.reviews{overflow:hidden}
.rev-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:48px}
.rev-rate{display:flex;align-items:center;gap:14px}
.rev-rate .big{font-family:var(--serif);font-size:3rem;color:var(--jade-2);line-height:1}
.rev-rate .stars{color:var(--jade-2);letter-spacing:3px}
.rev-rate small{display:block;color:var(--muted);font-size:.78rem;letter-spacing:.04em}
.mq{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.mtrack{display:flex;gap:22px;width:max-content;animation:scrollx 64s linear infinite}
.mq:hover .mtrack{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rcard{flex:0 0 360px;width:360px;background:var(--panel);border:1px solid var(--line);padding:30px 30px 26px;display:flex;flex-direction:column;gap:14px}
.rcard .rs{color:var(--jade-2);letter-spacing:2px;font-size:.9rem}
.rcard p{font-weight:300;color:var(--ivory-dim);font-size:1rem;line-height:1.6;font-style:italic;font-family:var(--serif)}
.rcard .who{margin-top:auto;display:flex;align-items:center;gap:12px}
.rcard .av{width:38px;height:38px;border-radius:50%;background:var(--jade-deep);color:var(--jade-2);display:grid;place-items:center;font-weight:700;font-size:.9rem;font-family:var(--sans)}
.rcard .who b{font-size:.92rem;font-weight:600}
.rcard .who small{display:block;color:var(--muted);font-size:.72rem}

/* ============================================================
   MENU PAGE
   ============================================================ */
.menu-tabs{position:sticky;top:var(--head-h);z-index:80;background:rgba(8,9,8,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
.menu-tabs::-webkit-scrollbar{display:none}
.menu-tabs .mt-in{display:flex;gap:6px;max-width:var(--maxw);margin:0 auto;padding:12px var(--pad)}
.menu-tabs button{flex:0 0 auto;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--muted);padding:10px 16px;border-radius:2px;transition:.3s;white-space:nowrap}
.menu-tabs button:hover{color:var(--ivory)}
.menu-tabs button.active{color:var(--jade-2);background:var(--jade-soft)}
.mcat{margin-bottom:clamp(48px,7vw,86px);scroll-margin-top:calc(var(--head-h) + 70px)}
.mcat-h{display:flex;align-items:baseline;gap:20px;margin-bottom:8px}
.mcat-h h2{font-size:clamp(1.7rem,4vw,2.7rem)}
.mcat-h .ln{flex:1;height:1px;background:var(--line)}
.mcat-note{color:var(--muted);font-weight:300;font-size:.95rem;margin-bottom:30px;max-width:62ch}
.mitems{display:grid;grid-template-columns:1fr 1fr;gap:4px 56px}
.mitem{display:grid;grid-template-columns:1fr auto;gap:6px 16px;padding:18px 0;border-bottom:1px solid var(--line);align-items:baseline}
.mitem .mi-n{font-family:var(--serif);font-size:1.18rem;font-weight:500}
.mitem .mi-p{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--jade-2);white-space:nowrap}
.mitem .mi-d{grid-column:1/-1;color:var(--muted);font-weight:300;font-size:.9rem;line-height:1.55;margin-top:-2px}
.mitem .mi-tag{display:inline-block;font-family:var(--sans);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--jade);border:1px solid var(--jade-deep);border-radius:2px;padding:2px 7px;margin-left:8px;vertical-align:middle}
.deg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:14px}
.deg{background:linear-gradient(180deg,var(--panel),var(--noir));border:1px solid var(--line);padding:32px 28px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.deg::before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--jade),transparent)}
.deg .dn{font-family:var(--serif);font-style:italic;font-size:1.7rem;color:var(--ivory)}
.deg .dp{font-family:var(--serif);font-size:2.1rem;color:var(--jade-2)}
.deg .dp small{font-size:.8rem;color:var(--muted);font-family:var(--sans);letter-spacing:.04em}
.deg ul li{padding:7px 0;border-bottom:1px solid var(--line);color:var(--ivory-dim);font-weight:300;font-size:.92rem;display:flex;gap:10px}
.deg ul li::before{content:"—";color:var(--jade)}
.note-box{border:1px solid var(--line);background:var(--panel);padding:22px 26px;color:var(--muted);font-size:.86rem;font-weight:300;display:flex;gap:14px;align-items:flex-start;border-radius:2px}
.note-box svg{flex:0 0 auto;width:20px;height:20px;color:var(--jade)}

/* ============================================================
   GALLERY + LIGHTBOX
   ============================================================ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:10px}
.gal figure{position:relative;overflow:hidden;border:1px solid var(--line);cursor:pointer;margin:0}
.gal figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.gal figure:hover img{transform:scale(1.08)}
.gal figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,8,7,.7));opacity:0;transition:.4s}
.gal figure figcaption{position:absolute;left:0;bottom:0;z-index:2;padding:14px 16px;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ivory);opacity:0;transform:translateY(8px);transition:.4s}
.gal figure:hover::after{opacity:1}
.gal figure:hover figcaption{opacity:1;transform:none}
.gal .big{grid-column:span 2;grid-row:span 2}
.gal .tall{grid-row:span 2}
.gal .wide{grid-column:span 2}

.lightbox{position:fixed;inset:0;z-index:1500;background:rgba(5,6,5,.96);display:flex;align-items:center;justify-content:center;opacity:0;transition:.4s;padding:4vw}
.lightbox.show{opacity:1}
.lightbox:not(.show){pointer-events:none}
.lightbox img{max-width:92vw;max-height:84vh;object-fit:contain;border:1px solid var(--line-2)}
.lightbox .lcap{position:absolute;bottom:5vh;left:50%;transform:translateX(-50%);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ivory-dim)}
.lightbox .lx{position:absolute;top:22px;right:26px;width:46px;height:46px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;font-size:1.3rem;color:var(--ivory);transition:.3s}
.lightbox .lx:hover{border-color:var(--jade);color:var(--jade-2);transform:rotate(90deg)}
.lightbox .lnav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--ivory);font-size:1.2rem;transition:.3s}
.lightbox .lnav:hover{border-color:var(--jade);color:var(--jade-2)}
.lightbox .lprev{left:3vw}.lightbox .lnext{right:3vw}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:880px;margin:0 auto}
.faq-it{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;text-align:left;padding:26px 0;font-family:var(--serif);font-size:clamp(1.1rem,2.4vw,1.5rem);color:var(--ivory);transition:.3s}
.faq-q:hover{color:var(--jade-2)}
.faq-q .pm{flex:0 0 auto;width:30px;height:30px;border:1px solid var(--line-2);border-radius:50%;position:relative;transition:.4s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--jade-2);left:50%;top:50%;transform:translate(-50%,-50%);transition:.4s}
.faq-q .pm::before{width:12px;height:1.5px}.faq-q .pm::after{width:1.5px;height:12px}
.faq-it.open .pm{border-color:var(--jade);transform:rotate(180deg)}
.faq-it.open .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a p{color:var(--ivory-dim);font-weight:300;padding:0 0 26px;max-width:70ch}

/* ============================================================
   CONTACT + MAP
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(24px,4vw,56px);align-items:stretch}
.cinfo .crow{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--line)}
.cinfo .crow .ci{flex:0 0 auto;width:42px;height:42px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--jade-2)}
.cinfo .crow .ci svg{width:18px;height:18px}
.cinfo .crow .k{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.cinfo .crow .v{font-size:1.05rem;color:var(--ivory)}
.cinfo .crow .v a:hover{color:var(--jade-2)}
.cinfo .crow .v small{display:block;color:var(--muted);font-size:.82rem}
.map-wrap{position:relative;min-height:380px;border:1px solid var(--line);overflow:hidden;background:var(--panel)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.4) contrast(1.05) brightness(.85)}
.hours-tab{width:100%;border-collapse:collapse;margin-top:8px}
.hours-tab td{padding:11px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.hours-tab td:first-child{color:var(--ivory-dim)}
.hours-tab td:last-child{text-align:right;color:var(--muted);font-family:var(--serif);font-style:italic}
.hours-tab tr.today td{color:var(--jade-2)}
.hours-tab tr.today td:last-child{color:var(--jade-2)}

/* ============================================================
   CTA band
   ============================================================ */
.cta{position:relative;text-align:center;padding:clamp(70px,12vw,150px) 0;overflow:hidden}
.cta .cbg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,7,6,.8),rgba(6,7,6,.92))}
.cta .cin{position:relative;z-index:2;max-width:720px;margin:0 auto;padding:0 var(--pad)}
.cta h2{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:18px}
.cta h2 .it{font-style:italic;color:var(--jade-2)}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--noir-2);border-top:1px solid var(--line);padding:clamp(56px,8vw,96px) 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:54px}
.foot .f-brand img{height:66px;width:auto;margin-bottom:18px}
.foot .f-brand p{color:var(--muted);font-weight:300;font-size:.92rem;max-width:34ch}
.foot h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--jade-2);margin-bottom:20px}
.foot ul li{margin-bottom:11px}
.foot ul li a,.foot .fcol p{color:var(--ivory-dim);font-weight:300;font-size:.94rem;transition:.3s}
.foot ul li a:hover{color:var(--jade-2)}
.fsoc{display:flex;gap:12px;margin-top:8px}
.fsoc a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--ivory-dim);transition:.35s}
.fsoc a:hover{border-color:var(--jade);color:var(--jade-2);transform:translateY(-3px)}
.fsoc a svg{width:17px;height:17px}
.foot-bot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding-top:26px;border-top:1px solid var(--line);font-size:.78rem;color:var(--muted)}
.foot-bot a:hover{color:var(--jade-2)}

/* ============================================================
   LANGUAGE SELECTOR (Uniswap-dialog style)
   ============================================================ */
.lang-overlay{position:fixed;inset:0;z-index:1600;display:flex;align-items:flex-start;justify-content:center;padding:14vh 20px 20px;opacity:0;transition:.34s var(--ease)}
.lang-overlay.show{opacity:1}
.lang-overlay:not(.show){pointer-events:none}
.lang-overlay .lo-back{position:absolute;inset:0;background:rgba(5,6,5,.7);backdrop-filter:blur(8px)}
.lang-modal{position:relative;z-index:2;width:min(440px,100%);background:var(--panel);border:1px solid var(--line-2);border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6);overflow:hidden;transform:scale(.92) translateY(10px);transition:.34s var(--ease)}
.lang-overlay.show .lang-modal{transform:none}
.lang-modal .lm-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.lang-modal .lm-h h3{font-size:1.15rem}
.lang-modal .lm-x{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ivory-dim);transition:.3s}
.lang-modal .lm-x:hover{border-color:var(--jade);color:var(--jade-2);transform:rotate(90deg)}
.lang-modal .lm-search{padding:14px 20px;border-bottom:1px solid var(--line)}
.lang-modal .lm-search input{width:100%;background:var(--noir);border:1px solid var(--line);border-radius:4px;padding:11px 14px;color:var(--ivory);font-family:var(--sans);font-size:.95rem}
.lang-modal .lm-search input:focus{outline:none;border-color:var(--jade)}
.lang-list{max-height:46vh;overflow-y:auto;padding:8px}
.lang-list button{width:100%;display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:5px;color:var(--ivory-dim);transition:.2s;text-align:left}
.lang-list button:hover{background:var(--panel-2);color:var(--ivory)}
.lang-list button.active{color:var(--jade-2);background:var(--jade-soft)}
.lang-list button .fl{font-size:1.2rem;line-height:1;width:24px;text-align:center}
.lang-list button .ln{flex:1;font-size:.96rem}
.lang-list button .ck{opacity:0;color:var(--jade-2)}
.lang-list button.active .ck{opacity:1}
.lang-list .no-res{padding:20px;text-align:center;color:var(--muted);font-size:.9rem}

/* ============================================================
   WhatsApp FAB
   ============================================================ */
.wa-fab{position:fixed;right:20px;bottom:20px;z-index:900;width:56px;height:56px;border-radius:50%;background:var(--jade);color:#06140f;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.4);transition:.4s var(--ease)}
.wa-fab:hover{transform:translateY(-4px) scale(1.05);background:var(--jade-2)}
.wa-fab svg{width:28px;height:28px}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  :root{--head-h:74px}
  .nav,.head .btn{display:none}
  .burger{display:block}
  .feat-grid{grid-template-columns:1fr 1fr}
  .deg-grid{grid-template-columns:1fr}
  .gal .big{grid-column:span 2;grid-row:span 1}
}
@media(max-width:860px){
  .split,.split.rev{grid-template-columns:1fr;gap:36px}
  .split .s-media{max-width:480px}
  .lux{grid-template-columns:1fr}
  .dishes{grid-template-columns:1fr 1fr}
  .feat-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .mitems{grid-template-columns:1fr;gap:0}
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
  .gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .gal .big,.gal .wide{grid-column:span 2}
  .gal .tall{grid-row:span 1}
  .hero-meta{display:none}
}
@media(max-width:560px){
  :root{--head-h:66px}
  .brand img{height:46px}
  .head.solid .brand img{height:42px}
  .lang-btn .lb-t{display:none}
  .dishes{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero .h-cta{flex-direction:column}
  .hero .h-cta .btn{width:100%}
  .rcard{flex:0 0 290px;width:290px}
  .deg-grid{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:130px}
  .statgrid{gap:22px}
  .band q{font-size:1.5rem}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero-bg .slide.on{animation:none}
  /* marquees always move (Michele's rule) */
  .mtrack{animation:scrollx 64s linear infinite!important}
  .ribbon .rtrack{animation:scrollx 38s linear infinite!important}
  .scroll-cue i{animation:none}
}
