/* ─── VARIABLES ─── */
:root {
  --bg: #0a0a0a;
  --bg2: #111;
  --bg3: #1a1814;
  --gold: #c8a04a;
  --gold2: #f0c040;
  --gold-dim: rgba(200,160,74,.15);
  --red: #8b1a1a;
  --red2: #c0392b;
  --text: #e8e0d0;
  --text2: #a09880;
  --border: rgba(200,160,74,.25);
  --font-title: 'Cinzel Decorative', serif;
  --font-sub: 'Cinzel', serif;
  --font-body: 'Crimson Pro', serif;
  --font-mono: 'Space Mono', monospace;
  --radius: 4px;
  --transition: .3s ease;
}

/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:1.1rem;line-height:1.7;overflow-x:hidden;cursor:none}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:none;border:none;background:none;font-family:inherit}

/* ─── GRAIN ─── */
.grain-overlay{pointer-events:none;position:fixed;inset:0;z-index:9999;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}

/* ─── CURSOR ─── */
.cursor-dot{position:fixed;width:8px;height:8px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:transform .1s,opacity .2s}
.cursor-ring{position:fixed;width:32px;height:32px;border:1.5px solid var(--gold);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:transform .15s,width .2s,height .2s,opacity .2s}
.cursor-ring.hover{width:48px;height:48px;border-color:var(--gold2)}
.cursor-ring.clicking{transform:translate(-50%,-50%) scale(.8)}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}

/* ─── NAVBAR — mobile first ─── */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.75rem 1.25rem;transition:background var(--transition),backdrop-filter var(--transition),border-bottom var(--transition)}
@media(min-width:900px){#navbar{padding:1rem 2rem}}
#navbar.scrolled{background:rgba(10,10,10,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center}
.logo-img{height:44px;width:auto;transition:filter var(--transition),transform var(--transition)}
@media(min-width:900px){.logo-img{height:56px}}
.logo-img:hover{filter:brightness(1.2) drop-shadow(0 0 8px rgba(200,160,74,.6));transform:scale(1.04)}
/* Desktop nav links — hidden by default (mobile) */
.nav-links{display:none;align-items:center;gap:2rem}
@media(min-width:900px){.nav-links{display:flex}}
.nav-link{font-family:var(--font-sub);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text2);transition:color var(--transition);position:relative}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width var(--transition)}
.nav-link:hover{color:var(--gold)}
.nav-link:hover::after{width:100%}
.nav-cta{background:var(--gold);color:var(--bg)!important;padding:.45rem 1.2rem;border-radius:var(--radius);font-weight:700;transition:background var(--transition),transform var(--transition)}
.nav-cta:hover{background:var(--gold2);transform:translateY(-1px)}
.nav-cta::after{display:none}
/* Hamburger — visible by default (mobile), hidden on desktop */
.hamburger{display:flex;flex-direction:column;gap:5px;padding:4px;z-index:1001}
@media(min-width:900px){.hamburger{display:none}}
.hamburger span{display:block;width:26px;height:2px;background:var(--gold);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:flex;position:fixed;inset:0;background:rgba(10,10,10,.97);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity var(--transition)}
.mobile-menu.open{opacity:1;pointer-events:all}
.mob-link{font-family:var(--font-sub);font-size:1.4rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text);transition:color var(--transition)}
.mob-link:hover{color:var(--gold)}
.mob-cta{color:var(--gold)!important;border:1px solid var(--gold);padding:.6rem 2rem;border-radius:var(--radius)}

/* ─── BUTTONS ─── */
.btn-gold{display:inline-flex;align-items:center;gap:.5rem;background:var(--gold);color:var(--bg);font-family:var(--font-sub);font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.75rem 2rem;border-radius:var(--radius);transition:background var(--transition),transform var(--transition),box-shadow var(--transition)}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,160,74,.3)}
.btn-gold span{transition:transform var(--transition)}
.btn-gold:hover span{transform:translateX(4px)}
.btn-outline{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--border);color:var(--text);font-family:var(--font-sub);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;padding:.75rem 2rem;border-radius:var(--radius);transition:border-color var(--transition),color var(--transition),transform var(--transition)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn-outline-sm{display:inline-flex;align-items:center;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;padding:.4rem 1rem;border-radius:var(--radius);margin-top:.75rem;transition:border-color var(--transition),color var(--transition)}
.btn-outline-sm:hover{border-color:var(--gold);color:var(--gold)}
.btn-whatsapp{display:inline-flex;align-items:center;gap:.75rem;background:#25d366;color:#fff;font-family:var(--font-sub);font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.85rem 2rem;border-radius:var(--radius);transition:background var(--transition),transform var(--transition),box-shadow var(--transition);width:100%;justify-content:center;margin-bottom:.75rem}
.btn-whatsapp:hover{background:#1da851;transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,.3)}

/* ─── SECTION COMMONS — mobile first ─── */
.section{padding:3.5rem 1.25rem;max-width:1200px;margin:0 auto}
@media(min-width:768px){.section{padding:6rem 2rem}}
.ornament{text-align:center;color:var(--gold);letter-spacing:.5em;font-size:.7rem;margin-bottom:1.5rem;opacity:.6}
.section-title{font-family:var(--font-title);font-size:clamp(1.8rem,6vw,3.5rem);text-align:center;color:var(--text);margin-bottom:.75rem;line-height:1.1}
.section-sub{text-align:center;font-family:var(--font-sub);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text2);margin-bottom:2rem}
@media(min-width:768px){.section-sub{font-size:.85rem;margin-bottom:3rem}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ─── TITLE SWEEP (sostituisce glitch) ─── */
.glitch{position:relative;display:inline-block}
.glitch::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold2),transparent);transition:width 1s cubic-bezier(.77,0,.175,1);border-radius:1px}
.glitch.visible::after{width:100%}
.glitch-active::after{width:100%!important}

/* ─── HERO ─── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg)}
.hero-bg{position:absolute;inset:0;background-image:url('../assets/hero_bg.png');background-size:cover;background-position:center;opacity:.22;filter:grayscale(30%) contrast(1.2)}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,.3) 0%,rgba(10,10,10,.7) 60%,var(--bg) 100%)}
.steam-wrap{position:absolute;inset:0;pointer-events:none;z-index:1}
.steam-particle{position:absolute;bottom:40%;border-radius:50%;background:radial-gradient(circle,rgba(200,160,74,.12) 0%,transparent 70%);animation:steamRise var(--dur,8s) ease-out infinite;opacity:0}
@keyframes steamRise{0%{opacity:0;transform:translateY(0) scale(1)}30%{opacity:1}100%{opacity:0;transform:translateY(-200px) scale(3)}}
.tracks-wrap{position:absolute;bottom:0;left:0;right:0;height:80px;z-index:1}
.track{position:absolute;bottom:20px;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.4}
.track-1{bottom:30px}
.track-2{bottom:18px}
.track-ties{position:absolute;bottom:14px;left:0;right:0;height:18px}
.tie{position:absolute;bottom:0;width:30px;height:18px;background:rgba(200,160,74,.2);border-radius:2px}
.hero-content{position:relative;z-index:2;text-align:center;padding:2rem}
.hero-est{font-family:var(--font-sub);font-size:.8rem;letter-spacing:.4em;color:var(--gold);margin-bottom:1.5rem;opacity:.8}
.hero-title{font-family:var(--font-title);font-size:clamp(2.8rem,8vw,6rem);line-height:1;margin-bottom:1rem;text-shadow:0 0 60px rgba(200,160,74,.2)}
.ht-top{display:block;color:var(--text);font-size:.65em;letter-spacing:.05em}
.ht-main{display:block;color:var(--gold);background:linear-gradient(135deg,#c8a04a,#f0c040,#c8a04a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-tagline{font-family:var(--font-sub);font-size:clamp(.9rem,2vw,1.3rem);letter-spacing:.4em;text-transform:uppercase;color:var(--text2);margin-bottom:.75rem}
.hero-beer{font-family:var(--font-body);font-style:italic;font-size:1.2rem;color:var(--text2);margin-bottom:2.5rem}
#rotatingBeer{color:var(--gold);font-style:normal;transition:opacity .4s}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.status-bar{position:absolute;bottom:6rem;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:.6rem;background:rgba(10,10,10,.7);border:1px solid var(--border);padding:.4rem 1.2rem;border-radius:2rem;font-family:var(--font-sub);font-size:.75rem;letter-spacing:.1em;white-space:nowrap;z-index:2}
.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.status-dot.open{background:#4caf50;box-shadow:0 0 8px #4caf50}
.status-dot.closed{background:var(--red2);box-shadow:0 0 8px var(--red2)}
.scroll-hint{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-family:var(--font-sub);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text2);opacity:.5;animation:bob 2s ease-in-out infinite;z-index:2}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent)}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ─── LEGGENDA ─── */
.leggenda-section{padding-top:5rem}
@media(min-width:900px){.leggenda-section{padding-top:7rem}}
.lead-text{font-size:1.3rem;line-height:1.8;color:var(--text);margin-bottom:1.5rem}
.lead-text em{color:var(--gold);font-style:normal}
.leggenda-text p{color:var(--text2);margin-bottom:1rem;font-size:1.05rem}
.timeline{margin-top:3rem;position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:.5rem;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold),transparent)}
.tl-item{position:relative;margin-bottom:2rem;padding-left:2rem}
.tl-year{font-family:var(--font-mono);font-size:.8rem;color:var(--gold);letter-spacing:.1em;margin-bottom:.25rem}
.tl-dot{position:absolute;left:-1.6rem;top:.1rem;width:12px;height:12px;border-radius:50%;border:2px solid var(--gold);background:var(--bg)}
.tl-dot--gold{background:var(--gold)}
.tl-text{color:var(--text2);font-size:1rem}
.leggenda-img{position:relative}
.leggenda-img img{border-radius:var(--radius);opacity:.85;filter:sepia(.2) contrast(1.1)}
.img-frame{position:absolute;inset:-8px;border:1px solid var(--border);border-radius:var(--radius);pointer-events:none}
.img-frame::before{content:'◆';position:absolute;top:-8px;left:-8px;width:16px;height:16px;background:var(--bg);color:var(--gold);font-size:.6rem;display:flex;align-items:center;justify-content:center}
.img-frame::after{content:'◆';position:absolute;bottom:-8px;right:-8px;width:16px;height:16px;background:var(--bg);color:var(--gold);font-size:.6rem;display:flex;align-items:center;justify-content:center}

