/* ════════════════════════════════════
   DESIGN TOKENS
════════════════════════════════════ */
:root {
  --ink:        #0c0b09;
  --ink-2:      #141310;
  --ink-3:      #1c1a16;
  --paper:      #f4ede0;
  --cream:      #ece4d2;
  --gold:       #b8965a;
  --gold-lt:    #d4aa6a;
  --gold-pale:  rgba(184,150,90,.12);
  --gold-glow:  rgba(184,150,90,.06);
  --sage:       #4a5e42;
  --forest:     #1a2018;
  --moss:       #2d3829;
  --red:        #8b2e2e;
  --muted:      rgba(244,237,224,.5);
  --border:     rgba(184,150,90,.18);
  --white:      #faf6ee;
  --ease:       cubic-bezier(.25,.46,.45,.94);
}

/* ════════════════════════════════════
   RESET & BASE
════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  background:var(--ink);
  color:var(--white);
  font-family:'Jost',sans-serif;
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
  cursor:none;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;}

/* ════════════════════════════════════
   CURSOR
════════════════════════════════════ */
#cur{
  position:fixed;width:7px;height:7px;
  background:var(--gold-lt);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .15s,height .15s,background .2s;
  mix-blend-mode:screen;
}
#cur-ring{
  position:fixed;width:34px;height:34px;
  border:1px solid rgba(184,150,90,.35);border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .2s var(--ease),height .2s var(--ease),border-color .2s;
}
body:has(a:hover) #cur-ring,
body:has(button:hover) #cur-ring{width:48px;height:48px;border-color:rgba(184,150,90,.6);}

/* ════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.visible{opacity:1;transform:none;}
.reveal-l{opacity:0;transform:translateX(-40px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal-l.visible{opacity:1;transform:none;}
.reveal-r{opacity:0;transform:translateX(40px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal-r.visible{opacity:1;transform:none;}
[data-delay="1"]{transition-delay:.1s!important;}
[data-delay="2"]{transition-delay:.2s!important;}
[data-delay="3"]{transition-delay:.3s!important;}
[data-delay="4"]{transition-delay:.4s!important;}
[data-delay="5"]{transition-delay:.5s!important;}
[data-delay="6"]{transition-delay:.6s!important;}

/* ════════════════════════════════════
   NAV
════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:22px 56px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .4s,backdrop-filter .4s,padding .3s;
}
#nav.scrolled{
  background:rgba(12,11,9,.88);
  backdrop-filter:blur(16px);
  padding:14px 56px;
  border-bottom:1px solid var(--border);
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;font-weight:400;letter-spacing:.3em;
  color:var(--gold-lt);
  display:flex;align-items:center;gap:6px;
}
.nav-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);margin-top:1px;}
.nav-links{display:flex;gap:40px;list-style:none;}
.nav-links a{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.4);font-weight:300;
  transition:color .2s;
  position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-3px;left:0;right:0;
  height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s;
}
.nav-links a:hover{color:var(--gold-lt);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-right{display:flex;align-items:center;gap:24px;}
.nav-cta{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:11px 26px;border:1px solid var(--gold);
  color:var(--gold-lt);font-weight:300;
  transition:all .3s;
}
.nav-cta:hover{background:var(--gold);color:var(--ink);}
.nav-burger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;padding:4px;
}
.nav-burger span{
  width:24px;height:1px;background:var(--white);
  transition:all .3s;display:block;
}
.nav-burger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px);}

/* Mobile menu */
#mobile-menu{
  position:fixed;inset:0;z-index:190;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  transform:translateX(100%);transition:transform .45s var(--ease);
}
#mobile-menu.open{transform:none;}
#mobile-menu a{
  font-family:'Cormorant Garamond',serif;
  font-size:42px;font-weight:300;
  color:rgba(255,255,255,.5);
  transition:color .2s;
}
#mobile-menu a:hover{color:var(--gold-lt);}

