
@font-face{font-family:'DM Serif Display';src:url('fonts/dmserifdisplay-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'DM Serif Display';src:url('fonts/dmserifdisplay-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Karla';src:url('fonts/karla-var.woff2') format('woff2');font-weight:300 700;font-style:normal;font-display:swap}

:root{
  --panna:#faf6ee; --avorio:#f3ecdf; --crema:#fffdf8;
  --rosso:#8b1b1e; --rosso-l:#a82a2d; --rosso-d:#6f1518;
  --verde:#2f4a3d; --verde-l:#43614f;
  --ink:#2a201c; --ink-soft:#5b4d44; --muted:#857567;
  --line:#e6dccb; --line-d:#d8ccb6;
  --gold:#b88a3e;
  --shadow:0 18px 50px -24px rgba(80,40,20,.35);
  --shadow-sm:0 8px 26px -16px rgba(80,40,20,.30);
  --r:18px; --r-lg:26px; --maxw:1180px;
  --head-h:76px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden;scroll-padding-top:var(--head-h);-webkit-text-size-adjust:100%}
body{font-family:'Karla',system-ui,-apple-system,Segoe UI,sans-serif;background:var(--panna);color:var(--ink);
  line-height:1.65;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.serif{font-family:'DM Serif Display',Georgia,'Times New Roman',serif;font-weight:400;line-height:1.08;letter-spacing:.2px}
h1,h2,h3,h4,p,span,a,li{overflow-wrap:break-word}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
[hidden]{display:none!important}
::selection{background:var(--rosso);color:#fff}

/* texture sottile carta */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background:radial-gradient(1200px 600px at 80% -10%,rgba(184,138,62,.06),transparent 60%),
             radial-gradient(900px 500px at -10% 110%,rgba(47,74,61,.05),transparent 60%)}
main,header,footer{position:relative;z-index:1}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;font-weight:700;color:var(--rosso);
  display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--rosso);display:inline-block}
.sec{padding:clamp(56px,8vw,104px) 0}
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head h1,.sec-head h2{font-size:clamp(2rem,4.6vw,3.2rem);margin:.34em 0 .3em;color:var(--ink);font-family:'DM Serif Display',Georgia,serif;font-weight:400;line-height:1.08}
.sec-head p{color:var(--ink-soft);font-size:1.05rem}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:'Karla',sans-serif;font-weight:700;
  font-size:.98rem;padding:.82em 1.5em;border-radius:999px;cursor:pointer;border:1.6px solid transparent;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s;letter-spacing:.01em;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--rosso);color:#fff;box-shadow:0 12px 26px -14px rgba(139,27,30,.7)}
