/*
Theme Name: Il Nonno
Theme URI: https://pizzeriailnonno.example
Author: Il Nonno
Description: Tema elegante y cálido para Pizzeria Il Nonno (Empuriabrava). Página única con carta, reseñas y reservas. Compatible con WordPress 6+.
Version: 1.6.0
License: GPL-2.0-or-later
Text Domain: ilnonno
*/

:root{
  --bg:#241a14;
  --bg-2:#241a14;
  --card:#241a14;
  --text:#f5ecdf;
  --muted:#bdae9c;
  --gold:#e6b860;
  --primary:#b3331f;
  --border:rgba(230,184,96,.18);
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-.01em;margin:0 0 .4em}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:.75rem;color:var(--gold);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase}
.eyebrow::before,.eyebrow::after{content:"";width:40px;height:1px;background:var(--gold);opacity:.6}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:14px 28px;font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;transition:all .25s;border:1px solid transparent;cursor:pointer}
.btn-gold{background:var(--gold);color:#241a14}
.btn-gold:hover{opacity:.9}
.btn-outline{border-color:var(--gold);color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:#241a14}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{opacity:.9}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(36,26,20,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;max-width:1280px;margin:0 auto}
.brand{display:inline-flex !important;flex-direction:column !important;align-items:flex-start !important;line-height:1;text-decoration:none;gap:.4rem}
.brand-name{display:block !important;font-family:var(--serif);font-size:1.5rem;color:var(--fg)}
.brand-name > span{color:var(--gold)}
.brand-city{display:inline-flex !important;align-items:center;gap:.35rem;font-size:.625rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.brand-pin{display:inline-block;animation:ilnonnoBounce 1.4s infinite;font-style:normal}
@keyframes ilnonnoBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.nav{display:none;gap:32px;font-size:.78rem;letter-spacing:.25em;text-transform:uppercase}
.nav a:hover{color:var(--gold)}
@media(min-width:768px){.nav{display:flex}}

/* Hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(36,26,20,.55),rgba(36,26,20,.4),var(--bg))}
.hero .inner{position:relative;z-index:2;max-width:780px;padding:0 24px}
.hero h1{font-size:clamp(2.6rem,6vw,5.5rem);line-height:1.05;margin-top:24px}
.hero h1 em{color:var(--gold);font-style:italic}
.hero p{margin:24px auto 36px;max-width:520px;color:#f5ecdfd9}
.hero .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Section */
section.block{padding:80px 0}
section.block.alt{background:transparent}
.section-head{text-align:center;margin-bottom:56px}
.section-head h2{font-size:clamp(2rem,4vw,3rem);margin-top:14px}

/* Categories */
.cats{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.cats{grid-template-columns:repeat(3,1fr)}}
.cat{position:relative;aspect-ratio:4/5;overflow:hidden;display:block}
.cat img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.cat:hover img{transform:scale(1.05)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,var(--bg),rgba(36,26,20,.2),transparent)}
.cat .label{position:absolute;left:0;right:0;bottom:0;padding:24px;text-align:center;z-index:2}
.cat .label small{color:var(--gold);text-transform:uppercase;letter-spacing:.25em;font-size:.7rem}
.cat .label h3{font-size:1.8rem;margin:8px 0 0}

/* Story */
.story{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:768px){.story{grid-template-columns:1fr 1fr}}
.story img{aspect-ratio:4/5;object-fit:cover;width:100%}
.story p{color:var(--muted);margin:0 0 14px}

/* Menu */
.menu-grid{display:grid;grid-template-columns:1fr;gap:28px 48px}
@media(min-width:768px){.menu-grid{grid-template-columns:1fr 1fr}}
.dish .row{display:flex;align-items:baseline;gap:12px}
.dish .name{font-family:var(--serif);font-size:1.18rem}
.dish .dots{flex:1;border-bottom:1px dotted rgba(255,255,255,.18);transform:translateY(-4px)}
.dish .price{color:var(--gold);font-weight:500}
.dish .desc{color:var(--muted);font-size:.92rem;margin:6px 0 0}
.note{text-align:center;color:var(--muted);font-style:italic;margin-top:32px}

/* Kids menu */
.kids{max-width:760px;margin:0 auto;background:var(--card);border:1px solid var(--border);padding:40px;text-align:center}
.kids .price{color:var(--gold);font-family:var(--serif);font-size:1.6rem;margin:6px 0 26px}
.kids-grid{display:grid;grid-template-columns:1fr;gap:22px;text-align:left}
@media(min-width:640px){.kids-grid{grid-template-columns:repeat(3,1fr)}}
.kids-grid h4{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:#f5ecdf;margin-bottom:6px}
.kids-grid p{color:var(--muted);font-size:.9rem;margin:0}

/* Reviews */
.reviews{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:768px){.reviews{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.reviews{grid-template-columns:repeat(3,1fr)}}
.review{background:var(--bg);border:1px solid var(--border);padding:28px;transition:border-color .25s}
.review:hover{border-color:rgba(230,184,96,.6)}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:10px}
.review p{font-style:italic;margin:0 0 18px}
.review small{color:var(--muted);text-transform:uppercase;letter-spacing:.25em;font-size:.7rem}

/* CTA */
.cta-band{padding:80px 24px;text-align:center;background:linear-gradient(135deg,#9c2d1d,#b3331f);color:#fff}
.cta-band h2{font-size:clamp(2rem,4vw,3rem);margin:14px 0 8px}
.cta-band p{opacity:.9;margin:0 0 28px}
.cta-band .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.info{display:flex;gap:16px;border-bottom:1px solid var(--border);padding-bottom:18px;margin-bottom:18px}
.info .ico{color:var(--gold);width:22px;flex:none;margin-top:4px}
.info small{display:block;color:var(--muted);text-transform:uppercase;letter-spacing:.25em;font-size:.7rem;margin-bottom:4px}
.info .val{font-family:var(--serif);font-size:1.15rem}
.map{aspect-ratio:1/1;border:1px solid var(--border);overflow:hidden}
.map iframe{width:100%;height:100%;border:0}

/* Footer */
.site-footer{margin-top:80px;border-top:1px solid var(--border);background:var(--card)}
.site-footer .grid{display:grid;grid-template-columns:1fr;gap:32px;padding:56px 0}
@media(min-width:768px){.site-footer .grid{grid-template-columns:repeat(3,1fr)}}
.site-footer h4{color:var(--gold);text-transform:uppercase;letter-spacing:.25em;font-size:.72rem;margin-bottom:10px;font-family:var(--sans);font-weight:500}
.site-footer p{color:var(--muted);margin:0 0 6px;font-size:.92rem}
.copyright{border-top:1px solid var(--border);padding:18px;text-align:center;color:var(--muted);font-size:.78rem}

/* Language switcher */
.header-right{display:flex;align-items:center;gap:14px}
.lang-switcher{position:relative}
.lang-btn{background:none;border:0;color:inherit;display:inline-flex;align-items:center;gap:6px;font:inherit;text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;cursor:pointer;padding:6px 8px}
.lang-btn:hover{color:var(--gold)}
.lang-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--card);border:1px solid var(--border);min-width:160px;list-style:none;margin:0;padding:4px 0;z-index:60}
.lang-menu li button{width:100%;text-align:left;background:none;border:0;color:inherit;padding:9px 14px;font:inherit;font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;cursor:pointer}
.lang-menu li button:hover{background:var(--bg);color:var(--gold)}
/* Hide Google Translate banner */
.goog-te-banner-frame.skiptranslate,#goog-gt-tt,.goog-te-balloon-frame{display:none!important}
body{top:0!important}
.goog-tooltip,.goog-tooltip:hover{display:none!important}
.goog-text-highlight{background:none!important;box-shadow:none!important}


/* ===== Wines ===== */
.wine-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:18px 28px;margin:30px auto 10px;font-size:.78rem;color:var(--muted);text-transform:none;letter-spacing:0}
.wine-legend-item{display:inline-flex;align-items:center;gap:8px}
.wine-legend-item strong{color:var(--fg);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;font-weight:500}
.wine-legend-desc{opacity:.85}
.wine-dot{display:inline-block;width:9px;height:9px;border-radius:50%}
.wine-cat{margin-top:30px}
.dish.wine .price{font-size:.92rem}
.wine-tag{color:var(--muted);text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;margin-right:4px;font-weight:400}
.wine-meta{display:flex;align-items:center;gap:14px;margin-top:6px;font-size:.85rem;color:var(--muted)}
.wine-region{font-style:italic}
.wine-style{display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.18em;font-size:.62rem}

/* ===== v1.4.0 — multi-page layout ===== */
.page-hero{padding:90px 0 40px;text-align:center;background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4rem);margin:14px 0 16px}
.page-hero p{color:var(--muted);max-width:640px;margin:0 auto}
.page-anchors{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:28px}
.page-anchors a{border:1px solid var(--border);padding:8px 16px;font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);transition:all .25s}
.page-anchors a:hover{border-color:var(--gold);color:var(--gold)}
.site-header .nav a.active{color:var(--gold)}
.site-header .nav a.active::after{content:"";display:block;height:1px;background:var(--gold);margin-top:4px}