/* ════════════════════════════════════
   HERO
════════════════════════════════════ */
#hero{
  min-height:100vh;position:relative;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 80%,rgba(184,150,90,.07) 0%,transparent 70%),
    radial-gradient(ellipse 40% 50% at 80% 20%,rgba(74,94,66,.08) 0%,transparent 60%),
    radial-gradient(ellipse 60% 40% at 10% 60%,rgba(26,26,20,.8) 0%,transparent 70%);
}
/* Animated grain */
.hero-grain{
  position:absolute;inset:0;opacity:.025;
  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'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}
/* Big kanji watermark */
.hero-kanji{
  position:absolute;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(300px,40vw,600px);
  font-weight:300;color:rgba(184,150,90,.028);
  line-height:1;user-select:none;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  pointer-events:none;
  letter-spacing:-.05em;
}
/* Vertical line left */
.hero-vline{
  position:absolute;left:56px;top:0;bottom:0;
  width:1px;background:linear-gradient(to bottom,transparent 10%,rgba(184,150,90,.15) 40%,rgba(184,150,90,.15) 60%,transparent 90%);
}
/* Vertical line right */
.hero-vline-r{
  position:absolute;right:56px;top:0;bottom:0;
  width:1px;background:linear-gradient(to bottom,transparent 10%,rgba(184,150,90,.1) 40%,rgba(184,150,90,.1) 60%,transparent 90%);
}
.hero-content{
  position:relative;z-index:2;
  text-align:center;padding:0 40px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:10px;letter-spacing:.45em;text-transform:uppercase;
  color:var(--gold);font-weight:300;
  margin-bottom:36px;
  animation:fadeIn .8s .3s both;
}
.hero-eyebrow-line{width:40px;height:1px;background:var(--gold);opacity:.5;}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(80px,14vw,180px);
  font-weight:300;line-height:.88;
  letter-spacing:-.02em;
  animation:fadeUp .9s .1s both;
}
.hero-title .t1{display:block;color:var(--white);}
.hero-title .t2{display:block;color:var(--gold-lt);font-style:italic;}
.hero-sub{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(16px,2.5vw,24px);
  font-style:italic;color:rgba(255,255,255,.35);
  margin-top:20px;letter-spacing:.08em;
  animation:fadeIn .8s .5s both;
}
.hero-divider{
  width:1px;height:60px;background:linear-gradient(to bottom,var(--gold),transparent);
  margin:36px auto;opacity:.45;
  animation:fadeIn 1s .6s both;
}
.hero-ctas{
  display:flex;align-items:center;justify-content:center;gap:16px;
  animation:fadeIn .8s .7s both;
}
.btn-gold{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  padding:14px 36px;background:var(--gold);color:var(--ink);
  border:none;font-weight:400;
  transition:all .3s;display:inline-block;
}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px);}
.btn-outline{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  padding:14px 36px;background:none;
  border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);
  font-weight:300;transition:all .3s;display:inline-block;
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold-lt);}

/* Hero stats bar */
.hero-stats{
  position:absolute;bottom:40px;left:0;right:0;
  display:flex;align-items:center;justify-content:center;gap:0;
  z-index:2;
  animation:fadeIn 1s .9s both;
}
.hero-stat{
  padding:0 40px;
  border-right:1px solid rgba(184,150,90,.15);
  text-align:center;
}
.hero-stat:last-child{border-right:none;}
.stat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;font-weight:300;color:var(--gold-lt);
  display:block;line-height:1;margin-bottom:4px;
}
.stat-label{
  font-size:9px;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(255,255,255,.25);font-weight:300;
}