.btn-primary:hover{background:var(--rosso-d);box-shadow:0 16px 30px -12px rgba(139,27,30,.8)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-d)}
.btn-ghost:hover{border-color:var(--rosso);color:var(--rosso)}
.btn-green{background:var(--verde);color:#fff}
.btn-green:hover{background:var(--verde-l)}

/* ===== HEADER ===== */
header.site{position:fixed;top:0;left:0;right:0;z-index:60;height:var(--head-h);
  display:flex;align-items:center;transition:background .3s,box-shadow .3s,height .3s;
  background:rgba(250,246,238,0);backdrop-filter:blur(0)}
header.site.scrolled{background:rgba(250,246,238,.92);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--line),0 10px 30px -22px rgba(80,40,20,.5);height:66px}
.nav{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.brand{display:flex;align-items:center;gap:.6em;flex-shrink:0}
/* alone chiaro sottile dietro al logo: lo stacca dalla foto chiara dell'hero
   SENZA ricolorarlo (il logo resta rosso reale) */
.brand img{height:54px;width:auto;object-fit:contain;max-width:48vw;
  filter:drop-shadow(0 1px 1px rgba(255,250,244,.9)) drop-shadow(0 0 10px rgba(255,250,244,.55))}
header.site.scrolled .brand img{height:46px;filter:none}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{font-weight:600;font-size:.96rem;color:var(--ink);padding:.5em .8em;border-radius:10px;
  transition:color .2s,background .2s;position:relative}
.nav-links a:hover{color:var(--rosso)}
.nav-links a.active{color:var(--rosso)}
.nav-links a.active::after{content:"";position:absolute;left:.8em;right:.8em;bottom:.28em;height:2px;background:var(--rosso);border-radius:2px}
.nav-right{display:flex;align-items:center;gap:10px}
.lang-btn{display:inline-flex;align-items:center;gap:.4em;background:var(--crema);border:1.4px solid var(--line-d);
  border-radius:999px;padding:.42em .7em;min-height:44px;cursor:pointer;font-family:inherit;font-weight:700;font-size:.9rem;color:var(--ink);transition:border-color .2s,background .2s}
.lang-btn:hover{border-color:var(--rosso)}
.lang-btn .flag{font-size:1.05rem;line-height:1}
.lang-btn .chev{width:9px;height:9px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);margin-left:1px}
.nav-book{padding:.6em 1.2em!important}
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:0;cursor:pointer;padding:8px;min-width:44px;min-height:44px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;background:var(--panna);display:flex;flex-direction:column;
  padding:90px 28px 40px;transform:translateX(100%);transition:transform .4s cubic-bezier(.7,0,.2,1)}
.drawer.open{transform:translateX(0)}
.drawer a{font-family:'DM Serif Display',serif;font-size:1.8rem;padding:.45em 0;border-bottom:1px solid var(--line);color:var(--ink)}
.drawer a:active{color:var(--rosso)}
.drawer .dclose{position:absolute;top:22px;right:22px;background:none;border:0;font-size:2rem;color:var(--ink);cursor:pointer;line-height:1}
.drawer .dbook{margin-top:26px;color:#fff;border-bottom:0;text-align:center;justify-content:center}
.drawer a.dbook:active{color:#fff}

/* ===== INTRO (fondo panna, logo rosso reale ben leggibile) ===== */
.intro{position:fixed;inset:0;z-index:200;background:var(--panna);display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:16px;overflow:hidden}
.intro.done{animation:introOut .9s cubic-bezier(.7,0,.2,1) forwards}
@keyframes introOut{to{transform:translateY(-100%);opacity:1}}
.intro::after{content:"";position:absolute;inset:0;background:
  radial-gradient(700px 360px at 50% 38%,rgba(184,138,62,.10),transparent 70%);pointer-events:none}
.intro-logo{width:min(72vw,200px);opacity:0;transform:scale(.9) translateY(10px);
  animation:introLogo 1.1s .25s cubic-bezier(.2,.8,.2,1) forwards;filter:drop-shadow(0 14px 30px rgba(139,27,30,.18))}
@keyframes introLogo{to{opacity:1;transform:scale(1) translateY(0)}}
.intro-plate{position:relative;width:108px;height:108px;margin-bottom:4px}
.intro-plate .ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(139,27,30,.18);
  border-top-color:var(--rosso);animation:spin 1.1s linear infinite}
.intro-steam{position:absolute;left:50%;bottom:60%;transform:translateX(-50%);display:flex;gap:9px}
.intro-steam i{width:5px;height:30px;border-radius:5px;background:linear-gradient(to top,rgba(139,27,30,0),rgba(139,27,30,.42));
  animation:steam 1.6s ease-in-out infinite}
.intro-steam i:nth-child(2){animation-delay:.3s;height:40px}
.intro-steam i:nth-child(3){animation-delay:.6s}
@keyframes steam{0%{opacity:0;transform:translateY(8px) scaleY(.6)}40%{opacity:.8}100%{opacity:0;transform:translateY(-16px) scaleY(1.1)}}
@keyframes spin{to{transform:rotate(360deg)}}
.intro-cap{color:var(--rosso);font-family:'DM Serif Display',serif;font-size:1.35rem;letter-spacing:.06em;opacity:0;
  animation:introLogo 1s .55s forwards}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:var(--head-h);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:kb 18s ease-in-out infinite alternate}