/* ===== v1.5.0 — scroll reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease-out,transform .8s ease-out;will-change:opacity,transform}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ===== v1.6.0 — Premium visual layer ===== */

/* Layered shadows */
:root{
  --shadow-soft:0 6px 18px rgba(0,0,0,.18);
  --shadow-elegant:0 20px 50px -20px rgba(0,0,0,.55), 0 4px 16px rgba(0,0,0,.25);
  --shadow-warm:0 24px 60px -25px rgba(179,51,31,.45), 0 6px 18px rgba(0,0,0,.3);
  --shadow-gold:0 16px 40px -20px rgba(230,184,96,.45);
}

/* Subtle noise texture overlay on alt blocks */
.block.alt{position:relative;isolation:isolate}
.block.alt::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.9 0 0 0 0 0.72 0 0 0 0 0.37 0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.block.alt > *{position:relative;z-index:1}

/* Decorative section dividers (olive branch silhouette) */
.block + .block,
.block + .cta-band,
.cta-band + .block{position:relative}
.block + .block::before,
.block + .cta-band::before,
.cta-band + .block::before{
  content:"";display:block;width:140px;height:32px;margin:0 auto;opacity:.45;
  background-repeat:no-repeat;background-position:center;background-size:contain;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 140 32' fill='none' stroke='%23e6b860' stroke-width='1.1'><line x1='0' y1='16' x2='52' y2='16'/><line x1='88' y1='16' x2='140' y2='16'/><path d='M62 16 q4 -8 8 0 q-4 8 -8 0z' fill='%23e6b860' stroke='none'/><circle cx='70' cy='16' r='2' fill='%23e6b860' stroke='none'/><path d='M78 16 q-4 -8 -8 0 q4 8 8 0z' fill='%23e6b860' stroke='none'/></svg>");
  transform:translateY(-8px);
}