/* menu styles → see mobile-first section below */

/* birre styles → see mobile-first section below */
.birre-section{background:var(--bg)}

/* ─── TAPPO ─── */
.tappo-section{background:linear-gradient(180deg,var(--bg) 0%,var(--bg3) 50%,var(--bg) 100%);text-align:center}
.tappo-wrap{display:flex;flex-direction:column;align-items:center;gap:2rem}
.tappo-cap{width:clamp(140px,40vw,180px);height:clamp(140px,40vw,180px);border-radius:50%;background:radial-gradient(circle at 35% 35%,#2a2620,#1a1410);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:transform var(--transition),box-shadow var(--transition);box-shadow:0 0 0 3px var(--gold),0 0 30px rgba(200,160,74,.15),inset 0 2px 4px rgba(255,255,255,.05)}
.tappo-cap:hover{box-shadow:0 0 0 3px var(--gold2),0 0 50px rgba(200,160,74,.3),inset 0 2px 4px rgba(255,255,255,.08);transform:scale(1.06) rotate(5deg)}
.tappo-cap:active{transform:scale(.95)}
.tappo-cap.spinning{animation:tappoSpin 1s cubic-bezier(.36,.07,.19,.97) both}
@keyframes tappoSpin{0%{transform:rotate(0) scale(1)}20%{transform:rotate(180deg) scale(1.1)}80%{transform:rotate(640deg) scale(1.05)}100%{transform:rotate(720deg) scale(1)}}
.cap-inner{width:85%;height:85%;display:flex;align-items:center;justify-content:center}
.cap-inner svg{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}
/* Crown serrations via clip-path — pure CSS */
.tappo-result{max-width:min(420px,90vw);background:var(--bg3);border:1px solid var(--gold);border-radius:var(--radius);padding:1.75rem;display:none;margin:0 auto}
.tappo-result.show{display:block;animation:fadeInUp .4s ease}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.tappo-result-emoji{font-size:2.5rem;margin-bottom:.5rem}
.tappo-result-name{font-family:var(--font-sub);font-size:1.15rem;color:var(--gold);margin-bottom:.5rem}
.tappo-result-desc{color:var(--text2);font-size:.95rem;line-height:1.6}

/* ─── BEER SELECTOR QUIZ ─── */
.selector-section{background:var(--bg);text-align:center}
.quiz-wrap{max-width:600px;margin:0 auto}
.quiz-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem;margin-bottom:1.5rem}
.quiz-q{font-family:var(--font-sub);font-size:1.15rem;color:var(--text);margin-bottom:1.5rem;line-height:1.5}
.quiz-options{display:grid;gap:.75rem}
.quiz-opt{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-body);font-size:1rem;padding:.85rem 1.2rem;border-radius:var(--radius);text-align:left;transition:all var(--transition)}
.quiz-opt:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.quiz-progress{height:2px;background:var(--border);border-radius:1px;margin-top:1.5rem;overflow:hidden}
.quiz-bar{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:1px;transition:width .4s ease}
.quiz-result{background:var(--bg3);border:1px solid var(--gold);border-radius:var(--radius);padding:2.5rem;display:none}
.quiz-result.show{display:block;animation:fadeInUp .4s ease}
.quiz-result-emoji{font-size:3rem;margin-bottom:1rem}
.quiz-result-name{font-family:var(--font-sub);font-size:1.5rem;color:var(--gold);margin-bottom:.5rem}
.quiz-result-style{font-family:var(--font-mono);font-size:.8rem;color:var(--text2);margin-bottom:1rem;letter-spacing:.05em}
.quiz-result-desc{color:var(--text2);font-size:1rem;margin-bottom:1.5rem}
.quiz-retry{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.8rem;letter-spacing:.1em;padding:.5rem 1.2rem;border-radius:var(--radius);transition:all var(--transition)}
.quiz-retry:hover{border-color:var(--gold);color:var(--gold)}

/* ─── PASSPORT ─── */
.passport-section{background:linear-gradient(180deg,var(--bg) 0%,var(--bg3) 50%,var(--bg) 100%)}
.passport-wrap{max-width:800px;margin:0 auto}
.passport-book{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:2rem}
.passport-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.passport-title{font-family:var(--font-sub);font-size:1rem;color:var(--text);letter-spacing:.1em}
.passport-count{font-family:var(--font-mono);font-size:.85rem;color:var(--gold)}
/* passport-beers grid → mobile-first section */
.pp-beer{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);user-select:none}
.pp-beer:hover{border-color:var(--gold);background:var(--gold-dim)}
.pp-beer.checked{border-color:#4caf50;background:rgba(76,175,80,.08)}
.pp-beer-check{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem;transition:all var(--transition)}
.pp-beer.checked .pp-beer-check{background:#4caf50;border-color:#4caf50;color:#fff}
.pp-beer-name{font-family:var(--font-sub);font-size:.8rem;color:var(--text2);transition:color var(--transition)}
.pp-beer.checked .pp-beer-name{color:var(--text)}
.passport-badges{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;padding-top:1.5rem;border-top:1px solid var(--border)}
.badge{text-align:center;padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius);min-width:90px;transition:all var(--transition);opacity:.4}
.badge.unlocked{border-color:var(--gold);opacity:1;background:var(--gold-dim)}
.badge-icon{font-size:1.8rem;margin-bottom:.3rem}
.badge-name{font-family:var(--font-sub);font-size:.65rem;letter-spacing:.08em;color:var(--gold);text-transform:uppercase}

/* ─── EVENTI ─── */
.eventi-section{background:var(--bg)}
.flip-board{background:#0a0e13;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:3rem;font-family:var(--font-mono)}
/* flip-header/row grid → mobile-first section */
.flip-row:hover{background:rgba(200,160,74,.04)}
.flip-row:last-child{border-bottom:none}
.flip-binario{font-size:.9rem;color:var(--gold);font-weight:700}
.flip-evento{color:var(--text);font-size:.95rem;font-family:var(--font-body)}
.flip-orario{color:var(--text2);font-size:.85rem}
.flip-stato.confermato{background:rgba(76,175,80,.15);color:#4caf50;border:1px solid rgba(76,175,80,.3)}
.flip-stato.prossimo{background:rgba(200,160,74,.15);color:var(--gold);border:1px solid var(--border)}
/* serate-cards grid → mobile-first section */
.serata-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;position:relative;overflow:hidden;transition:transform var(--transition),border-color var(--transition)}
.serata-card:hover{transform:translateY(-4px);border-color:var(--gold)}
.serata-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--red2))}
.serata-type{font-family:var(--font-sub);font-size:.7rem;letter-spacing:.15em;color:var(--gold);text-transform:uppercase;margin-bottom:.5rem}
.serata-title{font-family:var(--font-sub);font-size:1.1rem;color:var(--text);margin-bottom:.3rem}
.serata-date{font-family:var(--font-mono);font-size:.8rem;color:var(--text2);margin-bottom:.75rem}
.serata-desc{font-size:.9rem;color:var(--text2);line-height:1.5}
.serata-icon{font-size:2rem;margin-bottom:.75rem}

/* gallery styles → see mobile-first section below */

/* ─── CONTATTI ─── */
.contatti-section{background:var(--bg)}
/* contatti-grid → mobile-first section */
.info-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem}
.info-box h3{font-family:var(--font-sub);font-size:.95rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
.info-box p{color:var(--text2);font-size:1rem;line-height:1.6;margin-bottom:.5rem}
.orari-table{width:100%;border-collapse:collapse}
.orari-table td{padding:.3rem 0;font-size:.9rem;color:var(--text2)}
.orari-table td:first-child{font-family:var(--font-sub);font-size:.78rem;letter-spacing:.05em;padding-right:1rem}
.orari-table td.closed{color:var(--red2)}
.contact-link{color:var(--text);transition:color var(--transition)}
.contact-link:hover{color:var(--gold)}
.social-row{display:flex;gap:.75rem;margin-top:1rem}
.social-btn{width:36px;height:36px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all var(--transition)}
.social-btn svg{width:16px;height:16px}
.social-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.prenotazione-box{background:var(--bg3);border:1px solid var(--gold);border-radius:var(--radius);padding:1.75rem}
.prenotazione-box h3{font-family:var(--font-sub);font-size:.95rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}
.prenotazione-box p{color:var(--text2);font-size:.95rem;margin-bottom:1.5rem}
.prenotazione-box .btn-outline{width:100%;justify-content:center}
.note-prenotazione{margin-top:1rem!important;font-size:.82rem!important;color:var(--text2)!important;text-align:center;font-style:italic}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.map-wrap iframe{display:block}

/* ─── FOOTER ─── */
#footer{background:var(--bg);border-top:1px solid var(--border);padding:3rem 1.5rem 2rem;text-align:center}
@media(min-width:768px){#footer{padding:4rem 2rem 2rem}}
.footer-logo{display:flex;justify-content:center;margin-bottom:1.5rem}
.footer-logo img{height:60px;width:auto;opacity:.9;transition:opacity var(--transition),transform var(--transition)}
.footer-logo img:hover{opacity:1;transform:scale(1.05)}
@media(min-width:768px){.footer-logo img{height:80px}}
.footer-tagline{font-family:var(--font-body);font-style:italic;font-size:1.05rem;color:var(--text2);margin-bottom:1.5rem}
.footer-links{display:flex;gap:1.25rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}
.footer-links a{font-family:var(--font-sub);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);transition:color var(--transition)}
.footer-links a:hover{color:var(--gold)}
.footer-copy{font-size:.82rem;color:var(--text2);opacity:.5;margin-bottom:.5rem;line-height:1.7}
.footer-love{font-size:.8rem;color:var(--text2);opacity:.4;margin-bottom:.75rem}
.footer-powered{margin-top:.75rem;margin-bottom:.25rem}
.footer-powered a{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-sub);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text2);opacity:.35;transition:opacity var(--transition),color var(--transition)}
.footer-powered a:hover{opacity:.75;color:var(--gold)}
.footer-powered a span{color:var(--gold);font-weight:700;letter-spacing:.15em}
.konami-hint{font-family:var(--font-mono);font-size:.65rem;color:var(--text2);opacity:.15;margin-top:1rem;letter-spacing:.15em}

