/* ============================================================
   Osteria del Tortellino — "Bottega della Sfoglia"
   Editorial-heritage emiliano · panna-farina / bordeaux Lambrusco / oro tuorlo
   ============================================================ */
@font-face{font-family:Fraunces;font-style:normal;font-weight:400;font-display:swap;src:url(fonts/fraunces-400-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:Fraunces;font-style:normal;font-weight:400;font-display:swap;src:url(fonts/fraunces-400-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Fraunces;font-style:normal;font-weight:500;font-display:swap;src:url(fonts/fraunces-500-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Fraunces;font-style:normal;font-weight:500;font-display:swap;src:url(fonts/fraunces-500-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Fraunces;font-style:normal;font-weight:600;font-display:swap;src:url(fonts/fraunces-600-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Fraunces;font-style:normal;font-weight:600;font-display:swap;src:url(fonts/fraunces-600-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Fraunces;font-style:normal;font-weight:700;font-display:swap;src:url(fonts/fraunces-700-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Fraunces;font-style:normal;font-weight:700;font-display:swap;src:url(fonts/fraunces-700-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Hanken;font-style:normal;font-weight:400;font-display:swap;src:url(fonts/hanken-400-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Hanken;font-style:normal;font-weight:400;font-display:swap;src:url(fonts/hanken-400-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Hanken;font-style:normal;font-weight:500;font-display:swap;src:url(fonts/hanken-500-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Hanken;font-style:normal;font-weight:500;font-display:swap;src:url(fonts/hanken-500-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Hanken;font-style:normal;font-weight:600;font-display:swap;src:url(fonts/hanken-600-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Hanken;font-style:normal;font-weight:600;font-display:swap;src:url(fonts/hanken-600-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:Hanken;font-style:normal;font-weight:700;font-display:swap;src:url(fonts/hanken-700-lat.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122}
@font-face{font-family:Hanken;font-style:normal;font-weight:700;font-display:swap;src:url(fonts/hanken-700-ext.woff2) format('woff2');unicode-range:U+0100-02AF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF}

:root{
  --panna:#f5eddc; --panna-2:#efe3cd; --paper:#fbf6ea;
  --ink:#6d1f28; --ink-2:#8a2b34; --ink-deep:#4c141b;
  --gold:#c0842b; --gold-2:#dda23f; --gold-soft:#e8c98a;
  --char:#2c231d; --char-soft:#5a4d43;
  --line:rgba(76,20,27,.16); --line-2:rgba(76,20,27,.28);
  --shadow:0 24px 60px -30px rgba(44,20,15,.5);
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Hanken',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --wrap:1180px; --gap:clamp(20px,4vw,54px);
  --r:14px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:88px;overflow-x:clip}
body{
  margin:0;background:var(--panna);color:var(--char);
  font-family:var(--sans);font-size:clamp(16px,1.05vw,17.5px);line-height:1.65;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(rgba(76,20,27,.035) 1px,transparent 1px);background-size:22px 22px;
}
[hidden]{display:none!important}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.05;margin:0;color:var(--ink-deep);letter-spacing:-.01em;overflow-wrap:break-word}
h1,h2,h3,p,span,a,li,figcaption,label,input,select,textarea,button{overflow-wrap:break-word}
p{margin:0 0 1rem}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(18px,5vw,40px)}
section{position:relative}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* --- reveal --- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.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}

/* ============ INTRO / PRELOADER ============ */
#intro{position:fixed;inset:0;z-index:9999;background:var(--ink-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;overflow:hidden}
#intro .flour{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 40%,rgba(224,169,64,.14),transparent 60%);opacity:0;animation:flourGlow 2.4s ease forwards}
@keyframes flourGlow{0%{opacity:0}40%{opacity:1}100%{opacity:1}}
#intro .rollwrap{width:min(340px,72vw);height:120px;position:relative}
#intro svg.matt{width:100%;height:100%;overflow:visible}
#intro .sheet{fill:var(--gold-soft);opacity:.0;transform-origin:left center;animation:sheetGrow 1.8s .35s cubic-bezier(.5,0,.1,1) forwards}
@keyframes sheetGrow{0%{opacity:0;transform:scaleX(.02)}25%{opacity:1}100%{opacity:1;transform:scaleX(1)}}
#intro .pin{animation:pinRoll 1.8s .35s cubic-bezier(.5,0,.1,1) forwards}
@keyframes pinRoll{0%{transform:translateX(-130px) rotate(0)}100%{transform:translateX(150px) rotate(320deg)}}
#intro .logo{width:min(190px,54vw);height:auto;object-fit:contain;opacity:0;transform:translateY(14px) scale(.94);animation:introLogo 1.1s 1.35s cubic-bezier(.2,.8,.2,1) forwards;filter:drop-shadow(0 10px 30px rgba(0,0,0,.4))}
@keyframes introLogo{0%{opacity:0;transform:translateY(14px) scale(.94)}100%{opacity:1;transform:translateY(0) scale(1)}}
#intro .tag{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:15px;letter-spacing:.06em;opacity:0;animation:introTag 1s 1.9s ease forwards}
@keyframes introTag{to{opacity:1}}
body.intro-done #intro{animation:introOut .7s cubic-bezier(.7,0,.3,1) forwards}
@keyframes introOut{0%{opacity:1;clip-path:inset(0 0 0 0)}100%{opacity:1;clip-path:inset(0 0 100% 0);pointer-events:none}}

/* ============ HEADER ============ */
header.site{position:fixed;top:0;left:0;right:0;z-index:900;transition:background .35s,box-shadow .35s,padding .35s;padding:14px 0}
header.site .bar{display:flex;align-items:center;justify-content:space-between;gap:16px}
header.site.solid{background:rgba(245,237,220,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line),0 12px 30px -26px rgba(44,20,15,.6)}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand img{height:64px;width:auto;object-fit:contain;transition:height .35s}
header.site.solid .brand img{height:54px}
.brand .bw{display:flex;flex-direction:column;line-height:1;min-width:0}
.brand .bw b{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--ink-deep);letter-spacing:-.01em;white-space:nowrap}
.brand .bw i{font-style:normal;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:3px}
header.site:not(.solid) .brand .bw b{color:#fff}
header.site:not(.solid) .brand .bw i{color:var(--gold-soft)}
header.site:not(.solid).ondark{}
nav.main{display:flex;align-items:center;gap:8px}
nav.main a.nl{position:relative;font-weight:600;font-size:14.5px;padding:9px 13px;border-radius:9px;color:var(--char);transition:color .25s,background .25s;letter-spacing:.01em}
header.site:not(.solid) nav.main a.nl{color:#f5e7cf}
nav.main a.nl::after{content:"";position:absolute;left:13px;right:13px;bottom:5px;height:1.5px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s}
nav.main a.nl:hover::after,nav.main a.nl.active::after{transform:scaleX(1)}
nav.main a.nl:hover{color:var(--ink)}
header.site:not(.solid) nav.main a.nl:hover{color:#fff}
.hbtn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:14px;cursor:pointer;border:0;background:none}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;padding:12px 22px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;transition:transform .2s,box-shadow .25s,background .25s,color .25s;letter-spacing:.01em;font-family:var(--sans);white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-p{background:var(--ink);color:#fbeecb;box-shadow:0 12px 26px -14px rgba(76,20,27,.8)}
.btn-p:hover{background:var(--ink-deep);box-shadow:0 16px 30px -12px rgba(76,20,27,.9);transform:translateY(-2px)}
.btn-g{background:var(--gold);color:#3a2408}
.btn-g:hover{background:var(--gold-2);transform:translateY(-2px)}
.btn-o{border-color:var(--line-2);color:var(--ink)}
.btn-o:hover{background:var(--ink);color:#fbeecb;border-color:var(--ink)}
header.site:not(.solid) .btn-o{border-color:rgba(245,231,207,.5);color:#f5e7cf}
header.site:not(.solid) .btn-o:hover{background:#f5e7cf;color:var(--ink-deep)}
.lang-btn{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--line-2);background:transparent;color:var(--ink);border-radius:999px;padding:9px 13px;font-weight:600;font-size:13.5px;cursor:pointer;transition:.25s}
header.site:not(.solid) .lang-btn{border-color:rgba(245,231,207,.5);color:#f5e7cf}
.lang-btn:hover{background:var(--ink);color:#fbeecb;border-color:var(--ink)}
header.site:not(.solid) .lang-btn:hover{background:#f5e7cf;color:var(--ink-deep)}
.lang-btn svg{width:16px;height:16px}
.hamb{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center;border:1.5px solid var(--line-2);border-radius:11px;background:transparent;cursor:pointer}
header.site:not(.solid) .hamb{border-color:rgba(245,231,207,.5)}
.hamb span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
header.site:not(.solid) .hamb span{background:#f5e7cf}
.desk{display:flex;align-items:center;gap:10px}

/* mobile drawer */
#drawer{position:fixed;inset:0;z-index:950;pointer-events:none}
#drawer .bd{position:absolute;inset:0;background:rgba(30,12,14,.5);opacity:0;transition:opacity .35s;backdrop-filter:blur(3px)}
#drawer .panel{position:absolute;top:0;right:0;height:100%;width:min(340px,86vw);background:var(--paper);box-shadow:var(--shadow);transform:translateX(103%);transition:transform .4s cubic-bezier(.5,0,.2,1);display:flex;flex-direction:column;padding:22px}
#drawer.open{pointer-events:auto}
#drawer.open .bd{opacity:1}
#drawer.open .panel{transform:none}
#drawer .dh{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
#drawer .dh img{height:46px;width:auto;object-fit:contain}
#drawer .xc{width:42px;height:42px;border:1.5px solid var(--line-2);border-radius:11px;background:transparent;font-size:22px;color:var(--ink);cursor:pointer;line-height:1}
#drawer nav{display:flex;flex-direction:column;margin-top:14px}
#drawer nav a{font-family:var(--serif);font-size:23px;color:var(--ink-deep);padding:13px 4px;border-bottom:1px solid var(--line)}
#drawer .dcta{margin-top:auto;display:flex;flex-direction:column;gap:10px}
#drawer .dinfo{font-size:13.5px;color:var(--char-soft);margin-top:14px;line-height:1.7}

/* ============ HERO ============ */
.hero{min-height:100svh;display:flex;align-items:flex-end;position:relative;overflow:hidden;isolation:isolate}
.hero .bg{position:absolute;inset:0;z-index:-2}
.hero .bg img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.4s ease;transform:scale(1.06);animation:kb 18s ease-in-out infinite alternate}
.hero .bg img.show{opacity:1}
@keyframes kb{to{transform:scale(1.14)}}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(30,12,14,.55) 0%,rgba(30,12,14,.28) 40%,rgba(40,16,18,.72) 100%)}
.hero .inner{padding-bottom:clamp(48px,8vw,110px);padding-top:130px;color:#fbeeda;max-width:900px}
.hero .kick{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:20px}
.hero .kick::before{content:"";width:34px;height:1.5px;background:var(--gold)}
.hero h1{font-size:clamp(2.7rem,7.5vw,6rem);color:#fff;font-weight:600;text-shadow:0 4px 40px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.32rem);max-width:620px;margin:22px 0 30px;color:#f4e6d2}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .scroll{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:2;color:#f4e6d2;font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.85}
.hero .scroll i{width:1px;height:34px;background:linear-gradient(var(--gold-soft),transparent);animation:sd 1.8s ease-in-out infinite}
@keyframes sd{0%,100%{transform:scaleY(.4);opacity:.5;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ============ SECTION SCAFFOLD ============ */
.pad{padding-block:clamp(64px,9vw,120px)}
.kicker{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.kicker::before{content:"";width:26px;height:1.5px;background:var(--gold)}
.h-sec{font-size:clamp(2rem,4.2vw,3.3rem)}
.lead-2{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--char-soft);max-width:62ch}
.eyebrow-num{font-family:var(--serif);font-size:13px;color:var(--gold);font-weight:600}

/* story split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.split.rev{grid-template-columns:.95fr 1.05fr}
.story-figs{position:relative}
.story-figs .big{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5}
.story-figs .big img{width:100%;height:100%;object-fit:cover}
.story-figs .small{position:absolute;bottom:-32px;right:-22px;width:44%;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);border:5px solid var(--paper);aspect-ratio:1/1}
.story-figs .small img{width:100%;height:100%;object-fit:cover}
.story-figs .stamp{position:absolute;top:-26px;left:-24px;width:104px;height:104px;background:var(--ink);color:var(--gold-soft);border-radius:50%;display:grid;place-items:center;text-align:center;font-family:var(--serif);font-style:italic;font-size:13px;line-height:1.15;padding:14px;box-shadow:var(--shadow);transform:rotate(-8deg)}
.story-figs .stamp b{display:block;font-size:26px;font-style:normal;color:#fff}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;position:relative;overflow:hidden;transition:transform .35s,box-shadow .35s}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pillar .n{font-family:var(--serif);font-size:15px;color:var(--gold);font-weight:600;letter-spacing:.05em}
.pillar h3{font-size:1.5rem;margin:8px 0 12px}
.pillar p{color:var(--char-soft);font-size:.98rem;margin:0}
.pillar::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--ink))}

/* ============ MARQUEE (ribbon) ============ */
.ribbon{background:var(--ink);color:var(--gold-soft);padding:16px 0;overflow:hidden;border-block:2px solid var(--gold)}
.ribbon .track{display:flex;width:max-content;animation:scrollx 34s linear infinite}
.ribbon:hover .track{animation-play-state:paused}
.ribbon .track span{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2vw,1.7rem);padding:0 30px;white-space:nowrap;display:inline-flex;align-items:center;gap:30px}
.ribbon .track span::after{content:"✦";color:var(--gold);font-style:normal;font-size:.7em}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ============ MENU ============ */
.menu-tabs{position:sticky;top:74px;z-index:80;background:var(--panna);padding:12px 0;margin-bottom:8px;border-bottom:1px solid var(--line)}
.menu-tabs .row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.menu-tabs .row::-webkit-scrollbar{display:none}
.menu-tabs button{flex:0 0 auto;border:1.5px solid var(--line-2);background:var(--paper);color:var(--ink);border-radius:999px;padding:9px 16px;font-weight:600;font-size:13.5px;cursor:pointer;transition:.22s;white-space:nowrap;font-family:var(--sans)}
.menu-tabs button:hover{border-color:var(--gold)}
.menu-tabs button.active{background:var(--ink);color:#fbeecb;border-color:var(--ink)}
.mcat{margin-bottom:56px;scroll-margin-top:150px}
.mcat-h{display:flex;align-items:baseline;gap:16px;margin-bottom:24px;padding-bottom:12px;border-bottom:2px solid var(--line)}
.mcat-h h2{font-size:clamp(1.6rem,3.3vw,2.4rem)}
.mcat-h .co{flex:1;height:1px;background:repeating-linear-gradient(90deg,var(--line-2) 0 6px,transparent 6px 12px)}
.mcat-h .cnt{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1rem}
.dishes{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 30px}
.dish{display:flex;gap:16px;padding:16px 0;border-bottom:1px dotted var(--line-2);align-items:flex-start}
.dish .thumb{flex:0 0 84px;width:84px;height:84px;border-radius:11px;overflow:hidden;background:var(--panna-2);box-shadow:0 6px 16px -10px rgba(44,20,15,.5)}
.dish .thumb img{width:100%;height:100%;object-fit:cover}
.dish .body{flex:1;min-width:0}
.dish .top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.dish .nm{font-family:var(--serif);font-weight:600;font-size:1.12rem;color:var(--ink-deep);line-height:1.2}
.dish .dot{flex:1;border-bottom:1.5px dotted var(--line-2);transform:translateY(-4px);min-width:14px}
.dish .pr{font-family:var(--serif);font-weight:600;color:var(--gold);font-size:1.08rem;white-space:nowrap}
.dish .ds{font-size:.92rem;color:var(--char-soft);margin:5px 0 0;line-height:1.5}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.badge{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:6px}
.badge.star{background:var(--gold);color:#3a2408}
.badge.veg{background:#e4 efd;background:#dfeadb;color:#2f5230}
.badge.vegan{background:#d6e8d2;color:#255024}
.badge.gf{background:#f3e2c4;color:#7a521a}
.menu-note{margin-top:12px;font-size:.92rem;color:var(--char-soft);background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:10px;padding:14px 18px}

/* ============ GALLERY ============ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:190px;gap:12px}
.gal figure{margin:0;position:relative;overflow:hidden;border-radius:12px;background:var(--panna-2);cursor:zoom-in}
.gal figure img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gal figure:hover img{transform:scale(1.08)}
.gal .w2{grid-column:span 2}.gal .h2{grid-row:span 2}
.gal figure::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(40,16,18,.5));opacity:0;transition:.4s}
.gal figure:hover::after{opacity:1}

/* lightbox */
#lb{position:fixed;inset:0;z-index:1000;background:rgba(25,10,12,.92);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .3s}
#lb.open{opacity:1}
#lb img{max-width:92vw;max-height:86vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
#lb .x,#lb .nav{position:absolute;background:rgba(245,231,207,.14);border:1px solid rgba(245,231,207,.3);color:#fbeeda;cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:.2s}
#lb .x{top:20px;right:22px;width:46px;height:46px;font-size:24px}
#lb .nav{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:26px}
#lb .prev{left:18px}#lb .next{right:18px}
#lb .x:hover,#lb .nav:hover{background:var(--gold);color:#3a2408}

/* ============ REVIEWS ============ */
.rev-wrap{background:var(--ink-deep);color:#f4e2c9;overflow:hidden}
.rev-wrap .kicker{color:var(--gold-soft)}
.rev-wrap .kicker::before{background:var(--gold-soft)}
.rev-wrap h2{color:#fff}
.rev-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:36px}
.rev-score{display:flex;align-items:center;gap:14px}
.rev-score .big{font-family:var(--serif);font-size:3rem;color:var(--gold-soft);line-height:1}
.rev-score .stars{color:var(--gold);font-size:1.1rem;letter-spacing:2px}
.rev-score .sub{font-size:.9rem;color:#d8c4a6}
.rev-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.rev-track{display:flex;width:max-content;gap:20px;animation:scrollx 60s linear infinite}
.rev-marquee:hover .rev-track{animation-play-state:paused}
.rcard{flex:0 0 360px;max-width:360px;background:rgba(245,231,207,.06);border:1px solid rgba(245,231,207,.14);border-radius:var(--r);padding:24px}
.rcard .st{color:var(--gold);letter-spacing:2px;font-size:.95rem}
.rcard .tx{font-family:var(--serif);font-style:italic;font-size:1.02rem;line-height:1.5;color:#f4e2c9;margin:12px 0 16px}
.rcard .who{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#d8c4a6}
.rcard .who b{color:#fff;font-weight:600;font-style:normal;font-family:var(--sans)}
.rcard .src{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-soft)}

/* ============ FAQ ============ */
.faq{max-width:820px;margin-inline:auto}
.faq details{border:1px solid var(--line);background:var(--paper);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:box-shadow .3s}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--serif);font-weight:600;font-size:1.12rem;color:var(--ink-deep);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{flex:0 0 auto;width:26px;height:26px;position:relative;transition:transform .3s}
.faq summary .ic::before,.faq summary .ic::after{content:"";position:absolute;background:var(--gold);border-radius:2px}
.faq summary .ic::before{top:12px;left:4px;right:4px;height:2px}
.faq summary .ic::after{left:12px;top:4px;bottom:4px;width:2px;transition:transform .3s}
.faq details[open] summary .ic::after{transform:scaleY(0)}
.faq .ans{padding:0 24px 22px;color:var(--char-soft);font-size:.98rem}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px)}
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:28px;margin-bottom:16px}
.info-row{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:0}
.info-row .ic{flex:0 0 44px;width:44px;height:44px;border-radius:11px;background:var(--ink);color:var(--gold-soft);display:grid;place-items:center}
.info-row .ic svg{width:20px;height:20px}
.info-row .lab{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700}
.info-row .val{font-size:1.02rem;color:var(--char);font-weight:500}
.info-row a.val:hover{color:var(--ink);text-decoration:underline}
.socials{display:flex;gap:10px;margin-top:6px}
.socials a{width:44px;height:44px;border-radius:11px;border:1.5px solid var(--line-2);display:grid;place-items:center;color:var(--ink);transition:.25s}
.socials a:hover{background:var(--ink);color:#fbeecb;border-color:var(--ink)}
.socials svg{width:19px;height:19px}
.map-wrap{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);min-height:300px}
.map-wrap iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:saturate(.9)}
.rform{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:28px}
.rform h3{font-size:1.5rem;margin-bottom:6px}
.rform .fh{font-size:.9rem;color:var(--char-soft);margin-bottom:18px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field.full{grid-column:1/-1}
.field label{font-size:12.5px;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:15px;padding:12px 14px;border:1.5px solid var(--line-2);border-radius:10px;background:var(--panna);color:var(--char);transition:border .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field textarea{resize:vertical;min-height:72px}

/* ============ FOOTER ============ */
footer.site{background:var(--ink-deep);color:#e8d3b6;padding-block:clamp(48px,7vw,80px) 26px}
footer.site a:hover{color:var(--gold-soft)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
footer.site .fbrand img{height:70px;width:auto;object-fit:contain;margin-bottom:16px}
footer.site .fbrand p{color:#c9b393;font-size:.95rem;max-width:38ch}
footer.site h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--gold-soft);margin-bottom:16px}
footer.site ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;font-size:.95rem}
footer.site .fcont{font-size:.95rem;line-height:1.9;color:#c9b393}
footer.site .fcont b{color:#fff;font-weight:600}
.foot-bot{margin-top:40px;padding-top:22px;border-top:1px solid rgba(232,211,182,.16);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:#a98f6f}
.foot-bot a{color:#a98f6f}

/* ============ LANGUAGE DIALOG ============ */
#langModal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px;pointer-events:none}
#langModal .bd{position:absolute;inset:0;background:rgba(30,12,14,.55);opacity:0;transition:opacity .3s;backdrop-filter:blur(6px)}
#langModal .card{position:relative;width:min(460px,94vw);max-height:80vh;background:var(--paper);border-radius:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;transform:scale(.9) translateY(10px);opacity:0;transition:transform .32s cubic-bezier(.2,.9,.3,1),opacity .32s}
#langModal.open{pointer-events:auto}
#langModal.open .bd{opacity:1}
#langModal.open .card{transform:none;opacity:1}
#langModal .lh{padding:22px 24px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
#langModal .lh h3{font-size:1.3rem}
#langModal .lh button{width:38px;height:38px;border-radius:10px;border:1px solid var(--line-2);background:transparent;font-size:20px;cursor:pointer;color:var(--ink)}
#langModal .ls{padding:14px 24px}
#langModal .ls input{width:100%;padding:12px 14px;border:1.5px solid var(--line-2);border-radius:11px;font-size:15px;font-family:var(--sans);background:var(--panna)}
#langModal .ls input:focus{outline:none;border-color:var(--gold)}
#langModal .ll{overflow-y:auto;padding:6px 14px 18px;display:grid;grid-template-columns:1fr 1fr;gap:6px}
#langModal .ll button{display:flex;align-items:center;gap:11px;padding:12px 14px;border:1px solid transparent;border-radius:11px;background:transparent;cursor:pointer;font-family:var(--sans);font-size:15px;color:var(--char);text-align:left;transition:.18s}
#langModal .ll button:hover{background:var(--panna-2)}
#langModal .ll button.sel{border-color:var(--gold);background:var(--panna-2)}
#langModal .ll button .fl{font-size:20px}
#langModal .ll button .ck{margin-left:auto;color:var(--gold);font-weight:700}

/* ============ RESPONSIVE ============ */
@media(max-width:1080px){
  nav.main,.desk .btn-book-desk{display:none}
  .hamb{display:flex}
}
@media(max-width:860px){
  .split,.split.rev{grid-template-columns:1fr}
  .story-figs{max-width:440px;margin-inline:auto;order:-1}
  .story-figs .small{width:40%}
  .pillars{grid-template-columns:1fr;gap:14px;margin-top:34px}
  .dishes{grid-template-columns:1fr;gap:0}
  .contact-grid{grid-template-columns:1fr}
  .gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .menu-tabs{top:64px}
}
@media(max-width:768px){
  .hero .scroll{display:none}
  .hero .inner{padding-bottom:clamp(38px,10vw,64px)}
}
@media(max-width:640px){
  .brand .bw{display:none}
  .brand img{height:52px}
  header.site.solid .brand img{height:46px}
}
@media(max-width:560px){
  .hero .cta{width:100%;flex-direction:column}
  .hero .cta .btn{width:100%;justify-content:center}
  .fgrid{grid-template-columns:1fr}
  #langModal .ll{grid-template-columns:1fr}
  .rcard{flex-basis:300px}
  .gal .w2{grid-column:span 1}
  .brand .bw i{display:none}
  .story-figs .stamp{width:82px;height:82px;font-size:11px}
  .story-figs .stamp b{font-size:20px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero .bg img{animation:none}
  .ribbon .track,.rev-track{animation:scrollx 40s linear infinite!important}
}