/* HERO — Ken Burns */
.hero{position:relative;overflow:hidden}
.hero .bg{transition:none}
.hero.kenburns .bg{
  animation: kenburns 26s ease-in-out infinite alternate;
  transform-origin:55% 45%;
  will-change:transform;
}
@keyframes kenburns{
  0%{transform:scale(1.04) translate(0,0)}
  100%{transform:scale(1.18) translate(-2%, -1.5%)}
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 30% 40%, rgba(0,0,0,0) 0%, rgba(0,0,0,.35) 70%, rgba(0,0,0,.55) 100%);
  z-index:1;
}
.hero .inner{position:relative;z-index:2}

/* Refined hover for buttons / cards / cats / dishes / images */
.btn{transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, background .25s, color .25s, border-color .25s}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.btn-gold:hover{box-shadow:var(--shadow-gold)}
.btn-wa:hover{box-shadow:0 14px 34px -16px rgba(37,211,102,.55)}

.cats .cat{transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s}
.cats .cat img{transition:transform 1s cubic-bezier(.2,.7,.2,1), filter .5s}
.cats .cat:hover{transform:translateY(-6px);box-shadow:var(--shadow-warm)}
.cats .cat:hover img{transform:scale(1.06);filter:brightness(1.04) saturate(1.08)}

