:root{
  --bg:#07121d;
  --gold:#a88b45;
  --gold-soft:#c7ad67;
  --red:#a90000;
  --white:#f4f1e8;
  --muted:#a99352;
  --nav-h:54px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:#07121d;
  color:var(--gold);
  font-family:Arial, Helvetica, sans-serif;
  font-size:14px;
  line-height:1.7;
  overflow-x:hidden;
}
body::before,
body::after{content:none;display:none}
.site-nav, main{position:relative;z-index:2}
.floating-dust{
  position:fixed;
  inset:0;
  z-index:1;
  pointer-events:none;
  overflow:hidden;
}
.dust-particle{
  position:absolute;
  left:0;
  top:0;
  width:var(--size);
  height:var(--size);
  border-radius:50%;
  opacity:0;
  transform:translate3d(var(--x), var(--y), 0) scale(var(--scale));
  background:radial-gradient(circle, rgba(255,247,217,.98) 0%, rgba(255,228,155,.84) 34%, rgba(226,174,78,.34) 60%, transparent 78%);
  box-shadow:0 0 calc(var(--size) * 2.3) rgba(255,223,145,.62);
  filter:blur(var(--blur));
  will-change:transform, opacity;
  animation:
    dust-float var(--duration) ease-in-out var(--delay) infinite alternate,
    dust-twinkle var(--twinkle) ease-in-out var(--delay2) infinite alternate;
}
.dust-particle.back{background:radial-gradient(circle, rgba(255,233,171,.72) 0%, rgba(212,168,84,.32) 54%, transparent 78%);box-shadow:0 0 calc(var(--size) * 1.5) rgba(255,221,143,.30)}
.dust-particle.mid{background:radial-gradient(circle, rgba(255,246,214,.92) 0%, rgba(245,201,108,.62) 44%, rgba(177,136,60,.22) 70%, transparent 82%)}
.dust-particle.front{background:radial-gradient(circle, rgba(255,252,231,.98) 0%, rgba(255,226,151,.62) 42%, rgba(222,170,77,.22) 68%, transparent 82%);box-shadow:0 0 calc(var(--size) * 3.4) rgba(255,226,154,.58)}
@keyframes dust-float{
  0%{
    transform:translate3d(var(--x), var(--y), 0) scale(var(--scale));
    opacity:calc(var(--opacity) * .52);
  }
  27%{
    transform:translate3d(calc(var(--x) + var(--dx1)), calc(var(--y) + var(--dy1)), 0) scale(calc(var(--scale) * 1.08));
    opacity:calc(var(--opacity) * 1.06);
  }
  53%{
    transform:translate3d(calc(var(--x) + var(--dx2)), calc(var(--y) + var(--dy2)), 0) scale(calc(var(--scale) * .96));
    opacity:calc(var(--opacity) * .72);
  }
  79%{
    transform:translate3d(calc(var(--x) + var(--dx3)), calc(var(--y) + var(--dy3)), 0) scale(calc(var(--scale) * 1.13));
    opacity:calc(var(--opacity) * 1.06);
  }
  100%{
    transform:translate3d(calc(var(--x) + var(--dx4)), calc(var(--y) + var(--dy4)), 0) scale(var(--scale));
    opacity:calc(var(--opacity) * .60);
  }
}
@keyframes dust-twinkle{
  0%,100%{filter:blur(var(--blur));}
  45%{filter:blur(calc(var(--blur) + .4px));}
  55%{filter:blur(calc(var(--blur) + .1px));}
}
@media (prefers-reduced-motion: reduce){
  .dust-particle{animation:none;opacity:calc(var(--opacity) * .7)}
  html{scroll-behavior:auto}
  .hero-frame img.hero-photo, .hero-logo-wrap, .hero-action-row, .page-menu, .reveal-on-scroll, .site-nav{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}
}
a{color:inherit;text-decoration:none}
.site-nav{
  position:sticky;
  top:0;
  z-index:20;
  height:var(--nav-h);
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(6,18,29,.96);
}
.nav-inner{
  width:min(980px,94vw);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.nav-inner a{
  color:var(--gold-soft);
  font-size:12px;
  line-height:1;
  white-space:nowrap;
  padding:12px 0;
}
.nav-inner a:hover,
.nav-inner a.active{color:#fff}
.mobile-toggle{display:none}
.hero{
  min-height:calc(100vh - var(--nav-h));
  padding:0;
}
.hero-frame{
  position:relative;
  width:100vw;
  height:calc(100vh - var(--nav-h));
  margin:0;
  overflow:hidden;
}
.hero-frame{
  background:#07121d;
}
.hero-frame img.hero-photo{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
  filter:brightness(.82);
  transform:scale(1.02);
  opacity:0;
}
.hero-frame::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:32%;
  pointer-events:none;
  background:linear-gradient(to bottom, rgba(7,18,29,0) 0%, rgba(7,18,29,.42) 58%, #07121d 100%);
  z-index:1;
}
.hero-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:22px;
  padding:calc(var(--nav-h) + 18px) 20px 58px;
}
.hero-overlay.no-logo{
  justify-content:center;
  padding:0 20px;
}
.hero-logo-wrap{
  width:min(760px,84vw);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transform:translateY(30px);
}
.hero-logo{
  width:min(760px,84vw);
  max-width:100%;
  display:block;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.46));
}
.hero-action-row{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:28px;
  opacity:0;
  transform:none;
}
.hero-action-row-initial{
  margin-top:4vh;
}
.hero-button{
  width:320px;
  min-height:58px;
  padding:14px 20px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:3px solid #610000;
  background:#9a0000;
  color:#fff;
  font-family:Georgia, 'Times New Roman', serif;
  font-size:18px;
  letter-spacing:.14em;
  font-weight:700;
  text-transform:uppercase;
  box-shadow:0 0 0 1px rgba(0,0,0,.8) inset, 0 2px 8px rgba(0,0,0,.35);
  text-align:center;
}
.hero-button:hover{background:#b40000}
body.is-ready .hero-frame img.hero-photo{animation:heroPhotoIn 2.3s ease-out .55s both}
body.is-ready .hero-logo-wrap{animation:heroRise .95s cubic-bezier(.22,.61,.36,1) .18s both}
body.is-ready .hero-action-row{animation:heroFade .9s ease .08s both}
body.is-ready .page-menu{animation:pageFadeIn 1.25s ease both}
.reveal-on-scroll{opacity:0;transform:translateY(34px);transition:opacity .95s ease, transform .95s cubic-bezier(.22,.61,.36,1)}
.reveal-on-scroll.is-visible{opacity:1;transform:none}
@keyframes heroRise{
  from{opacity:0;transform:translateY(34px)}
  to{opacity:1;transform:none}
}
@keyframes heroFade{
  from{opacity:0}
  to{opacity:1}
}
@keyframes pageFadeIn{
  from{opacity:0}
  to{opacity:1}
}
@keyframes heroPhotoIn{
  from{opacity:0;transform:scale(1.06);filter:brightness(.70)}
  to{opacity:1;transform:scale(1.02);filter:brightness(.82)}
}
.section-separator{
  width:min(860px,82vw);
  height:1px;
  margin:26px auto 8px;
  background:linear-gradient(90deg, transparent 0%, rgba(199,173,103,.65) 12%, rgba(199,173,103,.65) 88%, transparent 100%);
  opacity:.6;
}
.section{
  width:min(1120px,88vw);
  margin:0 auto;
  padding:70px 0;
}
.section-title{
  margin:0 0 32px;
  text-align:center;
  color:#fff;
  font-family:Georgia, 'Times New Roman', serif;
  font-size:28px;
  letter-spacing:.28em;
  text-transform:uppercase;
}
.restaurant-text{
  width:min(980px,92vw);
  margin:0 auto;
  text-align:center;
  color:var(--muted);
  font-size:18px;
  line-height:2.35;
}
.restaurant-text p{
  margin:0 0 16px;
  white-space:nowrap;
}
.live-note{
  display:block;
  margin-top:10px;
  color:inherit;
  font:inherit;
  letter-spacing:inherit;
}
.down-mark{
  width:30px;
  height:60px;
  margin:42px auto 0;
  position:relative;
}
.down-mark::before{
  content:"";
  position:absolute;
  left:50%;top:0;
  width:1px;height:48px;
  background:var(--gold);
}
.down-mark::after{
  content:"";
  position:absolute;
  left:50%;bottom:7px;
  width:18px;height:18px;
  border-right:2px solid var(--gold);
  border-bottom:2px solid var(--gold);
  transform:translateX(-50%) rotate(45deg);
}
.gallery-section{padding-top:20px}
.gallery{
  width:min(860px,86vw);
  margin:0 auto;
}
.gallery-main{
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#03080d;
  border:1px solid rgba(168,139,69,.28);
}
.gallery-main img{
  width:100%;height:100%;object-fit:cover;display:block;
  opacity:1;
  transition:opacity 1.45s ease-in-out;
}
.gallery-main img.is-fading{
  opacity:0;
}
.thumbs{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:18px;
  overflow-x:auto;
  padding:4px 0 8px;
}
.thumbs button{
  width:58px;height:54px;
  padding:2px;
  border:1px solid rgba(255,255,255,.25);
  background:none;cursor:pointer;flex:0 0 auto;
}
.thumbs img{width:100%;height:100%;object-fit:cover;display:block;opacity:.78}
.thumbs button.active{border-color:var(--gold-soft);box-shadow:0 0 0 1px rgba(199,173,103,.65)}
.thumbs button.active img,.thumbs button:hover img{opacity:1}
.music-block{
  width:min(980px,88vw);
  margin:80px auto 0;
  display:grid;
  grid-template-columns:0.9fr 1.2fr;
  gap:70px;
  align-items:center;
}
#musica .music-block > div:first-child,
.contacts{
  position:relative;
}
.eyebrow{
  color:var(--gold-soft);
  text-transform:uppercase;
  letter-spacing:.45em;
  font-size:11px;
  margin:0 0 10px;
}
.music-title{
  margin:0 0 38px;
  color:#fff;
  font-family:Georgia, 'Times New Roman', serif;
  font-size:32px;
  letter-spacing:.22em;
}
.music-text{
  color:var(--muted);
  font-size:18px;
  line-height:2.35;
}
.music-card{
  position:relative;
  margin-top:0;
  background:#000 url("assets/images/cantante-drink.jpg") center/cover no-repeat;
  box-shadow:0 20px 28px rgba(0,0,0,.4);
  aspect-ratio:1/1;
  overflow:hidden;
  clip-path:polygon(14px 0, calc(100% - 14px) 0, 100% 14px, 100% calc(100% - 14px), calc(100% - 14px) 100%, 14px 100%, 0 calc(100% - 14px), 0 14px);
}
.music-card::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border:1px solid rgba(0,0,0,.55);
  clip-path:inherit;
}
.music-card video,.music-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.95;
  transform:scale(1.15);
  transform-origin:center;
  transition:opacity .4s ease;
}
.cocktail-strip{
  width:100%;
  height:470px;
  margin-top:70px;
  overflow:hidden;
  background-image:linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.08)), url("assets/images/cocktail-wide.jpg");
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
}
.hours-section{
  width:min(760px,86vw);
  margin:0 auto;
  padding:70px 0 34px;
}
.hours-standalone{
  width:min(640px,100%);
  margin:0 auto;
}
.hours-list{margin:0;color:var(--white);font-family:Georgia, 'Times New Roman', serif;font-size:15px;line-height:1.5}
.hours-list div{display:grid;grid-template-columns:130px 1fr;gap:18px;align-items:baseline;padding:10px 0;border-bottom:1px dotted rgba(199,173,103,.38)}
.hours-list div:last-child{border-bottom:0}
.hours-list dt{font-weight:700;position:relative;padding-left:16px}
.hours-list dt::before{content:"○";position:absolute;left:0;top:0;color:var(--gold-soft);font-size:10px}
.hours-list dd{margin:0;text-align:right;color:#eadfbd;white-space:nowrap}
.contacts{
  width:min(760px,86vw);
  margin:0 auto;
  padding:34px 0 76px;
  text-align:center;
  position:relative;
}
.contact-columns{
  width:min(980px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:34px;
  align-items:start;
}
.contact-col{
  color:var(--gold-soft);
  font-size:16px;
  line-height:1.9;
  text-align:center;
}
.contact-col p{margin:0}
.contact-col a{display:inline-block}
.contact-label{
  margin:0 0 10px!important;
  font-family:Georgia, 'Times New Roman', serif;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:#fff;
  font-size:12px;
}
.map-wrap{width:100%;height:445px;margin:15px 0 0;background:#333;overflow:hidden}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(15%) invert(90%) hue-rotate(170deg) saturate(70%)}
.page-menu{
  opacity:0;
  min-height:calc(100vh - var(--nav-h));
  padding:78px 0 96px;
  background-image:radial-gradient(circle at 72% 18%, rgba(255,244,178,.8), rgba(255,244,178,.28) 9px, transparent 16px);
}
.menu-title{
  margin:0 0 48px;
  text-align:center;
  color:#b50000;
  font-family:Georgia, 'Times New Roman', serif;
  font-size:44px;
  font-weight:700;
}
.menu-image{
  display:block;
  width:min(540px,78vw);
  max-height:none;
  margin:0 auto;
  box-shadow:none;
}
.menu-image.natale{width:min(540px,78vw)}

.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:60;padding:14px 18px;background:rgba(3,9,14,.96);border-top:1px solid rgba(168,139,69,.38);box-shadow:0 -10px 24px rgba(0,0,0,.28)}
.cookie-banner[hidden]{display:none!important}
.cookie-banner__inner{width:min(1100px,94vw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:18px}
.cookie-banner p{margin:0;color:#e9debf;font-size:13px;line-height:1.5}
.cookie-ok{border:1px solid rgba(168,139,69,.7);background:#9a0000;color:#fff;padding:10px 22px;font-family:Georgia,'Times New Roman',serif;font-size:14px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;flex:0 0 auto}
.cookie-ok:hover{background:#b40000}

.site-footer{
  padding:24px 20px 28px;
  text-align:center;
  color:var(--gold-soft);
  background:#07121d;
  border-top:1px solid rgba(168,139,69,.35);
  font-family:Georgia, 'Times New Roman', serif;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:13px;
}
@media (max-width: 800px){
  :root{--nav-h:56px}
  .site-nav{height:auto;min-height:var(--nav-h);align-items:stretch}
  .mobile-toggle{
    display:block;
    position:absolute;
    right:18px;top:14px;
    border:0;background:transparent;color:var(--gold-soft);
    font-size:24px;line-height:1;cursor:pointer;
  }
  .nav-inner{
    width:100%;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    gap:0;
    padding:52px 0 12px;
    display:none;
  }
  .site-nav.open .nav-inner{display:flex}
  .nav-inner a{font-size:13px;padding:10px 0}
  .hero{padding:0;min-height:calc(100vh - var(--nav-h))}
  .hero-frame{width:100%;height:calc(100vh - var(--nav-h))}
  .hero-logo-wrap,.hero-logo{width:min(88vw,640px)}
  .hero-action-row{gap:18px}
  .hero-button{width:240px;min-height:52px;font-size:14px;padding:10px 12px}
  .section{width:86vw;padding:48px 0}
  .section-title{font-size:23px;letter-spacing:.22em}
  .restaurant-text{width:86vw;font-size:15px;line-height:2.05}
  .restaurant-text p{white-space:normal;margin-bottom:14px}
  .live-note{font-size:inherit}
  .gallery{width:88vw}
  .music-block{grid-template-columns:1fr;gap:30px;margin-top:58px;width:86vw}
    .hours-section,.contacts{width:86vw}
  .hours-list div{grid-template-columns:112px 1fr;font-size:14px}
  .hours-list dd{white-space:normal}
  .contact-columns{grid-template-columns:1fr;gap:20px}
  .cocktail-strip{background-attachment:scroll;height:300px}
  .music-title{font-size:27px;margin-bottom:24px}
  .cocktail-strip{height:240px;margin-top:50px}
  .contacts{padding:48px 0 54px}
  .map-wrap{height:330px}
  .menu-title{font-size:38px;margin-bottom:36px}
  .menu-image{width:82vw}
  .menu-image.natale{width:82vw}
}
@media (max-width:800px){
  .cookie-banner__inner{flex-direction:column;align-items:flex-start}
  .cookie-ok{padding:9px 18px}
}

@media (max-width:480px){
  .section-separator{width:min(86vw,560px);margin:18px auto 4px}
  body{font-size:13px}
  .hero-frame{height:calc(100vh - var(--nav-h))}
  .hero-overlay{gap:14px;padding:calc(var(--nav-h) + 12px) 14px 42px}
  .hero-logo-wrap,.hero-logo{width:min(92vw,560px)}
  .hero-action-row{gap:16px}
  .section-title{font-size:20px;letter-spacing:.18em}
  .thumbs button{width:50px;height:46px}
  .hours-card,.contact-card{padding:22px 18px}
  .hours-card h3{font-size:22px;text-align:center}
  .hours-list div{grid-template-columns:1fr;gap:2px;text-align:center}
  .hours-list dt{padding-left:0}
  .hours-list dt::before{display:none}
  .hours-list dd{text-align:center}
  .contact-card{font-size:15px}
  .menu-title{font-size:34px}
}