/* ─── LOADER ─── */
#loader{position:fixed;inset:0;z-index:99999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;transition:opacity .6s ease,visibility .6s ease}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-track{position:relative;width:min(320px,85vw);height:60px}
.loader-train{position:absolute;top:0;left:-140px;animation:trainArrive 1.8s cubic-bezier(.25,.46,.45,.94) .3s forwards}
.loader-train svg{width:120px;height:40px}
@keyframes trainArrive{0%{left:-140px}100%{left:calc(50% - 60px)}}
.loader-rail{position:absolute;bottom:4px;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.loader-text{font-family:var(--font-title);font-size:clamp(1rem,4vw,1.4rem);color:var(--gold);letter-spacing:.05em;animation:heroIn .6s ease .8s both}
.loader-sub{font-family:var(--font-sub);font-size:.7rem;letter-spacing:.3em;color:var(--text2);animation:heroIn .6s ease 1s both}
@keyframes steamPuff{0%,100%{transform:translateY(0) scale(1);opacity:.4}50%{transform:translateY(-4px) scale(1.3);opacity:.6}}
.steam-puff{animation:steamPuff .8s ease-in-out infinite}
.steam-puff-2{animation:steamPuff .8s ease-in-out .2s infinite}

/* ─── NUMERI ─── */
.numeri-section{background:linear-gradient(180deg,var(--bg3) 0%,var(--bg) 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.numeri-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px;margin:0 auto}
@media(min-width:768px){.numeri-grid{grid-template-columns:repeat(4,1fr);gap:2rem}}
.numero-item{text-align:center;padding:1.5rem 1rem}
.numero-val{display:block;font-family:var(--font-title);font-size:clamp(2rem,7vw,3.5rem);color:var(--gold);margin-bottom:.4rem;background:linear-gradient(135deg,#c8a04a,#f0c040);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.numero-label{display:block;font-family:var(--font-sub);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text2)}

/* ─── GALLERY — touch scroll ─── */
.gallery-section{background:linear-gradient(180deg,var(--bg) 0%,var(--bg3) 50%,var(--bg) 100%);overflow:hidden}
.gallery-track-wrap{position:relative;overflow:hidden;margin:0 -1.25rem;cursor:grab;-webkit-overflow-scrolling:touch}
@media(min-width:768px){.gallery-track-wrap{margin:0 -2rem}}
.gallery-track-wrap:active{cursor:grabbing}
.gallery-track{display:flex;gap:.75rem;padding:.75rem 1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gallery-track::-webkit-scrollbar{display:none}
@media(min-width:768px){.gallery-track{gap:1rem;padding:1rem 2rem}}
.gallery-item{flex-shrink:0;width:min(280px,75vw);height:200px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);position:relative;scroll-snap-align:start}
@media(min-width:768px){.gallery-item{width:320px;height:220px}}
.gallery-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%) contrast(1.1);transition:filter .4s,transform .4s}
.gallery-item:hover img{filter:none;transform:scale(1.05)}
.gallery-item-label{position:absolute;bottom:0;left:0;right:0;padding:.6rem .75rem;background:linear-gradient(to top,rgba(10,10,10,.9),transparent);font-family:var(--font-sub);font-size:.72rem;letter-spacing:.08em;color:var(--text);transform:translateY(100%);transition:transform var(--transition)}
.gallery-item:hover .gallery-item-label{transform:none}
.gallery-placeholder{display:none}
.gallery-cta-text{text-align:center;margin-top:1.5rem;font-family:var(--font-sub);font-size:.82rem;color:var(--text2);letter-spacing:.08em}
.gallery-cta-text a{color:var(--gold);transition:color var(--transition)}
.gallery-cta-text a:hover{color:var(--gold2)}


/* ─── KONAMI OVERLAY ─── */
.konami-overlay{position:fixed;inset:0;background:var(--bg);z-index:99999;display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.konami-overlay.show{display:flex;animation:konamiIn .5s ease}
@keyframes konamiIn{from{opacity:0}to{opacity:1}}
.konami-title{font-family:var(--font-title);font-size:clamp(2rem,6vw,4rem);color:var(--gold);margin-bottom:1rem}
.konami-sub{font-family:var(--font-sub);font-size:1rem;color:var(--text2);letter-spacing:.2em;margin-bottom:2rem}
.konami-close{background:var(--gold);color:var(--bg);font-family:var(--font-sub);font-size:.8rem;font-weight:700;letter-spacing:.1em;padding:.6rem 1.5rem;border-radius:var(--radius)}
.konami-emojis{font-size:4rem;margin-bottom:1.5rem;animation:konPulse 1s ease infinite}
@keyframes konPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}


/* ─── PHOSPHOR ICONS ─── */
.ph{font-size:1rem;vertical-align:middle;line-height:1}
.v-tab .ph{font-size:1.1rem;margin-right:.3rem}
.menu-card-ph{font-size:2rem;color:var(--gold);margin-bottom:.75rem;display:block;opacity:.8}

/* ─── LEGGENDA — mobile first ─── */
.leggenda-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-top:2rem}
.leggenda-img{order:-1}
@media(min-width:900px){.leggenda-grid{grid-template-columns:1fr 1fr;gap:5rem;margin-top:3rem}.leggenda-img{order:0}}

/* ─── MENU — mobile first ─── */
.menu-section{background:linear-gradient(180deg,var(--bg) 0%,var(--bg3) 50%,var(--bg) 100%);max-width:100%;padding:3.5rem 1rem}
@media(min-width:768px){.menu-section{padding:6rem 2rem}}
.menu-section .section-title,.menu-section .section-sub,.menu-section .ornament{max-width:1200px;margin-left:auto;margin-right:auto}
.vagoni-tabs{display:flex;gap:.4rem;max-width:1200px;margin:0 auto 2rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:.25rem}
.vagoni-tabs::-webkit-scrollbar{display:none}
@media(min-width:768px){.vagoni-tabs{flex-wrap:wrap;justify-content:center;overflow-x:visible;margin-bottom:3rem}}
.v-tab{font-family:var(--font-sub);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);padding:.5rem 1rem;border:1px solid var(--border);border-radius:2rem;background:transparent;transition:all var(--transition);position:relative;overflow:hidden;white-space:nowrap;flex-shrink:0}
@media(min-width:768px){.v-tab{font-size:.78rem;letter-spacing:.1em;padding:.55rem 1.2rem}}
.v-tab::before{content:'';position:absolute;inset:0;background:var(--gold-dim);transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}
.v-tab:hover::before,.v-tab.active::before{transform:scaleX(1)}
.v-tab.active{color:var(--gold);border-color:var(--gold)}
.v-tab:hover{color:var(--gold);border-color:rgba(200,160,74,.5)}
.menu-panel{max-width:1200px;margin:0 auto}
.menu-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:600px){.menu-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}
@media(min-width:1024px){.menu-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}}
.menu-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;position:relative;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}
.menu-card:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:0 12px 32px rgba(200,160,74,.12)}
.menu-card.featured{border-color:var(--gold);background:linear-gradient(135deg,var(--bg3),rgba(200,160,74,.08))}
.menu-card-badge{position:absolute;top:-1px;right:1rem;background:var(--gold);color:var(--bg);font-family:var(--font-sub);font-size:.6rem;font-weight:700;letter-spacing:.1em;padding:.2rem .6rem;border-radius:0 0 var(--radius) var(--radius)}
.menu-card-name{font-family:var(--font-sub);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.menu-card-ref{font-size:.8rem;color:var(--gold);margin-bottom:.5rem;font-style:italic}
.menu-card-desc{font-size:.88rem;color:var(--text2);margin-bottom:1rem;line-height:1.5}
.menu-card-footer{display:flex;align-items:center;justify-content:space-between}
.menu-card-price{font-family:var(--font-mono);font-size:1rem;color:var(--gold);font-weight:700}
.menu-card-tag{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.08em;color:var(--text2);background:rgba(255,255,255,.05);padding:.2rem .5rem;border-radius:2rem}
.menu-card-tag.vegan{color:#4caf50;background:rgba(76,175,80,.1)}

/* ─── BIRRE — mobile first (flip system) ─── */
/* Grid and card styles moved to flip card section below */
.birra-emoji{font-size:2rem;margin-bottom:.6rem}
@media(min-width:768px){.birra-emoji{font-size:2.5rem;margin-bottom:.75rem}}
.birra-name{font-family:var(--font-sub);font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.birra-style{font-size:.72rem;color:var(--gold);font-family:var(--font-mono);margin-bottom:.4rem}
.birra-desc{font-size:.8rem;color:var(--text2);line-height:1.5;margin-bottom:.75rem;display:none}
@media(min-width:600px){.birra-desc{display:block}}
.birra-abv{display:inline-block;background:var(--gold-dim);border:1px solid var(--border);color:var(--gold);font-family:var(--font-mono);font-size:.7rem;padding:.2rem .5rem;border-radius:2rem}

/* ─── PASSPORT — mobile first ─── */
.passport-beers{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1.5rem}
@media(min-width:600px){.passport-beers{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.passport-beers{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}
.passport-badges{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}
@media(min-width:768px){.passport-badges{gap:1rem}}

/* ─── EVENTI — mobile first ─── */
.flip-header{display:grid;grid-template-columns:50px 1fr 80px;gap:.5rem;padding:.6rem 1rem;background:rgba(200,160,74,.1);border-bottom:1px solid var(--border);font-size:.68rem;letter-spacing:.12em;color:var(--gold);text-transform:uppercase}
@media(min-width:600px){.flip-header{grid-template-columns:80px 1fr 120px 100px;gap:1rem;padding:.75rem 1.5rem;font-size:.72rem}}
.flip-row{display:grid;grid-template-columns:50px 1fr 80px;gap:.5rem;padding:.85rem 1rem;border-bottom:1px solid rgba(255,255,255,.04);align-items:center;transition:background var(--transition)}
@media(min-width:600px){.flip-row{grid-template-columns:80px 1fr 120px 100px;gap:1rem;padding:1rem 1.5rem}}
.flip-stato{display:none}
@media(min-width:600px){.flip-stato{display:block;font-size:.72rem;letter-spacing:.08em;padding:.2rem .6rem;border-radius:2rem;text-align:center;font-family:var(--font-sub)}}
.flip-header span:last-child{display:none}
@media(min-width:600px){.flip-header span:last-child{display:block}}
.serate-cards{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:600px){.serate-cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.serate-cards{grid-template-columns:repeat(3,1fr);gap:1.5rem}}

/* ─── CONTATTI — mobile first ─── */
.contatti-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}
@media(min-width:600px){.contatti-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}
@media(min-width:1024px){.contatti-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:3rem}}

/* ─── HERO — mobile first ─── */
.hero-content{position:relative;z-index:2;text-align:center;padding:1.5rem 1.25rem}
@media(min-width:768px){.hero-content{padding:2rem}}
.hero-est{font-family:var(--font-sub);font-size:.7rem;letter-spacing:.35em;color:var(--gold);margin-bottom:1.25rem;opacity:.8}
.hero-title{font-family:var(--font-title);font-size:clamp(2.2rem,9vw,6rem);line-height:1.05;margin-bottom:.85rem}
.hero-tagline{font-family:var(--font-sub);font-size:clamp(.8rem,2.5vw,1.3rem);letter-spacing:.35em;text-transform:uppercase;color:var(--text2);margin-bottom:.65rem}
.hero-beer{font-family:var(--font-body);font-style:italic;font-size:1.1rem;color:var(--text2);margin-bottom:2rem}
.hero-btns{display:flex;flex-direction:column;gap:.75rem;align-items:center}
@media(min-width:480px){.hero-btns{flex-direction:row;justify-content:center}}

/* ─── MOBILE MENU FIX ─── */
.mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;background:rgba(8,8,8,.98);opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-overflow-scrolling:none;overflow:hidden}
.mobile-menu.open{opacity:1;pointer-events:all}
@media(min-width:900px){.mobile-menu{display:none!important}}

/* ─── NEW ANIMATIONS ─── */

/* Floating particles in hero */
@keyframes floatUp{0%{opacity:0;transform:translateY(0) scale(1)}20%{opacity:.6}80%{opacity:.3}100%{opacity:0;transform:translateY(-120px) scale(1.8)}}
.float-particle{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(200,160,74,.2),transparent 70%);animation:floatUp var(--d,6s) ease-out infinite;animation-delay:var(--dl,0s);pointer-events:none}

/* Magnetic hover on cards */
.menu-card,.birra-flip-wrap,.serata-card{will-change:transform}

/* Gold pulse on featured badge */
.menu-card-badge{animation:badgePulse 3s ease infinite}
@keyframes badgePulse{0%,100%{box-shadow:0 0 0 0 rgba(200,160,74,.4)}50%{box-shadow:0 0 0 6px rgba(200,160,74,0)}}

/* Shimmer on WhatsApp button */
.btn-whatsapp{position:relative;overflow:hidden}
.btn-whatsapp::before{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);animation:waShimmer 2.5s ease infinite}
@keyframes waShimmer{0%{left:-100%}100%{left:200%}}