/* Scroll indicator */
.hero-scroll{
  position:absolute;right:56px;bottom:40px;
  writing-mode:vertical-lr;
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.2);
  display:flex;align-items:center;gap:12px;
  z-index:2;
  animation:fadeIn 1s 1s both;
}
.hero-scroll-line{
  width:1px;height:50px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{
  0%,100%{transform:scaleY(1);transform-origin:top;}
  50%{transform:scaleY(.4);transform-origin:top;}
}

/* ════════════════════════════════════
   MARQUEE STRIP
════════════════════════════════════ */
.marquee-strip{
  background:var(--gold);
  padding:14px 0;overflow:hidden;
  border-top:1px solid rgba(0,0,0,.1);
}
.marquee-track{
  display:flex;gap:0;
  animation:marquee 18s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.marquee-item{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink);font-weight:400;
  padding:0 36px;
  display:flex;align-items:center;gap:36px;
}
.marquee-item::after{content:'◆';font-size:8px;opacity:.5;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ════════════════════════════════════
   CHI SIAMO
════════════════════════════════════ */
#about{
  padding:120px 56px;
  max-width:1300px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:100px;align-items:start;
}
.about-label{
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);font-weight:300;
  display:flex;align-items:center;gap:12px;
  margin-bottom:22px;
}
.about-label::before{content:'';width:32px;height:1px;background:var(--gold);opacity:.5;}
.about-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(40px,5vw,64px);
  font-weight:300;line-height:1.0;
  letter-spacing:-.02em;margin-bottom:28px;
}
.about-title em{font-style:italic;color:var(--gold-lt);}
.about-body{
  font-size:14.5px;color:var(--muted);
  line-height:1.9;margin-bottom:16px;
}
.about-body strong{color:var(--white);font-weight:400;}
.about-signature{
  margin-top:36px;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-size:22px;
  color:rgba(255,255,255,.3);
}
/* About visual panel */
.about-visual{position:relative;}
.about-img-wrap{
  aspect-ratio:3/4;
  background:var(--ink-3);
  border:1px solid var(--border);
  position:relative;overflow:hidden;
}
.about-img-inner{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
}
.about-img-inner svg{width:80%;height:80%;opacity:.15;}
.about-img-label{
  position:absolute;bottom:20px;left:20px;right:20px;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.2);
}
.about-badge{
  position:absolute;top:-20px;right:-20px;
  width:120px;height:120px;
  border-radius:50%;
  background:var(--gold);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;
}
.badge-num{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:300;color:var(--ink);line-height:1;
}
.badge-txt{
  font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(12,11,9,.6);font-weight:400;text-align:center;
  line-height:1.2;
}