.dish{transition:transform .35s ease, box-shadow .35s ease, border-color .35s}
.dish:hover{transform:translateY(-2px)}
.dish .price{transition:color .25s, transform .25s}
.dish:hover .price{color:var(--gold);transform:scale(1.04)}

.review{transition:transform .4s ease, box-shadow .4s ease}
.review:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}

.story img{transition:transform 1.2s cubic-bezier(.2,.7,.2,1), box-shadow .5s;box-shadow:var(--shadow-elegant)}
.story:hover img{transform:scale(1.03)}

/* Reveal variants */
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .9s ease-out, transform .9s ease-out}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .9s ease-out, transform .9s ease-out}
.reveal-zoom{opacity:0;transform:scale(.94);transition:opacity .9s ease-out, transform .9s ease-out}
.reveal-left.is-visible,.reveal-right.is-visible,.reveal-zoom.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal-left,.reveal-right,.reveal-zoom{opacity:1;transform:none;transition:none}
  .hero.kenburns .bg{animation:none}
}

/* ===== Stats section — "Nuestra historia en números" ===== */
.stats{padding:70px 0;background:linear-gradient(180deg,var(--bg-2),var(--bg));position:relative;overflow:hidden}
.stats::before,.stats::after{
  content:"";position:absolute;width:160px;height:160px;opacity:.08;pointer-events:none;
  background-repeat:no-repeat;background-size:contain;
}
.stats::before{
  top:20px;left:-20px;transform:rotate(-15deg);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='%2375a35a'><path d='M32 6 C20 18 18 36 32 58 C46 36 44 18 32 6 Z M32 14 L32 50' stroke='%23436c2c' stroke-width='1.4' fill='%2375a35a'/></svg>");
  animation:floatLeaf 9s ease-in-out infinite;
}
.stats::after{
  bottom:20px;right:-20px;transform:rotate(20deg);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%23e6b860' stroke-width='1.5'><path d='M32 4 Q34 16 32 30 Q30 16 32 4 M28 8 Q30 16 28 26 M36 8 Q34 16 36 26 M24 14 Q28 22 26 32 M40 14 Q36 22 38 32'/></svg>");
  animation:floatLeaf 11s ease-in-out infinite reverse;
}
@keyframes floatLeaf{
  0%,100%{transform:translateY(0) rotate(-15deg)}
  50%{transform:translateY(-10px) rotate(-10deg)}
}
.stats .container{position:relative;z-index:1}
.stats .stats-head{text-align:center;margin-bottom:40px}
.stats .stats-head h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.6rem);margin:10px 0 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;max-width:1000px;margin:0 auto}
.stat-card{text-align:center;padding:30px 18px;border:1px solid var(--border);background:rgba(255,255,255,.02);backdrop-filter:none;transition:transform .4s, box-shadow .4s, border-color .4s}
.stat-card:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:var(--shadow-gold)}
.stat-num{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--gold);line-height:1;font-weight:600}
.stat-suffix{color:var(--gold);font-family:var(--serif);font-size:1.6rem;margin-left:2px}
.stat-label{margin-top:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.22em;font-size:.7rem}
@media (max-width:780px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:18px}}