/* Timeline dot pulse */
.tl-dot--gold{animation:dotPulse 2s ease infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 rgba(200,160,74,.5)}50%{box-shadow:0 0 0 8px rgba(200,160,74,0)}}

/* Status dot breathing */
.status-dot.open{animation:breathe 2s ease infinite}
@keyframes breathe{0%,100%{box-shadow:0 0 4px #4caf50}50%{box-shadow:0 0 12px #4caf50,0 0 24px rgba(76,175,80,.4)}}

/* Section entrance — stagger children */
.menu-grid .menu-card,.birre-grid .birra-flip-wrap{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.menu-grid.animated .menu-card,.birre-grid.animated .birra-flip-wrap{opacity:1;transform:none}
.menu-grid .menu-card:nth-child(1),.birre-grid .birra-flip-wrap:nth-child(1){transition-delay:.05s}
.menu-grid .menu-card:nth-child(2),.birre-grid .birra-flip-wrap:nth-child(2){transition-delay:.1s}
.menu-grid .menu-card:nth-child(3),.birre-grid .birra-flip-wrap:nth-child(3){transition-delay:.15s}
.menu-grid .menu-card:nth-child(4),.birre-grid .birra-flip-wrap:nth-child(4){transition-delay:.2s}
.menu-grid .menu-card:nth-child(5),.birre-grid .birra-flip-wrap:nth-child(5){transition-delay:.25s}
.menu-grid .menu-card:nth-child(6),.birre-grid .birra-flip-wrap:nth-child(6){transition-delay:.3s}

/* Parallax hero background via JS transform */
.hero-bg{transform:translateY(0);will-change:transform}

/* Hero title entrance */
@keyframes heroIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.ht-top{animation:heroIn .8s ease .2s both}
.ht-main{animation:heroIn .8s ease .4s both}
.hero-tagline{animation:heroIn .8s ease .6s both}
.hero-beer{animation:heroIn .8s ease .8s both}
.hero-btns{animation:heroIn .8s ease 1s both}
.hero-est{animation:heroIn .8s ease 0s both}

/* Scroll indicator fade */
.scroll-hint{animation:bob 2s ease-in-out infinite,heroIn .8s ease 1.5s both}

/* Beer card tap feedback on mobile */
@media(hover:none){
  .birra-card:active{transform:scale(.96);border-color:var(--gold)}
  .menu-card:active{transform:scale(.98);border-color:var(--gold)}
  .btn-gold:active{transform:scale(.96)}
}

/* ─── CURSOR — desktop only ─── */
@media(hover:none),(pointer:coarse){
  .cursor-dot,.cursor-ring{display:none!important}
  body{cursor:auto}
}

/* ─── REDUCED MOTION ─── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}


/* ─── HERO BG — real image ─── */
.hero-bg{background-image:url('../assets/hero_bg.png');opacity:.28}

/* ─── FLOATING WHATSAPP BUTTON ─── */
.fab-whatsapp{position:fixed;bottom:5rem;right:1.25rem;z-index:900;width:56px;height:56px;background:#25d366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform var(--transition),box-shadow var(--transition);overflow:visible}
@media(min-width:768px){.fab-whatsapp{bottom:6rem;right:2rem}}
.fab-whatsapp:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.55)}
.fab-whatsapp::before{content:'';position:absolute;inset:0;border-radius:50%;background:#25d366;animation:waPulse 2s ease-out infinite;z-index:-1}
@keyframes waPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}
.fab-tooltip{position:absolute;right:64px;top:50%;transform:translateY(-50%);background:rgba(10,10,10,.9);color:var(--text);font-family:var(--font-sub);font-size:.68rem;letter-spacing:.08em;white-space:nowrap;padding:.35rem .75rem;border-radius:var(--radius);pointer-events:none;opacity:0;transition:opacity .2s;border:1px solid var(--border)}
.fab-whatsapp:hover .fab-tooltip{opacity:1}

/* ─── SCROLL TO TOP BUTTON ─── */
.fab-top{position:fixed;bottom:1.25rem;right:1.25rem;z-index:900;width:44px;height:44px;background:var(--bg3);color:var(--gold);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition);font-size:1.1rem}
@media(min-width:768px){.fab-top{bottom:2rem;right:2rem}}
.fab-top:hover{background:var(--gold);color:var(--bg);border-color:var(--gold);transform:translateY(-3px)}

/* ─── COOKIE BANNER ─── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9000;background:rgba(10,10,10,.97);border-top:1px solid var(--border);backdrop-filter:blur(12px);padding:1rem 1.25rem;transform:translateY(100%);transition:transform .4s cubic-bezier(.25,.46,.45,.94)}
.cookie-banner.show{transform:none}
.cookie-content{max-width:1000px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}
@media(min-width:600px){.cookie-content{flex-direction:row;align-items:center;justify-content:space-between}}
.cookie-text{font-family:var(--font-body);font-size:.9rem;color:var(--text2);line-height:1.5;flex:1}
.cookie-actions{display:flex;gap:.75rem;align-items:center;flex-shrink:0}
.cookie-btn{font-family:var(--font-sub);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.45rem 1.25rem;border-radius:var(--radius);transition:all var(--transition);white-space:nowrap}
.cookie-btn-accept{background:var(--gold);color:var(--bg);font-weight:700;border:none}
.cookie-btn-accept:hover{background:var(--gold2)}
.cookie-btn-info{border:1px solid var(--border);color:var(--text2)}
.cookie-btn-info:hover{border-color:var(--gold);color:var(--gold)}

/* ─── SCROLLSPY — active nav link ─── */
.nav-link.active{color:var(--gold)}
.nav-link.active::after{width:100%}

/* ─── ABOUT IMAGE in Leggenda ─── */
.leggenda-img img{content:url('../assets/about_bg.png')}


/* ══════════════════════════════════════════
   ── FLIP CARD BIRRE ──
   ══════════════════════════════════════════ */
.birre-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(min-width:600px){.birre-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.birre-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}}
.birra-flip-wrap{perspective:1000px;cursor:pointer;position:relative;height:240px}
@media(min-width:600px){.birra-flip-wrap{height:270px}}
.birra-flip-wrap.passport-checked .birra-front{border-color:#4caf50;background:linear-gradient(135deg,var(--bg3),rgba(76,175,80,.05))}
.birra-flip-inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.birra-flip-wrap.flipped .birra-flip-inner{transform:rotateY(180deg)}
.birra-front,.birra-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius);overflow:hidden}
.birra-back{transform:rotateY(180deg)}
/* Re-apply original birra-card styles to front */
.birra-front{background:var(--bg3);border:1px solid var(--border);padding:1.25rem 1rem;text-align:center;position:relative;transition:border-color var(--transition),box-shadow var(--transition)}
@media(min-width:768px){.birra-front{padding:1.5rem 1.25rem}}
.birra-front::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold2));transform:scaleX(0);transition:transform var(--transition)}
.birra-flip-wrap:hover .birra-front::before,.birra-flip-wrap.flipped .birra-front::before{transform:scaleX(1)}
.birra-flip-wrap:hover .birra-front{border-color:var(--gold);box-shadow:0 16px 40px rgba(200,160,74,.15)}
.flip-passport-badge{position:absolute;top:.5rem;right:.75rem;color:#4caf50;font-size:1rem;font-weight:700}
.birra-flip-hint{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.1em;color:var(--text2);opacity:.45;margin-top:.5rem;text-transform:uppercase}
/* Back side */
.birra-back{background:var(--bg3);border:1px solid var(--gold);padding:1.25rem 1rem;display:flex;flex-direction:column;justify-content:space-between}
.birra-back-name{font-family:var(--font-sub);font-size:.95rem;color:var(--gold);margin-bottom:.75rem;font-weight:700}
/* Tasting bars */
.birra-tasting{margin-bottom:.75rem}
.trow{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}
.trow span{font-family:var(--font-sub);font-size:.62rem;letter-spacing:.06em;color:var(--text2);text-transform:uppercase;width:52px;flex-shrink:0}
.tbar{flex:1;height:5px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.tbar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:3px;transition:width .6s ease}
.birra-pairing{font-size:.78rem;color:var(--text2);line-height:1.4;margin-bottom:.75rem;font-style:italic;border-top:1px solid var(--border);padding-top:.6rem}
.birra-passport-btn{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.68rem;letter-spacing:.08em;padding:.4rem .8rem;border-radius:var(--radius);transition:all var(--transition);cursor:pointer;width:100%;text-transform:uppercase}
.birra-passport-btn:hover{border-color:var(--gold);color:var(--gold)}
.birra-passport-btn.checked{border-color:#4caf50;color:#4caf50;background:rgba(76,175,80,.08)}

/* ══════════════════════════════════════════
   ── GALLERY LIGHTBOX ──
   ══════════════════════════════════════════ */
.lb-overlay{position:fixed;inset:0;z-index:99990;background:rgba(5,5,5,.96);display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}
.lb-overlay.show{opacity:1;visibility:visible}
.lb-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;max-height:100vh;gap:1rem}
.lb-img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:var(--radius);border:1px solid var(--border);transition:opacity .15s ease;box-shadow:0 20px 80px rgba(0,0,0,.8)}
.lb-caption{font-family:var(--font-sub);font-size:.78rem;letter-spacing:.12em;color:var(--text2);text-transform:uppercase;text-align:center}
.lb-close{position:fixed;top:1.25rem;right:1.5rem;width:44px;height:44px;background:rgba(200,160,74,.15);border:1px solid var(--border);border-radius:50%;color:var(--text);font-size:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);z-index:1}
.lb-close:hover{background:var(--gold);color:var(--bg);border-color:var(--gold)}
.lb-nav{width:48px;height:48px;background:rgba(200,160,74,.12);border:1px solid var(--border);border-radius:50%;color:var(--gold);font-size:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--transition);line-height:1}
.lb-nav:hover{background:var(--gold);color:var(--bg);border-color:var(--gold);transform:scale(1.1)}
@media(max-width:600px){.lb-nav{width:36px;height:36px;font-size:1.5rem}}