/* ════════════════════════════════════
   VALUES
════════════════════════════════════ */
#values{
  background:var(--paper);
  padding:120px 56px;
}
.values-inner{max-width:1200px;margin:0 auto;}
.values-header{
  text-align:center;margin-bottom:80px;
}
.section-eyebrow{
  display:block;font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);font-weight:300;margin-bottom:16px;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(38px,5vw,64px);
  font-weight:300;line-height:1.0;
  letter-spacing:-.02em;color:var(--ink);
}
.section-title em{font-style:italic;color:var(--gold);}
.values-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:2px;background:rgba(184,150,90,.2);
  border:1px solid rgba(184,150,90,.2);
}
.value-card{
  background:var(--paper);
  padding:48px 32px;
  transition:background .3s;
}
.value-card:hover{background:var(--cream);}
.value-icon{
  width:44px;height:44px;
  border:1px solid rgba(184,150,90,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:24px;
  color:var(--ink);
}
.value-name{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;font-weight:400;color:var(--ink);
  margin-bottom:12px;
}
.value-desc{font-size:13px;color:#7a7060;line-height:1.75;}

/* ════════════════════════════════════
   MENU
════════════════════════════════════ */
#menu{
  padding:140px 56px;
  max-width:1200px;margin:0 auto;
}
.menu-header{
  display:grid;grid-template-columns:1fr auto;
  align-items:end;margin-bottom:72px;gap:40px;
}
.menu-tabs{
  display:flex;gap:0;
  border-bottom:1px solid var(--border);
}
.menu-tab{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  padding:14px 28px;background:none;border:none;
  color:rgba(255,255,255,.3);font-weight:300;
  position:relative;transition:color .2s;cursor:pointer;
}
.menu-tab::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;
  height:2px;background:var(--gold);
  transform:scaleX(0);transition:transform .3s;
}
.menu-tab.active{color:var(--gold-lt);}
.menu-tab.active::after{transform:scaleX(1);}
.menu-tab:hover{color:rgba(255,255,255,.6);}
.menu-panel{display:none;}
.menu-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;}
.menu-description{
  font-size:14px;color:var(--muted);line-height:1.85;
  margin-bottom:28px;
}
.menu-price-note{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:300;color:var(--gold-lt);
  margin-bottom:6px;
}
.menu-price-sub{
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.25);
}
.menu-highlights{
  border-top:1px solid var(--border);
  padding-top:24px;margin-top:28px;
}
.menu-hl-title{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;font-weight:300;
}
.menu-hl-list{list-style:none;display:flex;flex-direction:column;gap:8px;}
.menu-hl-list li{
  font-family:'Cormorant Garamond',serif;
  font-size:18px;color:rgba(255,255,255,.6);
  display:flex;align-items:center;gap:10px;
}
.menu-hl-list li::before{
  content:'';width:16px;height:1px;background:var(--gold);opacity:.5;flex-shrink:0;
}
.menu-visual{
  aspect-ratio:4/5;
  background:var(--ink-3);
  border:1px solid var(--border);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.menu-visual-kanji{
  font-family:'Cormorant Garamond',serif;
  font-size:120px;color:rgba(184,150,90,.07);
  user-select:none;line-height:1;
}
.menu-visual-label{
  position:absolute;bottom:20px;left:20px;
  font-size:9px;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(255,255,255,.2);
}
.menu-ctas{
  display:flex;gap:12px;margin-top:32px;flex-wrap:wrap;
}

/* ════════════════════════════════════
   MOSHI GARDEN SECTION
════════════════════════════════════ */
#garden{
  min-height:90vh;
  background:var(--forest);
  position:relative;overflow:hidden;
  display:flex;align-items:center;
}
.garden-bg-full{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 70% at 50% 80%,rgba(74,94,66,.3) 0%,transparent 65%),
    radial-gradient(ellipse 30% 40% at 20% 60%,rgba(45,56,41,.6) 0%,transparent 55%);
}
/* Bamboo silhouettes */
.bamboo{
  position:absolute;bottom:0;
  background:var(--moss);
  opacity:.18;
  border-radius:4px 4px 0 0;
}
.garden-fireflies{position:absolute;inset:0;pointer-events:none;}
.firefly{
  position:absolute;
  width:2px;height:2px;
  border-radius:50%;
  background:var(--gold-lt);
  animation:ff linear infinite;
  opacity:0;
}
@keyframes ff{
  0%,100%{opacity:0;transform:translate(0,0);}
  25%{opacity:.6;}
  50%{opacity:.2;}
  75%{opacity:.5;}
}
.garden-inner{
  position:relative;z-index:2;
  max-width:1200px;margin:0 auto;
  padding:120px 56px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.garden-left{}
.garden-eyebrow{
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(184,150,90,.7);font-weight:300;
  display:flex;align-items:center;gap:12px;margin-bottom:22px;
}
.garden-eyebrow::before{content:'';width:28px;height:1px;background:var(--gold);opacity:.4;}
.garden-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(44px,6vw,80px);
  font-weight:300;line-height:.95;
  letter-spacing:-.02em;color:var(--white);
  margin-bottom:28px;
}
.garden-title em{font-style:italic;color:var(--gold-lt);}
.garden-body{
  font-size:14.5px;color:rgba(240,234,216,.5);
  line-height:1.9;margin-bottom:32px;
}
.garden-features{
  display:grid;grid-template-columns:1fr 1fr;
  gap:14px;margin-bottom:40px;
}
.garden-feature{
  display:flex;gap:12px;align-items:flex-start;
}
.gf-icon{font-size:16px;flex-shrink:0;margin-top:1px;}
.gf-text{font-size:13px;color:rgba(240,234,216,.4);line-height:1.6;}
.gf-text strong{color:rgba(240,234,216,.75);font-weight:400;}
/* Garden illustration panel */
.garden-panel{
  aspect-ratio:3/4;
  border:1px solid rgba(184,150,90,.15);
  background:var(--moss);
  position:relative;overflow:hidden;
}
.garden-panel svg{width:100%;height:100%;}

/* ════════════════════════════════════
   EVENTI
════════════════════════════════════ */
#eventi{
  padding:140px 56px;
  max-width:1200px;margin:0 auto;
}
.eventi-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:60px;gap:40px;
}
.section-link{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);font-weight:300;
  display:flex;align-items:center;gap:8px;
  transition:gap .3s;
  white-space:nowrap;
}
.section-link:hover{gap:14px;}
.section-link::after{content:'→';font-size:14px;}