@keyframes kb{to{transform:scale(1.16) translateY(-2%)}}
/* scrim FORTE multi-strato: il testo (eyebrow+titolo in ALTO) resta leggibile
   ovunque cada sulla foto chiara — top scuro + lato sinistro + base scura */
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(28,18,14,.74) 0%,rgba(28,18,14,.46) 22%,rgba(28,18,14,.30) 46%,rgba(28,18,14,.52) 78%,rgba(28,18,14,.78) 100%),
  linear-gradient(100deg,rgba(28,18,14,.80) 0%,rgba(28,18,14,.55) 40%,rgba(28,18,14,.22) 72%,rgba(28,18,14,.10) 100%)}
.hero-inner{position:relative;z-index:2;max-width:680px;color:#fff;padding:40px 0}
.hero .eyebrow{color:#ffe0bb;text-shadow:0 2px 12px rgba(0,0,0,.7)}
.hero .eyebrow::before{background:#ffe0bb}
.hero h1{font-size:clamp(2.5rem,6.2vw,4.7rem);margin:.3em 0 .42em;color:#fff;text-shadow:0 3px 18px rgba(0,0,0,.7),0 1px 2px rgba(0,0,0,.5)}
.hero p.lead{font-size:clamp(1.04rem,2vw,1.22rem);color:#f6ece1;max-width:48ch;margin-bottom:2em;line-height:1.6;text-shadow:0 2px 14px rgba(0,0,0,.65)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;margin-top:2.6em;flex-wrap:wrap}
.hero-stats .st{display:flex;flex-direction:column}
.hero-stats .st b{font-family:'DM Serif Display',serif;font-size:2.1rem;color:#ffe0bb;line-height:1;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.hero-stats .st span{font-size:.82rem;letter-spacing:.04em;color:#f0e2d4;margin-top:.3em;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.hero-stars{color:#ffc857}

/* ===== TWIN (ristorante / pizzeria) ===== */
.twin{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.twin-card{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:430px;display:flex;align-items:flex-end;
  box-shadow:var(--shadow);isolation:isolate}
.twin-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .8s}
.twin-card:hover img{transform:scale(1.06)}
.twin-card::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(30,18,14,.92),rgba(30,18,14,.35) 55%,rgba(30,18,14,.05))}
.twin-body{padding:34px 32px;color:#fff}
.twin-body .k{color:#ffd9b0}
.twin-body h3{font-size:2rem;margin:.25em 0 .4em;color:#fff}
.twin-body p{color:#efe2d6;font-size:1rem;margin-bottom:1.2em;max-width:42ch}
.twin-body .lnk{color:#fff;font-weight:700;border-bottom:2px solid #ffd9b0;padding-bottom:2px;font-size:.96rem}
.twin-body .lnk:hover{color:#ffd9b0}

/* ===== SIGNATURE cards (home) ===== */
.sign-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}
.sign{background:var(--crema);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .35s,box-shadow .35s}
.sign:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.sign figure{aspect-ratio:4/3;position:relative;overflow:hidden}
.sign figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}
.sign:hover figure img{transform:scale(1.07)}
.sign .si{padding:18px 20px 22px}
.sign .si b{font-family:'DM Serif Display',serif;font-size:1.32rem;display:block;color:var(--ink)}
.sign .si .pr{color:var(--rosso);font-weight:700;margin-top:.3em;display:inline-block}

/* ===== STORY band ===== */
.story{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.story-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5}
.story-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.story-media .badge{position:absolute;left:18px;bottom:18px;background:var(--rosso);color:#fff;border-radius:14px;
  padding:14px 18px;box-shadow:var(--shadow-sm)}
.story-media .badge b{font-family:'DM Serif Display',serif;font-size:1.7rem;display:block;line-height:1}
.story-media .badge span{font-size:.78rem;letter-spacing:.05em;opacity:.92}
.story h1,.story h2{font-size:clamp(1.9rem,4vw,2.9rem);margin:.3em 0 .5em;font-family:'DM Serif Display',Georgia,serif;font-weight:400;line-height:1.08}
.story p{color:var(--ink-soft);margin-bottom:1.4em;font-size:1.05rem}

/* hours card */
.hours-card{background:var(--crema);border:1px solid var(--line);border-radius:var(--r);padding:26px 28px;box-shadow:var(--shadow-sm)}
.hours-card h3{font-size:1.4rem;margin-bottom:.6em;color:var(--ink)}
.hrow{display:flex;justify-content:space-between;gap:14px;padding:.5em 0;border-bottom:1px dashed var(--line);font-size:.96rem}
.hrow:last-child{border-bottom:0}
.hrow .d{color:var(--ink);font-weight:600}
.hrow .h{color:var(--ink-soft);text-align:right}
.hrow.today{color:var(--rosso)}
.hrow.today .d,.hrow.today .h{color:var(--rosso);font-weight:700}
.hours-note{color:var(--muted);font-size:.86rem;margin-top:.9em}

/* ===== MENU page ===== */
.menu-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:34px;position:sticky;top:var(--head-h);z-index:30;
  background:var(--panna);padding:14px 0;border-bottom:1px solid var(--line)}
.menu-tab{font-family:'Karla',sans-serif;font-weight:700;font-size:.92rem;padding:.6em 1.15em;border-radius:999px;
  border:1.5px solid var(--line-d);background:var(--crema);color:var(--ink-soft);cursor:pointer;transition:.22s}
.menu-tab:hover{border-color:var(--rosso);color:var(--rosso)}
.menu-tab.active{background:var(--rosso);color:#fff;border-color:var(--rosso)}
.menu-group{margin-bottom:46px;scroll-margin-top:140px}
.menu-group h3{font-size:1.7rem;color:var(--rosso);display:flex;align-items:center;gap:.6em;margin-bottom:.7em}
.menu-group h3::after{content:"";flex:1;height:1px;background:var(--line-d)}
.menu-item{display:flex;align-items:baseline;gap:10px;padding:.62em 0;border-bottom:1px dotted var(--line)}
.menu-item:last-child{border-bottom:0}
.menu-item .nm{font-weight:600;color:var(--ink);font-size:1.02rem}
.menu-item .dots{flex:1;border-bottom:1.5px dotted var(--line-d);transform:translateY(-3px);min-width:18px}
.menu-item .pr{font-weight:700;color:var(--rosso);white-space:nowrap;font-size:1rem}
.menu-note{background:var(--avorio);border-left:3px solid var(--gold);border-radius:0 12px 12px 0;padding:14px 18px;
  color:var(--ink-soft);font-size:.95rem;margin-bottom:30px}
/* lascia spazio al FAB sulle righe prezzo (evita sovrapposizione bottom-right) */
@media(max-width:1320px){ .menu-group{padding-right:64px} }
@media(max-width:560px){ .menu-group{padding-right:0} }

/* ===== GALLERY ===== */
.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:14px}
.gal figure{position:relative;aspect-ratio:1/1;border-radius:16px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm)}
.gal figure.tall{aspect-ratio:3/4}
.gal figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}
.gal figure:hover img{transform:scale(1.08)}
.gal figure figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 14px 12px;color:#fff;font-size:.9rem;font-weight:600;
  background:linear-gradient(to top,rgba(20,12,9,.85),transparent);opacity:0;transform:translateY(6px);transition:.3s}
.gal figure:hover figcaption{opacity:1;transform:translateY(0)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(20,12,9,.92);display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;transition:opacity .3s}
.lightbox.show{opacity:1}
.lightbox:not(.show){pointer-events:none}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox .lbclose,.lightbox .lbnav{position:absolute;background:rgba(255,255,255,.12);border:0;color:#fff;cursor:pointer;
  width:50px;height:50px;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox .lbclose:hover,.lightbox .lbnav:hover{background:rgba(255,255,255,.25)}
.lightbox .lbclose{top:20px;right:20px}
.lightbox .lbprev{left:18px;top:50%;transform:translateY(-50%)}
.lightbox .lbnext{right:18px;top:50%;transform:translateY(-50%)}

/* ===== REVIEWS ===== */
.rev-agg{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:36px}
.rev-score{font-family:'DM Serif Display',serif;font-size:3.4rem;color:var(--rosso);line-height:1}
.rev-meta .stars{color:#ffba2b;font-size:1.2rem;letter-spacing:2px}
.rev-meta small{color:var(--muted);display:block;margin-top:.2em}
.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)}
.mtrack{display:flex;gap:18px;width:max-content;animation:marq 60s linear infinite}
.marquee:hover .mtrack{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev-card{flex:0 0 340px;width:340px;background:var(--crema);border:1px solid var(--line);border-radius:var(--r);
  padding:22px 24px;box-shadow:var(--shadow-sm)}
.rev-card .top{display:flex;align-items:center;gap:12px;margin-bottom:.7em}
.rev-card .av{width:42px;height:42px;border-radius:50%;background:var(--rosso);color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:1.15rem;flex-shrink:0}
.rev-card .nm{font-weight:700;font-size:.96rem;color:var(--ink)}
.rev-card .dt{font-size:.78rem;color:var(--muted)}
.rev-card .rstars{color:#ffba2b;font-size:.9rem;letter-spacing:1.5px;margin-bottom:.5em}
.rev-card p{font-size:.95rem;color:var(--ink-soft);line-height:1.55}
.rev-card .src{font-size:.74rem;color:var(--muted);margin-top:.8em;letter-spacing:.04em}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start}
.ci{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.ci:last-child{border-bottom:0}
.ci .ico{width:42px;height:42px;border-radius:12px;background:var(--avorio);color:var(--rosso);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci .ico svg{width:20px;height:20px}
.ci .lab{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.ci .val{font-size:1.05rem;color:var(--ink);font-weight:600}
.ci .val a:hover{color:var(--rosso)}
.book-box{background:var(--rosso);color:#fff;border-radius:var(--r-lg);padding:32px 30px;box-shadow:var(--shadow)}
.book-box h3{font-size:1.7rem;margin-bottom:.4em;color:#fff}
.book-box p{color:#f6dcd6;margin-bottom:1.3em}
.book-box .bbtns{display:flex;gap:12px;flex-wrap:wrap}
.book-box .btn-ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.book-box .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.map-wrap{margin-top:14px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.map-wrap iframe{width:100%;height:340px;border:0;display:block}

/* ===== FAQ ===== */
.faq-list{max-width:820px}
.faq-item{border:1px solid var(--line);border-radius:16px;background:var(--crema);margin-bottom:12px;overflow:hidden;
  box-shadow:var(--shadow-sm)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:inherit;
  padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:700;font-size:1.05rem;color:var(--ink)}
.faq-q .ic{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:1.6px solid var(--rosso);color:var(--rosso);
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:transform .3s}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 22px 20px;color:var(--ink-soft);font-size:1rem}

/* ===== FOOTER ===== */
footer.site{background:var(--ink);color:#e8dccf;padding:60px 0 28px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
.foot-brand img{height:52px;margin-bottom:14px;filter:none}
.foot-brand p{color:#bcaa99;font-size:.95rem;max-width:34ch}
.foot-col h4{font-family:'Karla',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;margin-bottom:1em}
.foot-col a,.foot-col p{display:block;color:#cbbcac;font-size:.95rem;padding:.22em 0;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-social{display:flex;gap:10px;margin-top:.4em}
.foot-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;padding:0}
.foot-social a:hover{background:var(--rosso)}
.foot-social svg{width:18px;height:18px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:22px;display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;color:#9c8b7c;font-size:.85rem}

/* ===== LANG MODAL ===== */
.lang-ov{position:fixed;inset:0;z-index:140;display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(30,18,14,.4);backdrop-filter:blur(3px);opacity:0;transition:opacity .25s}
.lang-ov.show{opacity:1}
.lang-ov:not(.show){pointer-events:none}
.lang-dialog{background:var(--crema);border-radius:26px;width:100%;max-width:400px;max-height:min(520px,86vh);
  display:flex;flex-direction:column;box-shadow:0 40px 100px -30px rgba(0,0,0,.5);overflow:hidden;
  transform:scale(.95);filter:blur(4px);opacity:0;transition:transform .3s,filter .3s,opacity .3s}
.lang-ov.show .lang-dialog{transform:scale(1);filter:blur(0);opacity:1}
.lang-h{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 14px}
.lang-h h3{font-size:1.5rem;color:var(--ink)}
.lang-h button{background:var(--avorio);border:0;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1.2rem;color:var(--ink-soft);transition:.2s}
.lang-h button:hover{background:var(--rosso);color:#fff}
.lang-search{margin:0 22px 12px;display:flex;align-items:center;gap:8px;background:var(--avorio);border-radius:12px;padding:.6em .9em}
.lang-search input{border:0;background:none;outline:0;font-family:inherit;font-size:.98rem;width:100%;color:var(--ink)}
.lang-list{overflow-y:auto;padding:0 14px 16px;display:flex;flex-direction:column;gap:2px}
.lang-list::-webkit-scrollbar{width:8px}.lang-list::-webkit-scrollbar-thumb{background:var(--line-d);border-radius:8px}
.lang-row{display:flex;align-items:center;gap:12px;padding:.7em .8em;border-radius:12px;cursor:pointer;border:0;background:none;
  font-family:inherit;font-size:1rem;width:100%;text-align:left;color:var(--ink);transition:background .15s}
.lang-row:hover{background:var(--avorio)}
.lang-row.active{background:var(--avorio)}
.lang-row .flag{font-size:1.3rem}
.lang-row .nm{flex:1;font-weight:600}
.lang-row .ck{color:var(--rosso);font-weight:700;opacity:0}
.lang-row.active .ck{opacity:1}

/* FAB */
.fab{position:fixed;right:18px;bottom:18px;z-index:90;display:flex;flex-direction:column;gap:12px;transition:transform .4s,opacity .4s}
.fab.hide{transform:translateY(120px);opacity:0;pointer-events:none}
.fab a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 26px -8px rgba(0,0,0,.4);transition:transform .25s}
.fab a:hover{transform:scale(1.08)}
.fab .wa{background:#25d366}.fab .tel{background:var(--rosso)}
.fab svg{width:26px;height:26px;fill:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}[data-d="3"]{transition-delay:.24s}[data-d="4"]{transition-delay:.32s}

/* RTL */
html[dir="rtl"] .eyebrow::before{margin-left:0}
html[dir="rtl"] .nav-links a.active::after{left:.8em;right:.8em}
html[dir="rtl"] body{font-family:'Karla','Segoe UI',Tahoma,sans-serif}
html[dir="rtl"] .menu-item .pr,html[dir="rtl"] .ci .val{direction:ltr;unicode-bidi:embed}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .twin{grid-template-columns:1fr}
  .story{grid-template-columns:1fr}.story-media{aspect-ratio:16/10;max-height:420px}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:820px){
  .nav-links{display:none}
  .burger{display:flex}
  .nav-book{display:none}
}
@media(max-width:560px){
  body{font-size:16px}
  .hero-stats{gap:22px}
  .hero-stats .st b{font-size:1.7rem}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .foot-bottom{flex-direction:column;gap:6px}
  .rev-card{flex-basis:280px;width:280px}
  .gal{grid-template-columns:1fr 1fr}
  .menu-tabs{top:60px}
}
@media(max-width:380px){
  .brand img{height:46px}
  .gal{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero-bg img{animation:none}
  .mtrack{animation:marq 60s linear infinite!important}
}