/* ══════════════════════════════════════════
   ── WALL OF FAME ──
   ══════════════════════════════════════════ */
.wof-section{background:linear-gradient(180deg,var(--bg3) 0%,var(--bg) 100%)}
.wof-board{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-bottom:2rem}
@media(min-width:600px){.wof-board{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.wof-board{grid-template-columns:repeat(3,1fr);gap:1.5rem}}
.wof-card{position:relative;background:#f5f0e8;border-radius:2px;padding:1.5rem 1.25rem 1.25rem;color:#2a2018;box-shadow:0 4px 20px rgba(0,0,0,.4),2px 2px 0 rgba(0,0,0,.1);transform:rotate(var(--rot,0deg));transition:transform .3s ease,box-shadow .3s ease}
.wof-card:hover{transform:rotate(0deg) translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.5),2px 2px 0 rgba(0,0,0,.1)}
.wof-pin{position:absolute;top:-10px;left:50%;transform:translateX(-50%);width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#e84,#c62);box-shadow:0 2px 4px rgba(0,0,0,.4)}
.wof-pin::after{content:'';position:absolute;top:10px;left:50%;transform:translateX(-50%);width:2px;height:14px;background:rgba(0,0,0,.2)}
.wof-stars{color:#c8a04a;font-size:1.1rem;margin-bottom:.75rem;letter-spacing:.1em}
.wof-text{font-family:Georgia,serif;font-size:.95rem;line-height:1.6;color:#3a2e22;margin-bottom:.75rem;font-style:italic}
.wof-author{font-family:var(--font-mono);font-size:.75rem;color:#6a5840;text-align:right}
.wof-cta{display:inline-flex;align-items:center;font-family:var(--font-sub);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid rgba(200,160,74,.4);padding-bottom:.2rem;transition:border-color var(--transition),color var(--transition)}
.wof-cta:hover{color:var(--gold2);border-color:var(--gold2)}

/* ══════════════════════════════════════════
   ── LIVE BEER COUNTER ──
   ══════════════════════════════════════════ */
.live-counter-wrap{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:2rem;padding:.75rem 1.5rem;background:rgba(200,160,74,.06);border:1px solid rgba(200,160,74,.2);border-radius:2rem;max-width:380px;margin-left:auto;margin-right:auto}
.live-counter-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;box-shadow:0 0 8px #4caf50;animation:breathe 2s ease infinite;flex-shrink:0}
.live-counter-label{font-family:var(--font-sub);font-size:.75rem;letter-spacing:.08em;color:var(--text2)}
.live-counter-num{font-family:var(--font-mono);font-size:1.1rem;color:var(--gold);font-weight:700;min-width:2ch;text-align:center}

/* ══════════════════════════════════════════
   ── QUIZ TICKET ──
   ══════════════════════════════════════════ */
.quiz-ticket-preview{margin:1.25rem auto;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-width:420px;background:#1a1814}
.quiz-ticket-preview canvas{display:block;max-width:100%;height:auto}
.quiz-ticket-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}
.quiz-ticket-dl{background:var(--gold);color:var(--bg);font-family:var(--font-sub);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.55rem 1.4rem;border-radius:var(--radius);border:none;cursor:pointer;transition:background var(--transition),transform var(--transition)}
.quiz-ticket-dl:hover{background:var(--gold2);transform:translateY(-1px)}

/* ══════════════════════════════════════════
   ── MIDNIGHT MODE ──
   ══════════════════════════════════════════ */
body.midnight-mode{--bg:#060605;--bg2:#0d0d0b;--bg3:#130f0c}
body.midnight-mode .hero-bg{opacity:.18;filter:grayscale(60%) brightness(.8)}
body.midnight-mode .ht-main{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#8a7040,#b09050,#8a7040);-webkit-background-clip:text;background-clip:text}

/* ══════════════════════════════════════════
   ── MENU PREMIUM ──
   ══════════════════════════════════════════ */

/* Tab attiva gold */
.v-tab{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1rem;border-radius:2rem;cursor:pointer;transition:all var(--transition);white-space:nowrap;display:flex;align-items:center;gap:.4rem}
.v-tab.active{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--bg);border-color:transparent;font-weight:700;box-shadow:0 4px 20px rgba(200,160,74,.35)}
.v-tab:not(.active):hover{border-color:var(--gold);color:var(--gold)}

/* Category banner */
.menu-cat-banner{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem}
.mcb-icon{width:40px;height:40px;flex-shrink:0;opacity:.85}
.mcb-icon svg{width:100%;height:100%}
.mcb-label{font-family:var(--font-title);font-size:1.1rem;color:var(--text);line-height:1}
.mcb-count{font-family:var(--font-sub);font-size:.68rem;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;margin-top:.2rem}
.mcb-vegan-toggle{margin-left:auto;display:flex;align-items:center;gap:.4rem;font-family:var(--font-sub);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);background:transparent;border:1px solid var(--border);padding:.35rem .75rem;border-radius:2rem;cursor:pointer;transition:all var(--transition)}
.mcb-vegan-toggle.active,.mcb-vegan-toggle:hover{border-color:#4caf50;color:#4caf50;background:rgba(76,175,80,.08)}

/* Menu card premium */
.menu-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:0;overflow:hidden;position:relative;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);display:flex;flex-direction:column}
.menu-card:hover{border-color:var(--cat-accent,var(--gold));box-shadow:0 16px 40px rgba(0,0,0,.3);transform:translateY(-3px)}
.menu-card-accent-bar{height:3px;width:100%;flex-shrink:0}
.menu-card-ref{font-family:var(--font-body);font-style:italic;font-size:.72rem;color:var(--gold);opacity:.8;padding:.85rem 1rem .1rem;line-height:1}
.menu-card-name{font-family:var(--font-title);font-size:1.05rem;color:var(--text);padding:.3rem 1rem .1rem;line-height:1.2;font-weight:400}
@media(min-width:600px){.menu-card-name{font-size:1.15rem}}
.menu-card-ornament{font-size:.55rem;color:var(--gold);opacity:.4;padding:.3rem 1rem 0;letter-spacing:.2em}
.menu-card-desc{font-size:.8rem;color:var(--text2);line-height:1.5;padding:.35rem 1rem;flex:1}
.menu-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--border);margin-top:auto}
.menu-card-price-block{display:flex;align-items:baseline;gap:.15rem}
.menu-price-symbol{font-family:var(--font-sub);font-size:.75rem;color:var(--gold);opacity:.8}
.menu-price-num{font-family:var(--font-mono);font-size:1.1rem;color:var(--gold);font-weight:700}
.menu-card-badge{position:absolute;top:.6rem;right:.6rem;background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--bg);font-family:var(--font-sub);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;padding:.22rem .6rem;border-radius:2rem;font-weight:700;animation:badgePulse 3s ease infinite}
.menu-card-tag{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.08em;color:var(--text2);background:rgba(255,255,255,.05);padding:.2rem .5rem;border-radius:2rem;text-transform:uppercase}
.menu-card-tag.vegan{color:#4caf50;background:rgba(76,175,80,.12);border:1px solid rgba(76,175,80,.2)}
.menu-card.featured{border-color:rgba(200,160,74,.3)}
.menu-empty{grid-column:1/-1;text-align:center;color:var(--text2);font-family:var(--font-sub);font-size:.8rem;padding:2rem;opacity:.6}

/* ══════════════════════════════════════════
   ── BIRRE ORIZZONTALE ──
   ══════════════════════════════════════════ */
.birra-flip-wrap{perspective:1000px;cursor:pointer;position:relative;height:160px}
@media(min-width:480px){.birra-flip-wrap{height:180px}}
.birra-flip-inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.birra-flip-wrap.flipped .birra-flip-inner{transform:rotateY(180deg)}
.birra-front,.birra-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius);overflow:hidden}
.birra-back{transform:rotateY(180deg)}