/* Filter */
.filter-row{
  display:flex;gap:0;
  border-bottom:1px solid var(--border);
  margin-bottom:48px;overflow-x:auto;scrollbar-width:none;
}
.filter-row::-webkit-scrollbar{display:none;}
.filter-btn{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  padding:14px 22px;background:none;border:none;
  color:rgba(255,255,255,.3);font-weight:300;
  position:relative;transition:color .2s;white-space:nowrap;cursor:pointer;
}
.filter-btn::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;
  height:2px;background:var(--gold);
  transform:scaleX(0);transition:transform .3s;
}
.filter-btn.active{color:var(--gold-lt);}
.filter-btn.active::after{transform:scaleX(1);}
.filter-btn:hover{color:rgba(255,255,255,.6);}

/* Recurring strip */
.recur-strip{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--border);margin-bottom:48px;
}
.recur-item{
  padding:22px 24px;
  border-right:1px solid var(--border);
  display:flex;gap:14px;align-items:center;
  transition:background .2s;cursor:default;
}
.recur-item:last-child{border-right:none;}
.recur-item:hover{background:var(--gold-glow);}
.recur-icon-box{
  width:38px;height:38px;flex-shrink:0;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:17px;
}
.recur-info .recur-name{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;color:var(--white);margin-bottom:2px;
}
.recur-info .recur-freq{
  font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);
}

/* Event grid */
.events-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.ev-card{
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.018);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .3s,transform .3s;
  cursor:pointer;
}
.ev-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(184,150,90,.05),transparent 60%);
  opacity:0;transition:opacity .3s;
}
.ev-card:hover{border-color:rgba(184,150,90,.35);transform:translateY(-3px);}
.ev-card:hover::before{opacity:1;}
.ev-card.featured{grid-column:span 2;flex-direction:row;}
.ev-visual{
  aspect-ratio:16/9;
  background:var(--ink-3);
  position:relative;overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.ev-card.featured .ev-visual{aspect-ratio:auto;width:42%;}
.ev-visual svg{width:80%;height:80%;opacity:.25;}
.ev-date-box{
  position:absolute;top:14px;left:14px;
  background:var(--ink);border:1px solid var(--gold);
  padding:7px 11px;text-align:center;
}
.ev-day{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;font-weight:300;color:var(--gold-lt);
  line-height:1;display:block;
}
.ev-mon{
  font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.4);display:block;margin-top:2px;
}
.ev-badge{
  position:absolute;bottom:10px;right:10px;
  font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  padding:3px 10px;font-weight:400;
}
.badge-u{background:rgba(139,46,46,.2);color:#d47270;border:1px solid rgba(139,46,46,.3);}
.badge-p{background:rgba(184,150,90,.15);color:var(--gold-lt);border:1px solid rgba(184,150,90,.25);}
.badge-r{background:rgba(74,94,66,.2);color:#8aab80;border:1px solid rgba(74,94,66,.3);}
.badge-f{background:rgba(100,120,160,.2);color:#90a8d4;border:1px solid rgba(100,120,160,.3);}
.ev-body{padding:22px;flex:1;display:flex;flex-direction:column;}
.ev-time{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.ev-title{
  font-family:'Cormorant Garamond',serif;
  font-size:21px;font-weight:400;color:var(--white);
  line-height:1.2;margin-bottom:8px;
}
.ev-card.featured .ev-title{font-size:28px;}
.ev-desc{font-size:12.5px;color:rgba(255,255,255,.38);line-height:1.7;flex:1;}
.ev-footer{
  margin-top:16px;padding-top:14px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;
}
.ev-spots{font-size:11px;color:rgba(255,255,255,.25);}
.ev-spots span{color:var(--gold-lt);}
.ev-btn{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  padding:7px 16px;border:1px solid rgba(184,150,90,.4);
  color:var(--gold-lt);background:none;
  transition:all .25s;font-weight:300;
}
.ev-btn:hover{background:var(--gold);color:var(--ink);border-color:var(--gold);}
.ev-card.hidden{display:none;}

/* ════════════════════════════════════
   GALLERIA
════════════════════════════════════ */
#galleria{
  background:var(--paper);
  padding:140px 56px;
}
.galleria-inner{max-width:1200px;margin:0 auto;}
.gallery-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:56px;
}
.gallery-header .section-title{color:var(--ink);}
.gallery-header .section-eyebrow{color:var(--gold);}
/* Masonry-ish grid */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto;
  gap:8px;
}
.g-item{
  background:var(--cream);
  border:1px solid rgba(184,150,90,.15);
  overflow:hidden;position:relative;
  cursor:pointer;
}
.g-item:hover .g-overlay{opacity:1;}
.g-item:nth-child(1){grid-column:span 2;grid-row:span 2;}
.g-item:nth-child(5){grid-column:span 2;}
.g-item:nth-child(8){grid-column:span 2;}
.g-aspect-1{aspect-ratio:1;}
.g-aspect-h{aspect-ratio:16/9;}
.g-aspect-t{aspect-ratio:4/5;}
.g-inner{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--cream),var(--paper));
  min-height:200px;
  position:relative;
}
.g-inner svg{opacity:.12;width:60%;max-width:120px;}
.g-inner-label{
  position:absolute;bottom:12px;left:14px;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(184,150,90,.4);
}
.g-overlay{
  position:absolute;inset:0;
  background:rgba(12,11,9,.55);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s;
}
.g-overlay-icon{
  width:44px;height:44px;border:1px solid rgba(255,255,255,.5);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:16px;color:white;
}
.gallery-note{
  text-align:center;margin-top:36px;
  font-size:12px;color:#9a9080;
  font-style:italic;font-family:'Cormorant Garamond',serif;font-size:16px;
}