/* ===== Mobile off-canvas menu ===== */
.menu-toggle{display:none;position:relative;width:42px;height:42px;background:none;border:1px solid var(--border);cursor:pointer;padding:0;border-radius:2px;transition:border-color .25s, background .25s}
.menu-toggle:hover{border-color:var(--gold)}
.menu-toggle .bar{position:absolute;left:10px;right:10px;height:1.5px;background:var(--text);transition:transform .35s ease, top .35s ease, opacity .25s ease;border-radius:1px}
.menu-toggle .bar:nth-child(1){top:14px}
.menu-toggle .bar:nth-child(2){top:20px}
.menu-toggle .bar:nth-child(3){top:26px}
.menu-toggle[aria-expanded="true"] .bar:nth-child(1){top:20px;transform:rotate(45deg)}
.menu-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] .bar:nth-child(3){top:20px;transform:rotate(-45deg)}

.mobile-nav{position:fixed;inset:0;z-index:90;visibility:hidden;pointer-events:none}
.mobile-nav .backdrop{position:absolute;inset:0;background:rgba(15,10,7,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .4s ease}
.mobile-nav .panel{position:absolute;top:0;right:0;height:100%;width:min(82vw,360px);background:linear-gradient(170deg,var(--bg-2),var(--bg));border-left:1px solid var(--border);transform:translateX(105%);transition:transform .45s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;padding:80px 32px 32px;box-shadow:-30px 0 60px rgba(0,0,0,.4)}
.mobile-nav .panel::before{
  content:"";position:absolute;top:24px;left:32px;width:60px;height:2px;background:var(--gold);opacity:.6;
}
.mobile-nav a{display:block;padding:14px 0;font-family:var(--serif);font-size:1.5rem;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);opacity:0;transform:translateX(20px);transition:opacity .4s ease, transform .4s ease, color .25s}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav .panel .mn-cta{margin-top:auto;display:flex;flex-direction:column;gap:12px;opacity:0;transform:translateY(20px);transition:opacity .5s ease .35s, transform .5s ease .35s}
.mobile-nav.is-open{visibility:visible;pointer-events:auto}
.mobile-nav.is-open .backdrop{opacity:1}
.mobile-nav.is-open .panel{transform:translateX(0)}
.mobile-nav.is-open a{opacity:1;transform:none}
.mobile-nav.is-open a:nth-child(1){transition-delay:.15s}
.mobile-nav.is-open a:nth-child(2){transition-delay:.22s}
.mobile-nav.is-open a:nth-child(3){transition-delay:.29s}
.mobile-nav.is-open a:nth-child(4){transition-delay:.36s}
.mobile-nav.is-open .mn-cta{opacity:1;transform:none}

@media (max-width:900px){
  .site-header .nav{display:none}
  .site-header .header-right .btn{display:none}
  .menu-toggle{display:block}
}

/* ===== Floating CTA (WhatsApp + Phone) ===== */
.floating-cta{position:fixed;right:20px;bottom:20px;z-index:80;display:flex;flex-direction:column;gap:14px}
.floating-cta a{position:relative;width:56px;height:56px;padding:0;line-height:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;box-shadow:0 10px 28px rgba(0,0,0,.35);transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;overflow:visible;-webkit-tap-highlight-color:transparent}
.floating-cta a:hover{transform:translateY(-3px) scale(1.05)}
.floating-cta .fab-wa{background:#25D366}
.floating-cta .fab-wa:hover{box-shadow:0 14px 34px -8px rgba(37,211,102,.55)}
.floating-cta .fab-wa::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(37,211,102,.55);animation:pulseFab 2.4s ease-out infinite;pointer-events:none}
.floating-cta .fab-tel{background:var(--primary)}
.floating-cta a svg{width:28px;height:28px;display:block;margin:0;flex:none}
.floating-cta .fab-tel svg{fill:#fff}
@keyframes pulseFab{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.55)}
  70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}
}
@media (prefers-reduced-motion: reduce){
  .floating-cta .fab-wa::after{animation:none}
}