/* Fronte: layout 2 colonne */
.birra-front{background:var(--bg3);border:1px solid var(--border);display:flex;transition:border-color var(--transition),box-shadow var(--transition)}
.birra-flip-wrap:hover .birra-front{border-color:var(--beer-accent,var(--gold));box-shadow:0 8px 30px rgba(0,0,0,.3)}
.birra-flip-wrap.passport-checked .birra-front{border-color:var(--beer-accent,var(--gold))}
.birra-icon-block{width:90px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:.75rem .5rem;position:relative}
@media(min-width:480px){.birra-icon-block{width:110px}}
.birra-svg-icon{width:52px;height:52px}
.birra-svg-icon svg{width:100%;height:100%}
.birra-abv-badge{font-family:var(--font-mono);font-size:.65rem;font-weight:700;color:#fff;padding:.18rem .55rem;border-radius:2rem;letter-spacing:.05em}
.birra-spina-dot{display:flex;align-items:center;gap:.3rem;font-family:var(--font-sub);font-size:.55rem;letter-spacing:.08em;color:var(--text2);text-transform:uppercase}
.birra-spina-dot span{width:5px;height:5px;border-radius:50%;background:#4caf50;box-shadow:0 0 5px #4caf50;flex-shrink:0;animation:breathe 2s ease infinite}
.birra-text-block{flex:1;padding:.85rem .9rem;display:flex;flex-direction:column;justify-content:center;min-width:0}
.birra-style-label{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.2rem}
.birra-name{font-family:var(--font-title);font-size:1.1rem;color:var(--text);line-height:1.1;margin-bottom:.3rem}
@media(min-width:480px){.birra-name{font-size:1.25rem}}
.birra-desc{font-size:.75rem;color:var(--text2);line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.birra-flip-hint{font-family:var(--font-sub);font-size:.55rem;letter-spacing:.1em;color:var(--text2);opacity:.45;margin-top:.4rem;text-transform:uppercase}
.flip-passport-badge{position:absolute;top:.4rem;left:.4rem;color:#4caf50;font-size:.9rem;font-weight:700;z-index:1}

/* Retro */
.birra-back{background:var(--bg3);border:1px solid var(--border);padding:1rem;display:flex;flex-direction:column;justify-content:space-between}
.birra-back-header{display:flex;align-items:center;gap:.6rem;padding-bottom:.6rem;border-bottom:1px solid var(--border);margin-bottom:.6rem}
.birra-back-icon{width:28px;height:28px;flex-shrink:0}
.birra-back-name{font-family:var(--font-title);font-size:.9rem;line-height:1.1}
.birra-passport-btn{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.65rem;letter-spacing:.08em;padding:.4rem .8rem;border-radius:var(--radius);transition:all var(--transition);cursor:pointer;width:100%;text-transform:uppercase}
.birra-passport-btn:hover{border-color:var(--beer-accent,var(--gold));color:var(--beer-accent,var(--gold))}
.birra-passport-btn.checked{border-color:#4caf50;color:#4caf50;background:rgba(76,175,80,.08)}

/* ══════════════════════════════════════════
   ── BEER PASSPORT VINTAGE ──
   ══════════════════════════════════════════ */
.passport-book{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.passport-cover{background:linear-gradient(135deg,#1e1810,#2a2218);border-bottom:1px solid rgba(200,160,74,.2);padding:2rem;text-align:center}
.passport-cover-ornament{font-size:.7rem;letter-spacing:.3em;color:var(--gold);opacity:.6;margin-bottom:.75rem}
.passport-cover-title{font-family:var(--font-title);font-size:clamp(1rem,3vw,1.5rem);color:var(--gold);letter-spacing:.2em;margin-bottom:.4rem}
.passport-cover-sub{font-family:var(--font-sub);font-size:.7rem;letter-spacing:.15em;color:var(--text2);text-transform:uppercase;margin-bottom:1rem}
.passport-cover-count{display:flex;align-items:baseline;justify-content:center;gap:.5rem}
.passport-cover-count span:first-child{font-family:var(--font-mono);font-size:2.5rem;color:var(--gold);line-height:1}
.pp-count-label{font-family:var(--font-sub);font-size:.72rem;letter-spacing:.1em;color:var(--text2)}

/* Barra treno */
.passport-train-wrap{padding:1.25rem 1.5rem .75rem}
.passport-train-track{position:relative;height:8px;background:rgba(255,255,255,.05);border-radius:4px;border:1px solid var(--border);overflow:visible;margin-bottom:.5rem}
.passport-train-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.passport-train-loco{position:absolute;top:-14px;transition:left .8s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 4px rgba(200,160,74,.5))}
.passport-train-labels{display:flex;justify-content:space-between;font-family:var(--font-sub);font-size:.6rem;letter-spacing:.1em;color:var(--text2);opacity:.5;text-transform:uppercase}

/* Timbri */
.passport-stamps-label{font-family:var(--font-sub);font-size:.65rem;letter-spacing:.2em;color:var(--gold);opacity:.7;text-align:center;text-transform:uppercase;padding:.75rem 0 .5rem}
.passport-beers{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;padding:0 1.25rem}
@media(min-width:480px){.passport-beers{grid-template-columns:repeat(5,1fr)}}
@media(min-width:768px){.passport-beers{grid-template-columns:repeat(9,1fr);gap:.5rem}}
.pp-stamp{cursor:pointer;transition:transform var(--transition),box-shadow var(--transition)}
.pp-stamp:hover{transform:scale(1.08)}
.pp-stamp-inner{border:2px dashed rgba(255,255,255,.12);border-radius:var(--radius);padding:.6rem .4rem;display:flex;flex-direction:column;align-items:center;gap:.3rem;text-align:center;transition:border-color var(--transition),background var(--transition)}
.pp-stamp.stamped .pp-stamp-inner{border-style:solid;background:rgba(255,255,255,.03)}
.pp-stamp:hover .pp-stamp-inner{border-color:var(--beer-accent,var(--gold))}
.pp-stamp-icon{width:32px;height:32px}
.pp-stamp-icon svg{width:100%;height:100%}
.pp-stamp-name{font-family:var(--font-sub);font-size:.5rem;letter-spacing:.08em;color:var(--text2);text-transform:uppercase;line-height:1.2}
.pp-stamp-check{width:16px;height:16px;border-radius:50%;border:1.5px solid;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700}

/* Badge */
.passport-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:0 1.25rem 1.5rem}
@media(min-width:600px){.passport-badges{grid-template-columns:repeat(5,1fr)}}
.badge{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem .5rem;border:1px dashed rgba(255,255,255,.08);border-radius:var(--radius);opacity:.35;transition:all var(--transition)}
.badge.unlocked{opacity:1;border-color:rgba(200,160,74,.3);background:rgba(200,160,74,.04)}
.badge-svg-icon{width:40px;height:40px;color:var(--text2);transition:color var(--transition)}
.badge.unlocked .badge-svg-icon{color:var(--gold)}
.badge-svg-icon svg{width:100%;height:100%}
.badge-name{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;text-align:center}
.badge.unlocked .badge-name{color:var(--gold)}
.badge-req{font-family:var(--font-mono);font-size:.55rem;color:var(--text2);opacity:.6}
/* Shine animation */
@keyframes badgeShine{0%{background-position:-200% center}100%{background-position:200% center}}
.badge.do-shine{background:linear-gradient(90deg,transparent 30%,rgba(200,160,74,.25) 50%,transparent 70%) 0 0/200% auto;animation:badgeShine .8s ease}

/* ══════════════════════════════════════════
   ── BEER CURSOR ──
   ══════════════════════════════════════════ */
.beer-cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:99999;will-change:transform;transition:opacity .2s}
@keyframes foamPop{0%{opacity:1;transform:translate(var(--dx),0) scale(1)}100%{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.3)}}
.beer-foam-particle{position:fixed;width:8px;height:8px;border-radius:50%;background:rgba(200,160,74,.7);pointer-events:none;z-index:99998;animation:foamPop .6s ease forwards}

/* ══════════════════════════════════════════
   ── KITCHEN COUNTDOWN ──
   ══════════════════════════════════════════ */
.kitchen-countdown{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(90deg,#8b1a1a,#5c0f0f);z-index:9000;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-family:var(--font-sub);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;box-shadow:0 -4px 20px rgba(139,26,26,.5)}
.kc-icon{font-size:1rem}
.kc-timer{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:#ffd700;background:rgba(0,0,0,.3);padding:.1rem .4rem;border-radius:.25rem}

/* ══════════════════════════════════════════
   ── SPLIT-FLAP BOARD ──
   ══════════════════════════════════════════ */
.sfb-board{background:#0d0c0a;border:1px solid rgba(200,160,74,.2);border-radius:var(--radius);overflow:hidden;max-width:900px;margin:0 auto 2rem;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.sfb-header{display:grid;grid-template-columns:70px 1fr 120px 130px;gap:0;padding:.5rem .75rem;background:rgba(200,160,74,.08);border-bottom:1px solid rgba(200,160,74,.15);font-family:var(--font-sub);font-size:.6rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}
.sfb-row{display:grid;grid-template-columns:70px 1fr 120px 130px;gap:0;padding:.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.04);align-items:center;transition:background var(--transition)}
.sfb-row:hover{background:rgba(200,160,74,.04)}
.sfb-cell{display:inline-block;font-family:var(--font-mono);font-size:.85rem;color:var(--gold);background:#111008;border:1px solid rgba(200,160,74,.1);width:1.1em;height:1.4em;line-height:1.4;text-align:center;margin:0 .5px;border-radius:2px;position:relative;overflow:hidden;vertical-align:middle}
@keyframes flapFlip{0%{transform:rotateX(0deg)}50%{transform:rotateX(-90deg)}51%{transform:rotateX(90deg)}100%{transform:rotateX(0deg)}}
.sfb-cell.flapping{animation:flapFlip .1s ease}
.sfb-binario .sfb-cell{font-size:1.1rem;font-weight:700;color:#fff;width:1.4em}
.sfb-stato.confermato .sfb-cell{color:#4caf50}
.sfb-stato.prossimo .sfb-cell{color:var(--gold)}
@media(max-width:600px){
  .sfb-header,.sfb-row{grid-template-columns:40px 1fr 80px;gap:0}
  .sfb-stato{display:none}
  .sfb-header span:last-child{display:none}
  .sfb-cell{font-size:.7rem;width:.95em}
}

/* ══════════════════════════════════════════
   ── MOOD SELECTOR ──
   ══════════════════════════════════════════ */
.umore-section{}
.mood-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:700px;margin:0 auto 2rem}
@media(min-width:600px){.mood-grid{grid-template-columns:repeat(3,1fr)}}
.mood-cell{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem .75rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);position:relative;overflow:hidden}
.mood-cell::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,var(--gold) 0%,transparent 70%);opacity:0;transition:opacity var(--transition)}
.mood-cell:hover::before{opacity:.04}
.mood-cell:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.3)}
.mood-cell.selected{border-color:var(--gold);background:rgba(200,160,74,.06);box-shadow:0 0 20px rgba(200,160,74,.2)}
.mood-emoji{font-size:2rem;line-height:1}
.mood-label{font-family:var(--font-sub);font-size:.65rem;letter-spacing:.08em;color:var(--text2);text-transform:uppercase;text-align:center;line-height:1.4}
.mood-result{max-width:600px;margin:0 auto;opacity:0;transform:translateY(10px);transition:opacity .4s,transform .4s}
.mood-result.show{opacity:1;transform:translateY(0)}
.mood-res-inner{display:flex;align-items:center;gap:1.5rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;border-left:3px solid var(--beer-accent,var(--gold))}
.mood-res-icon{width:60px;height:60px;flex-shrink:0}
.mood-res-icon svg{width:100%;height:100%}
.mood-res-beer{font-family:var(--font-title);font-size:1.3rem;line-height:1.1;margin-bottom:.2rem}
.mood-res-style{font-family:var(--font-sub);font-size:.65rem;letter-spacing:.12em;color:var(--text2);text-transform:uppercase;margin-bottom:.5rem}
.mood-res-msg{font-size:.82rem;color:var(--text2);line-height:1.5;font-style:italic}

/* ══════════════════════════════════════════
   ── GRATTA & SCOPRI ──
   ══════════════════════════════════════════ */
.scratch-wrap{position:relative;max-width:340px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}
#scratchCanvas{border-radius:var(--radius);cursor:crosshair;display:block;max-width:100%;transition:opacity .4s}
.scratch-reveal{position:absolute;inset:0;bottom:auto;top:0;height:180px;border-radius:var(--radius);background:linear-gradient(135deg,var(--bg3),#2a2218);border:1px solid rgba(200,160,74,.3);display:flex;align-items:center;justify-content:center;z-index:1}
.scratch-content{text-align:center;padding:1rem}
.sc-emoji{font-size:2.5rem;line-height:1;margin-bottom:.5rem}
.sc-title{font-family:var(--font-title);font-size:1rem;color:var(--gold);margin-bottom:.25rem;letter-spacing:.08em}
.sc-item{font-family:var(--font-sub);font-size:.75rem;color:var(--text);margin-bottom:.4rem;letter-spacing:.05em}
.sc-price{font-family:var(--font-mono);font-size:1.4rem;color:var(--gold);font-weight:700}
.sc-note{font-size:.65rem;color:var(--text2);margin-top:.3rem;font-style:italic}
.scratch-reset{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.4rem 1rem;border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}
.scratch-reset:hover{border-color:var(--gold);color:var(--gold)}

/* ══════════════════════════════════════════
   ── RANDOM DISH ──
   ══════════════════════════════════════════ */
.v-tab-random{border-color:rgba(200,160,74,.4);color:var(--gold)}
.v-tab-random:hover{background:rgba(200,160,74,.08)}
.v-tab-random.spinning svg{animation:spin .5s ease}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.menu-card.random-highlight{border-color:var(--gold);box-shadow:0 0 30px rgba(200,160,74,.4);animation:highlightPulse 2.5s ease}
@keyframes highlightPulse{0%,100%{box-shadow:0 0 10px rgba(200,160,74,.2)}50%{box-shadow:0 0 40px rgba(200,160,74,.5)}}

/* ══════════════════════════════════════════
   ── HUB GIOCHI ──
   ══════════════════════════════════════════ */
.giochi-section{overflow:visible}
.giochi-tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.g-tab{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.55rem 1.1rem;border-radius:2rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:.4rem;white-space:nowrap}
.g-tab:hover{border-color:var(--gold);color:var(--gold)}
.g-tab.active{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--bg);border-color:transparent;font-weight:700;box-shadow:0 4px 20px rgba(200,160,74,.35)}
.giochi-panels{position:relative;min-height:400px}
.g-panel{display:none;animation:panelIn .35s ease}
.g-panel.active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.g-panel-sub{text-align:center;font-family:var(--font-sub);font-size:.78rem;letter-spacing:.1em;color:var(--text2);margin-bottom:2rem;text-transform:uppercase}

/* ── TAPPO RESULT CARD ── */
.tappo-result-card{display:flex;align-items:center;gap:1.5rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;border-left:3px solid var(--beer-accent,var(--gold));max-width:520px;margin:1.5rem auto 0;animation:tappoReveal .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes tappoReveal{from{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.tappo-res-icon{width:64px;height:64px;flex-shrink:0}
.tappo-res-icon svg{width:100%;height:100%}
.tappo-res-name{font-family:var(--font-title);font-size:1.2rem;line-height:1.1;margin-bottom:.2rem}
.tappo-res-style{font-family:var(--font-sub);font-size:.65rem;letter-spacing:.12em;color:var(--text2);text-transform:uppercase;margin-bottom:.4rem}
.tappo-res-desc{font-size:.8rem;color:var(--text2);line-height:1.5;font-style:italic}

/* ── QUIZ RESULT SVG HEADER ── */
.quiz-res-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.quiz-res-svg{width:56px;height:56px;flex-shrink:0}
.quiz-res-svg svg{width:100%;height:100%}

/* ── CONFETTI BURST ── */
@keyframes confettiPop{0%{opacity:1;transform:translate(0,0) scale(1) rotate(0deg)}100%{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.4) rotate(360deg)}}

/* ══════════════════════════════════════════
   ── GIOCHI SECTION PREMIUM ──
   ══════════════════════════════════════════ */
.giochi-section{
  background:
    radial-gradient(circle at 20% 20%,rgba(200,160,74,.04) 0%,transparent 50%),
    radial-gradient(circle at 80% 80%,rgba(200,160,74,.03) 0%,transparent 50%),
    var(--bg2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;
  overflow:hidden;
}
/* Arcade dots pattern */
.giochi-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(200,160,74,.06) 1px,transparent 1px);
  background-size:28px 28px;
  pointer-events:none;
}
/* Arcade badge above title */
.giochi-section .section-title::before{
  content:'◆ ARCADE ◆';
  display:block;
  font-family:var(--font-sub);
  font-size:.6rem;
  letter-spacing:.3em;
  color:var(--gold);
  opacity:.5;
  margin-bottom:.5rem;
  text-align:center;
}
/* Tabs scroll on mobile */
.giochi-tabs{
  overflow-x:auto;
  flex-wrap:nowrap;
  justify-content:flex-start;
  padding-bottom:.25rem;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.giochi-tabs::-webkit-scrollbar{display:none}
@media(min-width:700px){
  .giochi-tabs{flex-wrap:wrap;justify-content:center;overflow-x:visible}
}
/* Panel content area */
.giochi-panels{
  background:rgba(0,0,0,.15);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem 1.5rem;
  margin-top:.5rem;
}
@media(min-width:600px){.giochi-panels{padding:2.5rem 2rem}}

/* ══════════════════════════════════════════
   ── SERATE CARD PREMIUM ──
   ══════════════════════════════════════════ */
.serate-cards{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-top:2rem}
@media(min-width:500px){.serate-cards{grid-template-columns:repeat(3,1fr)}}
.serata-card{
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);
  position:relative;
}
.serata-card:hover{
  border-color:var(--serata-accent,var(--gold));
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.serata-card-top{
  display:flex;align-items:center;gap:.75rem;
  padding:1.25rem 1rem .75rem;
}
.serata-svg-icon{width:36px;height:36px;flex-shrink:0}
.serata-svg-icon svg{width:100%;height:100%}
.serata-type{
  font-family:var(--font-sub);font-size:.6rem;letter-spacing:.15em;
  color:var(--text2);text-transform:uppercase;
  border:1px solid currentColor;
  color:var(--serata-accent,var(--gold));
  border-color:var(--serata-accent,var(--gold));
  opacity:.8;
  padding:.2rem .55rem;border-radius:2rem;
}
.serata-card-accent-bar{height:2px;width:100%;flex-shrink:0;opacity:.7}
.serata-title{
  font-family:var(--font-title);font-size:1rem;
  color:var(--text);padding:.75rem 1rem .25rem;line-height:1.2;
}
.serata-date{
  font-family:var(--font-mono);font-size:.68rem;
  color:var(--serata-accent,var(--gold));padding:.1rem 1rem .5rem;
  opacity:.85;
}
.serata-desc{
  font-size:.78rem;color:var(--text2);line-height:1.5;
  padding:.25rem 1rem 1.25rem;flex:1;
}




/* -- NEWSPAPER LAYOUT -- */
.newspaper-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:var(--max-w);margin:0 auto}
@media(min-width:700px){.newspaper-grid{grid-template-columns:1fr 140px 1fr;gap:0}}
.np-col{padding:0 1.5rem}
.np-col-quote{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:0 .5rem}
@media(min-width:700px){.np-col-main{border-right:1px solid var(--border);padding-right:2rem}.np-col-img{border-left:1px solid var(--border);padding-left:2rem}}
.np-dropcap{font-size:.92rem;line-height:1.7;color:var(--text2);margin-bottom:1rem}
.np-dropcap strong{font-family:var(--font-title);color:var(--gold);font-size:1.3em}
.np-body{font-size:.85rem;line-height:1.75;color:var(--text2);margin-bottom:.75rem}
.np-rule{border:none;border-top:1px solid var(--border);margin:1.5rem 0}
.np-pullquote{margin:0;padding:0 .5rem;text-align:center}
.np-pullquote p{font-family:var(--font-title);font-size:.95rem;line-height:1.5;color:var(--gold);font-style:italic}
.np-divider-v{width:1px;flex:1;background:linear-gradient(to bottom,transparent,var(--border) 30%,var(--border) 70%,transparent);min-height:40px}
.np-badge-stack{display:flex;flex-direction:column;gap:.75rem;align-items:center}
.np-badge-num{font-family:var(--font-title);font-size:1.5rem;color:var(--gold);line-height:1}
.np-badge-label{font-family:var(--font-sub);font-size:.55rem;letter-spacing:.15em;color:var(--text2);text-transform:uppercase;margin-top:.15rem}
.np-img-wrap img{width:100%;border-radius:var(--radius);filter:saturate(.8) brightness(.9);border:1px solid var(--border);display:block}
.np-img-caption{font-family:var(--font-sub);font-size:.55rem;letter-spacing:.1em;color:var(--text2);text-align:center;margin-top:.5rem;text-transform:uppercase}
/* -- FOOTER PREMIUM -- */
#footer{background:var(--bg);border-top:1px solid var(--border);padding:3rem 1.5rem 1.5rem;position:relative}
.footer-inner{display:grid;grid-template-columns:1fr;gap:2rem;max-width:var(--max-w);margin:0 auto;padding-bottom:2rem;border-bottom:1px solid var(--border)}
@media(min-width:600px){.footer-inner{grid-template-columns:1fr 1fr 1fr;align-items:start}}
.footer-brand{text-align:center}
@media(min-width:600px){.footer-brand{text-align:left}}
.footer-logo img{opacity:.85;filter:drop-shadow(0 2px 8px rgba(200,160,74,.2))}
.footer-tagline{font-family:var(--font-sub);font-size:.7rem;letter-spacing:.1em;color:var(--text2);margin-top:.75rem;line-height:1.6;text-transform:uppercase}
.footer-h-title{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:.75rem;opacity:.7}
.hours-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.7rem}
.hours-table td{padding:.3rem 0;color:var(--text2)}
.hours-table td:last-child{text-align:right;color:var(--text)}
.hours-closed{color:var(--text2)!important;opacity:.5}
.footer-cucina-note{font-size:.62rem;color:var(--text2);opacity:.5;margin-top:.5rem;font-style:italic}
.footer-nav .footer-links{display:flex;flex-direction:column;gap:.4rem}
.footer-nav .footer-links a{font-family:var(--font-sub);font-size:.7rem;letter-spacing:.08em;color:var(--text2);text-decoration:none;text-transform:uppercase;transition:color var(--transition)}
.footer-nav .footer-links a:hover{color:var(--gold)}
.footer-bottom{text-align:center;padding-top:1.5rem;max-width:var(--max-w);margin:0 auto}
.footer-copy{font-size:.7rem;color:var(--text2);line-height:1.7;margin-bottom:.5rem}
.footer-love{font-size:.65rem;color:var(--text2);opacity:.4;letter-spacing:.05em;margin-bottom:.25rem}
.footer-powered a{font-family:var(--font-sub);font-size:.6rem;letter-spacing:.15em;color:var(--text2);text-decoration:none;text-transform:uppercase;opacity:.5;transition:opacity var(--transition)}
.footer-powered a:hover{opacity:1;color:var(--gold)}
.footer-powered span{color:var(--gold)}

/* -- FIX MOBILE BIRRE -- */
@media(max-width:600px){
  .birre-grid{grid-template-columns:1fr!important}
  .birra-flip-wrap{min-height:260px}
}

/* -- MOOD CELL SVG -- */
.mood-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;margin-bottom:.4rem}
.mood-icon svg{transition:transform .2s}
.mood-cell:hover .mood-icon svg{transform:scale(1.2)}
.mood-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.9rem .6rem;gap:.15rem}

/* -- QUIZ BIGLIETTO PREMIUM -- */
.quiz-ticket-preview{margin:1.25rem auto 0;max-width:420px;border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.4);border:1px solid var(--border);position:relative}
.quiz-ticket-preview canvas{display:block;width:100%;height:auto}
.quiz-ticket-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.25rem;flex-wrap:wrap}
.quiz-ticket-dl{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--bg);font-family:var(--font-sub);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:.6rem 1.4rem;border-radius:2rem;border:none;cursor:pointer;font-weight:700;transition:opacity .2s}
.quiz-ticket-dl:hover{opacity:.85}
.quiz-retry{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-sub);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.6rem 1.2rem;border-radius:2rem;cursor:pointer;transition:border-color .2s,color .2s}
.quiz-retry:hover{border-color:var(--gold);color:var(--gold)}
.quiz-res-header{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;border-left:3px solid var(--beer-accent,var(--gold))}
.quiz-result-name{font-family:var(--font-title);font-size:1.4rem;line-height:1}
.quiz-result-style{font-family:var(--font-sub);font-size:.62rem;letter-spacing:.12em;color:var(--text2);text-transform:uppercase;margin-top:.25rem}
.quiz-result-desc{font-size:.82rem;color:var(--text2);line-height:1.6;margin:1rem 0;font-style:italic;text-align:center;max-width:420px;margin-left:auto;margin-right:auto}