/* ════════════════════════════════════
   SOCIAL CORNER
════════════════════════════════════ */
#social-corner{
  padding:120px 56px;
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.sc-left .about-label{margin-bottom:22px;}
.sc-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(38px,5vw,60px);
  font-weight:300;line-height:1.0;letter-spacing:-.02em;
  margin-bottom:24px;
}
.sc-title em{font-style:italic;color:var(--gold-lt);}
.sc-body{font-size:14px;color:var(--muted);line-height:1.85;margin-bottom:16px;}
.sc-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;}
.sc-tag{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  padding:7px 16px;border:1px solid var(--border);color:var(--gold);
}
.sc-visual{
  display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;gap:8px;
}
.sc-v-card{
  background:var(--ink-3);border:1px solid var(--border);
  padding:28px 22px;display:flex;flex-direction:column;gap:8px;
}
.sc-v-card:first-child{grid-column:span 2;}
.sc-v-icon{font-size:22px;}
.sc-v-name{
  font-family:'Cormorant Garamond',serif;
  font-size:18px;color:var(--white);
}
.sc-v-desc{font-size:12px;color:var(--muted);line-height:1.6;}
.sc-hashtag{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;font-style:italic;color:rgba(184,150,90,.2);
  text-align:center;margin-top:8px;
  grid-column:span 2;
  padding:18px;border:1px solid var(--border);
}