/* ===== Reviews carousel enhancement ===== */
.reviews.is-carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:24px;scroll-behavior:smooth;padding-bottom:12px;scrollbar-width:none}
.reviews.is-carousel::-webkit-scrollbar{display:none}
.reviews.is-carousel .review{flex:0 0 min(420px,85%);scroll-snap-align:center}
.reviews-wrap{position:relative}
.reviews-nav{display:flex;justify-content:center;gap:10px;margin-top:18px}
.reviews-nav button{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:1rem;transition:border-color .25s, color .25s, background .25s}
.reviews-nav button:hover{border-color:var(--gold);color:var(--gold)}

/* Decorative accent on reviews section corner */
.block:has(.reviews){position:relative}

/* Subtle scrollbar smoothing for anchor jumps with sticky offset */
html{scroll-padding-top:80px}

/* ============================================================
   Responsive polish (mobile-first fixes, desktop unchanged)
   ============================================================ */

/* Prevent any horizontal scroll on small screens */
html, body{overflow-x:hidden;max-width:100%}
img, video, iframe{max-width:100%;height:auto}

/* Mobile nav CTA buttons: full width, single line, balanced typography */
.mobile-nav .panel .mn-cta{width:100%}
.mobile-nav .panel .mn-cta .btn{
  display:flex;
  width:100%;
  justify-content:center;
  align-items:center;
  text-align:center;
  white-space:nowrap;
  padding:14px 16px;
  font-size:.7rem;
  letter-spacing:.18em;
  line-height:1.1;
  min-height:48px;
  box-sizing:border-box;
}
/* Auto-shrink type on narrow phones so the phone number stays on one line */
@media (max-width:380px){
  .mobile-nav .panel .mn-cta .btn{font-size:.62rem;letter-spacing:.12em;padding:14px 10px}
}
@media (max-width:340px){
  .mobile-nav .panel .mn-cta .btn{font-size:.56rem;letter-spacing:.08em;padding:13px 8px}
}

/* Mobile-wide refinements */
@media (max-width:640px){
  .container{padding:0 18px}
  .site-header .inner{padding:14px 18px}
  .hero h1{font-size:clamp(2rem, 9vw, 2.8rem);line-height:1.1}
  .hero p{font-size:1rem;margin:18px auto 28px;padding:0 6px}
  .hero .inner .btn{padding:13px 22px;font-size:.68rem;letter-spacing:.2em}

  h2{font-size:clamp(1.6rem, 6vw, 2rem)}
  h3{font-size:1.2rem}

  /* Generic buttons never break their label on phones */
  .btn{white-space:nowrap}

  /* Section paddings */
  .block, section.block{padding-left:0;padding-right:0}

  /* Page anchors / wine legend wrap nicely */
  .page-anchors{flex-wrap:wrap;gap:10px;justify-content:center}
  .page-anchors a{font-size:.66rem;letter-spacing:.18em;padding:8px 12px}
  .wine-legend{gap:12px 18px;font-size:.72rem;padding:0 8px}

  /* Kids menu padding compresses on phone */
  .kids{padding:28px 20px}

  /* Floating CTAs slightly smaller on phone, safe-area aware */
  .floating-cta{right:14px;bottom:calc(16px + env(safe-area-inset-bottom));gap:12px}
  .floating-cta a{width:52px;height:52px}
  .floating-cta a svg{width:26px;height:26px}

  /* Carta/menu items: prevent price from being pushed off-screen */
  .menu-item, .cat li{flex-wrap:wrap}

  /* Footer */
  .site-footer{padding-left:18px;padding-right:18px}
}

/* Extra-narrow phones (≤360px) — iPhone SE, Galaxy Fold cover */
@media (max-width:360px){
  .container{padding:0 14px}
  .hero h1{font-size:1.85rem}
  .brand-city{font-size:.55rem;letter-spacing:.22em}
}

/* Tablet sanity */
@media (min-width:641px) and (max-width:900px){
  .container{padding:0 28px}
}