/* -- SCRATCH PREMIUM -- */
.scratch-wrap{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:400px;margin:0 auto;position:relative}
#scratchCanvas{border-radius:var(--radius);cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='6' fill='%23c8a04a' opacity='.6'/%3E%3C/svg%3E") 12 12,crosshair;box-shadow:0 4px 24px rgba(0,0,0,.35);border:1px solid var(--border);touch-action:none;max-width:100%;width:100%;height:auto}
.scratch-reveal{text-align:center;font-family:var(--font-title);font-size:1.1rem;color:var(--gold);min-height:2rem}
.scratch-reset{font-family:var(--font-sub);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;background:transparent;border:1px solid var(--border);color:var(--text2);padding:.45rem 1rem;border-radius:2rem;cursor:pointer;transition:all .2s}
.scratch-reset:hover{border-color:var(--gold);color:var(--gold)}

/* -- PASSPORT MOBILE -- */
@media(max-width:600px){
  .passport-book{padding:1rem .75rem}
  .passport-cover{padding:1.5rem 1rem}
  .passport-cover-title{font-size:1rem;letter-spacing:.12em}
  .passport-beers{grid-template-columns:repeat(3,1fr)!important;gap:.5rem!important}
  .pp-stamp{min-height:80px!important}
  .pp-stamp-name{font-size:.52rem!important}
  .passport-badges{grid-template-columns:repeat(3,1fr)!important;gap:.5rem!important}
  .badge{padding:.6rem .4rem!important}
  .badge-name{font-size:.55rem!important}
}