/* ════════════════════════════════════
   PRENOTA
════════════════════════════════════ */
#prenota{
  background:var(--paper);
  padding:0;overflow:hidden;
}
.prenota-inner{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:700px;
}
.prenota-left{
  padding:100px 64px;
  background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;
}
.prenota-left .about-label{color:var(--gold);}
.prenota-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(42px,5vw,68px);
  font-weight:300;line-height:1.0;
  letter-spacing:-.02em;color:var(--white);
  margin-bottom:28px;
}
.prenota-title em{font-style:italic;color:var(--gold-lt);}
.prenota-body{
  font-size:14px;color:var(--muted);line-height:1.85;margin-bottom:36px;
}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:18px;margin-bottom:40px;}
.contact-item{display:flex;align-items:flex-start;gap:16px;}
.c-icon{
  width:36px;height:36px;flex-shrink:0;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;margin-top:2px;
}
.c-label{
  font-size:9px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold);margin-bottom:4px;font-weight:300;
}
.c-val{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;color:var(--white);font-weight:400;
}
.c-sub{font-size:12px;color:rgba(255,255,255,.3);margin-top:2px;}
.prenota-right{
  background:var(--cream);
  display:flex;flex-direction:column;justify-content:center;
  padding:80px 64px;
}
.form-title{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:300;color:var(--ink);
  margin-bottom:32px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.form-label{
  font-size:9px;letter-spacing:.25em;text-transform:uppercase;
  color:#9a9080;font-weight:300;
}
.form-input,.form-select,.form-textarea{
  background:rgba(12,11,9,.04);
  border:1px solid rgba(184,150,90,.25);
  color:var(--ink);font-family:'Jost',sans-serif;
  font-size:13.5px;font-weight:300;
  padding:13px 16px;outline:none;
  transition:border-color .2s;
  width:100%;
  -webkit-appearance:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(12,11,9,.25);}
.form-textarea{resize:none;min-height:80px;}
.form-submit{
  width:100%;background:var(--ink);color:var(--white);
  border:none;font-family:'Jost',sans-serif;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  padding:16px;cursor:pointer;font-weight:300;
  transition:background .3s;margin-top:8px;
}
.form-submit:hover{background:#2a2820;}
.form-note{
  font-size:11px;color:#9a9080;text-align:center;
  margin-top:12px;
}
/* Hours table */
.hours-box{
  background:var(--ink-3);border:1px solid var(--border);
  padding:24px;margin-top:28px;
}
.hours-title{
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;font-weight:300;
}
.hours-row{
  display:flex;justify-content:space-between;
  font-size:13px;color:rgba(255,255,255,.5);
  padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05);
}
.hours-row:last-child{border-bottom:none;}
.hours-row .day{font-weight:300;}
.hours-row .time{color:rgba(255,255,255,.7);}
.hours-row.closed .time{color:rgba(255,255,255,.2);}

/* ════════════════════════════════════
   LOYALTY / NEWSLETTER
════════════════════════════════════ */
#loyalty{
  padding:120px 56px;text-align:center;
  position:relative;overflow:hidden;
}
#loyalty::before{
  content:'';position:absolute;top:0;left:15%;right:15%;height:1px;
  background:linear-gradient(to right,transparent,var(--border),transparent);
}
.loyalty-star{font-size:24px;opacity:.3;margin-bottom:28px;display:block;}
.loyalty-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(40px,6vw,72px);
  font-weight:300;line-height:1.0;letter-spacing:-.02em;
  margin-bottom:16px;
}
.loyalty-title em{font-style:italic;color:var(--gold-lt);}
.loyalty-sub{
  font-size:14.5px;color:var(--muted);max-width:480px;
  margin:0 auto 44px;line-height:1.85;
}
.loyalty-form{
  display:flex;max-width:440px;margin:0 auto 14px;
}
.loyalty-input{
  flex:1;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-right:none;
  color:var(--white);font-family:'Jost',sans-serif;
  font-size:13px;font-weight:300;padding:14px 18px;outline:none;
  transition:border-color .2s;
}
.loyalty-input::placeholder{color:rgba(255,255,255,.2);}
.loyalty-input:focus{border-color:var(--gold);}
.loyalty-submit{
  background:var(--gold);border:1px solid var(--gold);
  color:var(--ink);font-family:'Jost',sans-serif;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  padding:14px 26px;cursor:pointer;font-weight:400;
  transition:background .2s;white-space:nowrap;
}
.loyalty-submit:hover{background:var(--gold-lt);}
.loyalty-note{font-size:11px;color:rgba(255,255,255,.18);}

/* ════════════════════════════════════
   FOOTER
════════════════════════════════════ */
footer{
  background:var(--ink-2);
  border-top:1px solid var(--border);
}
.footer-top{
  max-width:1200px;margin:0 auto;
  padding:80px 56px 60px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
}
.footer-brand{}
.footer-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;font-weight:400;letter-spacing:.25em;
  color:var(--gold-lt);margin-bottom:16px;
}
.footer-tagline{
  font-size:13px;color:rgba(255,255,255,.3);
  line-height:1.7;max-width:280px;margin-bottom:28px;
}
.footer-socials{display:flex;gap:12px;}
.footer-social{
  width:36px;height:36px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:rgba(255,255,255,.4);
  transition:all .2s;
}
.footer-social:hover{border-color:var(--gold);color:var(--gold-lt);}
.footer-col-title{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);font-weight:300;margin-bottom:20px;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{
  font-size:13px;color:rgba(255,255,255,.35);
  transition:color .2s;
}
.footer-links a:hover{color:var(--gold-lt);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.05);
  padding:24px 56px;
  max-width:none;
  display:flex;align-items:center;justify-content:space-between;
}
.footer-copy{
  font-size:11px;color:rgba(255,255,255,.15);
  letter-spacing:.05em;
}
.footer-made{
  font-size:11px;color:rgba(255,255,255,.15);
  letter-spacing:.05em;
}