/* -- SPLIT-FLAP MOBILE -- */
@media(max-width:700px){
  .sfb-board{padding:.75rem .5rem!important;overflow-x:auto}
  .sfb-header{display:none}
  .sfb-row{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.6rem .5rem;border-bottom:1px solid var(--border)}
  .sfb-row:last-child{border-bottom:none}
  .sfb-binario{font-size:.6rem;opacity:.6;margin-bottom:.1rem;min-width:0}
  .sfb-evento,.sfb-orario,.sfb-stato{font-size:.72rem;letter-spacing:.04em}
  .sfb-cell{min-width:8px!important;font-size:.65rem!important}
  .sfb-evento{font-size:.78rem}
}

/* -- FIX: SCRATCH OUTER STACKING -- */
.scratch-outer{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  max-width:400px;
  margin:0 auto 1rem;
}
.scratch-outer #scratchReveal{
  position:absolute;
  inset:0;
  z-index:1;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius);
  background:var(--bg3);
  border:1px solid var(--border);
}
.scratch-outer #scratchCanvas{
  position:relative;
  z-index:2;
  max-width:100%;
  border-radius:var(--radius);
  cursor:crosshair;
  box-shadow:0 4px 24px rgba(0,0,0,.35);
  border:1px solid var(--border);
  touch-action:none;
  display:block;
}
/* Scratch reveal icon */
.sc-beer-icon{width:52px;height:52px;margin:0 auto .5rem;display:block}
.scratch-content{text-align:center;padding:1rem 1.5rem}
.sc-title{font-family:var(--font-title);font-size:1rem;color:var(--gold);margin-bottom:.25rem}
.sc-item{font-size:.82rem;color:var(--text);margin-bottom:.35rem}
.sc-price{font-family:var(--font-title);font-size:1.5rem;color:var(--gold);margin-bottom:.25rem}
.sc-note{font-size:.65rem;color:var(--text2);opacity:.6;text-transform:uppercase;letter-spacing:.1em}

/* -- FIX: TAPPO SIZE -- */
.tappo-cap{width:170px;height:170px;cursor:pointer}
.cap-inner svg{display:block}

/* -- FIX: TIMELINE DOT PULSE -- */
.tl-dot--pulse{animation:tlPulse 2s ease-in-out infinite}
@keyframes tlPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(200,160,74,.5),0 0 0 0 rgba(200,160,74,.3)}
  50%{box-shadow:0 0 0 6px rgba(200,160,74,.15),0 0 0 12px rgba(200,160,74,.05)}
}

/* -- FIX: SFB STATO WIDTH -- */
.sfb-stato{min-width:calc(12*1.25rem)!important}

/* -- FIX: MOOD ICON SIZE + GLOW -- */
.mood-icon svg{width:36px!important;height:36px!important}
.mood-cell:hover .mood-icon svg{filter:drop-shadow(0 0 8px currentColor)}

/* -- PASSPORT COUNTER POP -- */
@keyframes ppCountPop{0%{transform:scale(1)}50%{transform:scale(1.35);color:var(--gold)}100%{transform:scale(1)}}
.pp-count-pop{animation:ppCountPop .4s ease}