/* ════════════════════════════════════
   ANIMATIONS
════════════════════════════════════ */
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:none;}}

/* ════════════════════════════════════
   RESPONSIVE
════════════════════════════════════ */
@media(max-width:1024px){
  #about{grid-template-columns:1fr;gap:40px;padding:80px 32px;}
  #social-corner{grid-template-columns:1fr;gap:48px;padding:80px 32px;}
  .about-visual{max-width:520px;}
  #garden .garden-inner{grid-template-columns:1fr;gap:48px;padding:80px 32px;}
  .prenota-inner{grid-template-columns:1fr;}
  .prenota-left{padding:60px 32px;}
  .prenota-right{padding:60px 32px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px;padding:60px 32px 40px;}
  #eventi,#menu,#galleria,#loyalty{padding:80px 32px;}
  .events-grid{grid-template-columns:1fr 1fr;}
  .ev-card.featured{grid-column:span 2;}
}
@media(max-width:768px){
  #about{padding:60px 20px;gap:32px;}
  .about-visual{max-width:100%;}
  .about-badge{top:-14px;right:-10px;width:96px;height:96px;}
  .badge-num{font-size:26px;}
  #nav{padding:16px 24px;}
  #nav.scrolled{padding:12px 24px;}
  .nav-links,.nav-cta{display:none;}
  .nav-burger{display:flex;}
  .hero-stats{flex-wrap:wrap;padding:0 24px;}
  .hero-stat{padding:12px 24px;border-right:none;border-bottom:1px solid rgba(184,150,90,.1);}
  .hero-vline,.hero-vline-r,.hero-scroll{display:none;}
  .values-grid{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;}
  .g-item:nth-child(1){grid-column:span 2;}
  .g-item:nth-child(5),.g-item:nth-child(8){grid-column:span 2;}
  .recur-strip{grid-template-columns:1fr;}
  .recur-item{border-right:none;border-bottom:1px solid var(--border);}
  .events-grid{grid-template-columns:1fr;}
  .ev-card.featured{grid-column:span 1;flex-direction:column;}
  .ev-card.featured .ev-visual{width:100%;aspect-ratio:16/9;}
  .menu-panel.active{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;gap:32px;padding:40px 24px 32px;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;padding:20px 24px;}
  .loyalty-form{flex-direction:column;}
  .loyalty-input{border-right:1px solid var(--border);border-bottom:none;}
}
@media(max-width:480px){
  .values-grid{grid-template-columns:1fr;}
  .hero-title{font-size:64px;}
  .garden-features{grid-template-columns:1fr;}
  #about{padding:48px 16px;}
}

/* ════════════════════════════════════
   LIGHTBOX
════════════════════════════════════ */
#lightbox{
  display:none;position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.94);
  align-items:center;justify-content:center;
  cursor:zoom-out;
  padding:20px;
}
#lightbox.open{display:flex;}
#lb-img{
  max-width:92vw;max-height:88vh;
  object-fit:contain;
  box-shadow:0 0 80px rgba(0,0,0,.6);
  cursor:default;
  animation:lbIn .25s ease;
}
@keyframes lbIn{from{opacity:0;transform:scale(.96);}to{opacity:1;transform:scale(1);}}
#lb-close{
  position:absolute;top:20px;right:24px;
  background:none;border:1px solid rgba(255,255,255,.25);
  color:rgba(255,255,255,.7);width:40px;height:40px;
  font-size:20px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;
  z-index:1;
}
#lb-close:hover{border-color:var(--gold);color:var(--gold);}
#lb-caption{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.3);white-space:nowrap;
}
.g-item{cursor:zoom-in;}