/* =============================================
   Gigi Vera Pizza – style.css
   Design: Fresh, luminous, gourmet minimal
   Palette: #FAFAF7 cream · #0A2218 pine · #E8341A tomato
   Fonts: Cormorant Garamond (display) + Lora (serif body)
   ============================================= */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#FAFAF7;
  --pine:#0A2218;--pine2:#163829;--pine3:#1E4A35;
  --muted:#6B7D74;--muted2:#9AADA4;
  --tomato:#E8341A;--tomato2:#C5290F;
  --border:#E2EAE6;--card:#F2F7F4;
  --card2:#1E3A2C;
}
html{scroll-behavior:smooth}
body{font-family:'Lora',serif;background:var(--cream);color:var(--pine);overflow-x:hidden}
a{text-decoration:none;color:inherit}
::selection{background:var(--tomato);color:#fff}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--tomato);border-radius:2px}

/* ── HEADER / NAV ── */
header{position:sticky;top:0;z-index:99;background:rgba(250,250,247,.95);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.nav{max-width:1200px;margin:0 auto;padding:0 40px;height:68px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
.nav-left{display:flex;gap:32px}
.nav-left a{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.nav-left a:hover{color:var(--pine)}
.nav-logo{font-size:18px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--pine);text-align:center;line-height:1;font-family:'Cormorant Garamond',serif}
.nav-logo span{color:var(--tomato)}
.nav-right{display:flex;justify-content:flex-end}
.nav-cta{background:var(--tomato);color:#fff;font-family:'Cormorant Garamond',serif;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:10px 22px;border-radius:100px;transition:all .2s}
.nav-cta:hover{background:var(--tomato2);transform:translateY(-1px)}
.ham{display:none;background:none;border:none;cursor:pointer;color:var(--pine);padding:4px}
.ham-lines{display:flex;flex-direction:column;gap:5px}
.ham-lines span{display:block;width:22px;height:1.5px;background:currentColor;transition:all .3s}

/* ── FULLSCREEN OVERLAY ── */
#nav-overlay{display:none;position:fixed;inset:0;background:var(--pine);z-index:200;flex-direction:column;align-items:center;justify-content:center;gap:40px}
#nav-overlay.open{display:flex}
.overlay-logo{font-size:18px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.overlay-logo span{color:var(--tomato)}
.overlay-links{display:flex;flex-direction:column;align-items:center;gap:24px}
.overlay-links a{font-size:clamp(2.5rem,7vw,5rem);font-weight:400;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.5);transition:color .2s;font-family:'Cormorant Garamond',serif;font-style:italic}
.overlay-links a:hover{color:#fff}
.overlay-close{position:absolute;top:28px;right:40px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.6);font-size:28px;line-height:1;transition:color .2s;font-family:'Cormorant Garamond',serif}
.overlay-close:hover{color:#fff}
.overlay-cta{background:var(--tomato);color:#fff;font-family:'Cormorant Garamond',serif;font-size:14px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:14px 36px;border-radius:100px;margin-top:8px;transition:background .2s}
.overlay-cta:hover{background:var(--tomato2)}

/* ── HERO ── */
.hero{min-height:calc(100vh - 68px);display:grid;grid-template-columns:1fr 1fr;max-width:1200px;margin:0 auto;padding:0 40px;gap:40px;align-items:center}
.hero-left{padding:80px 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:100px;padding:6px 14px;margin-bottom:32px}
.hero-eyebrow-dot{width:6px;height:6px;background:var(--tomato);border-radius:50%;flex-shrink:0}
.hero-eyebrow-text{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.hero-h1{font-size:clamp(3rem,6vw,5.5rem);font-weight:600;line-height:1.08;letter-spacing:.01em;color:var(--pine);margin-bottom:28px;font-family:'Cormorant Garamond',serif}
.hero-h1 em{font-style:italic;color:var(--tomato)}
.hero-sub{font-family:'Lora',serif;font-size:18px;font-weight:400;color:var(--muted);line-height:1.7;max-width:420px;margin-bottom:40px;font-style:italic}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{background:var(--pine);color:#fff;font-family:'Cormorant Garamond',serif;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:16px 32px;border-radius:100px;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.btn-primary svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-primary:hover{background:var(--pine2);transform:translateY(-2px)}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--pine);font-family:'Cormorant Garamond',serif;font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:16px 32px;border-radius:100px;transition:all .25s}
.btn-outline:hover{border-color:var(--pine);background:var(--card)}
.hero-right{display:flex;align-items:center;justify-content:center;padding:60px 0}
.hero-img-wrap{position:relative;width:100%;max-width:480px}
.hero-img-mask{
  width:100%;aspect-ratio:4/5;
  background:var(--card);
  border-radius:60% 40% 55% 45% / 50% 55% 45% 50%;
  overflow:hidden;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:10px;color:var(--muted2);
  transition:border-radius .6s ease;
}
.hero-img-mask:hover{border-radius:45% 55% 40% 60% / 55% 45% 55% 45%}
.hero-img-mask img{width:100%;height:100%;object-fit:cover;display:block}
.hero-img-placeholder svg{width:48px;height:48px;stroke:var(--muted2);fill:none;stroke-width:1.5}
.hero-img-placeholder span{font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase}
.hero-float{position:absolute;bottom:-16px;left:-16px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:10px}
.hero-float-icon{width:36px;height:36px;background:var(--card);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.hero-float-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.hero-float-val{font-size:14px;font-weight:700;color:var(--pine)}

/* ── BENTO ── */
.bento-wrap{background:var(--pine);padding:100px 40px}
.bento-inner{max-width:1200px;margin:0 auto}
.bento-header{text-align:center;margin-bottom:64px}
.bento-eyebrow{font-size:11px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.bento-title{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:500;color:#fff;line-height:1.12;letter-spacing:.02em;font-family:'Cormorant Garamond',serif}
.bento-title em{font-style:italic;color:var(--tomato)}
.bento-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;gap:16px}
.bento-card{border-radius:20px;padding:36px 32px;position:relative;overflow:hidden}
.bento-card.b1{grid-column:1/3;background:#fff;color:var(--pine)}
.bento-card.b2{grid-column:3/4;background:var(--tomato);color:#fff}
.bento-card.b3{grid-column:1/2;background:var(--card2);border:1px solid rgba(255,255,255,.1);color:#fff}
.bento-card.b4{grid-column:2/4;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff}
.bc-num{font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;margin-bottom:20px}
.bento-card.b1 .bc-num{color:var(--muted)}
.bento-card.b2 .bc-num{color:rgba(255,255,255,.6)}
.bento-card.b3 .bc-num,.bento-card.b4 .bc-num{color:rgba(255,255,255,.4)}
.bc-title{font-size:clamp(1.6rem,3vw,2.5rem);font-weight:500;line-height:1.18;letter-spacing:.01em;margin-bottom:12px;font-family:'Cormorant Garamond',serif}
.bento-card.b3 .bc-title em,.bento-card.b4 .bc-title em{font-style:normal;color:var(--tomato)}
.bc-sub{font-family:'Lora',serif;font-size:15px;font-style:italic;line-height:1.65}
.bento-card.b1 .bc-sub{color:var(--muted)}
.bento-card.b2 .bc-sub{color:rgba(255,255,255,.85)}
.bento-card.b3 .bc-sub,.bento-card.b4 .bc-sub{color:rgba(255,255,255,.6)}
.bc-badge{display:inline-flex;align-items:center;gap:6px;background:var(--tomato);color:#fff;font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:5px 12px;border-radius:100px;margin-bottom:16px}
.bento-card.b2 .bc-badge{background:rgba(255,255,255,.25)}
.bc-big-num{font-size:clamp(4rem,7vw,6.5rem);font-weight:600;letter-spacing:.02em;line-height:1;margin-bottom:8px;font-family:'Cormorant Garamond',serif}
.bento-card.b1 .bc-big-num{color:var(--pine)}
.bento-card.b2 .bc-big-num{color:#fff}

/* ── MENU ── */
.menu-wrap{padding:100px 40px;background:var(--cream)}
.menu-inner{max-width:1200px;margin:0 auto}
.menu-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px;padding-bottom:32px;border-bottom:1.5px solid var(--pine)}
.menu-title{font-size:clamp(2.8rem,5.5vw,5rem);font-weight:500;letter-spacing:.02em;line-height:1.06;color:var(--pine);font-family:'Cormorant Garamond',serif}
.menu-sub{font-family:'Lora',serif;font-size:15px;font-style:italic;color:var(--muted);max-width:240px;text-align:right;line-height:1.6}
.pizza-item{display:grid;grid-template-columns:40px 1fr auto;align-items:baseline;padding:28px 0;border-bottom:1px solid var(--border);gap:24px;transition:all .2s;cursor:default}
.pizza-item.last{border-bottom:none}
.pizza-item:hover{padding-left:8px}
.pizza-item:hover .pi-num{color:var(--tomato)}
.pi-num{font-size:13px;font-weight:700;color:var(--border);font-variant-numeric:tabular-nums;letter-spacing:.1em;transition:color .2s}
.pi-name{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:500;letter-spacing:.02em;color:var(--pine);margin-bottom:6px;line-height:1.1;font-family:'Cormorant Garamond',serif}
.pi-ing{font-family:'Lora',serif;font-size:14px;font-style:italic;color:var(--muted);line-height:1.5}
.pi-price{font-size:20px;font-weight:800;color:var(--pine);white-space:nowrap}

/* ── CTA / DOVE SIAMO ── */
.cta-wrap{padding:100px 40px;background:var(--card)}
.cta-inner{max-width:1200px;margin:0 auto}
.cta-top{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-bottom:64px}
.cta-tag{font-size:11px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--tomato);margin-bottom:20px}
.cta-title{font-size:clamp(2.8rem,5.5vw,4.5rem);font-weight:500;letter-spacing:.02em;line-height:1.1;color:var(--pine);margin-bottom:28px;font-family:'Cormorant Garamond',serif}
.cta-sub{font-family:'Lora',serif;font-size:17px;font-style:italic;color:var(--muted);line-height:1.7;margin-bottom:36px;max-width:440px}
.cta-btn{background:var(--tomato);color:#fff;font-family:'Cormorant Garamond',serif;font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:16px 36px;border-radius:100px;transition:all .25s;display:inline-block}
.cta-btn:hover{background:var(--tomato2);transform:translateY(-2px)}
.cta-right{padding-top:12px;display:flex;flex-direction:column;gap:24px}
.info-row{display:flex;align-items:flex-start;gap:14px}
.info-icon{width:40px;height:40px;background:#fff;border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-icon svg{width:18px;height:18px;stroke:var(--pine);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.info-label{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.info-val{font-size:15px;font-weight:600;color:var(--pine);line-height:1.6}
.info-val a{color:inherit;transition:color .2s}
.info-val a:hover{color:var(--tomato)}
.info-note{font-size:13px;color:var(--muted);margin-top:2px;font-weight:400}
.map-wrap{border-radius:20px;overflow:hidden;border:1px solid var(--border);height:260px}
.map-wrap iframe{width:100%;height:100%;display:block;border:none}

/* ── FOOTER ── */
footer{background:var(--pine);padding:40px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-logo{font-size:17px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);font-family:'Cormorant Garamond',serif}
.foot-logo span{color:var(--tomato)}
.foot-copy{font-size:12px;color:rgba(255,255,255,.3);letter-spacing:.03em}
.foot-links{display:flex;gap:20px}
.foot-links a{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);transition:color .2s}
.foot-links a:hover{color:#fff}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .nav-left,.nav-right{display:none}
  .ham{display:block}
  .nav{grid-template-columns:1fr auto}
  .hero{grid-template-columns:1fr;padding:0 24px;gap:0;min-height:auto}
  .hero-left{padding:60px 0 32px}
  .hero-right{padding:0 0 60px}
  .hero-img-mask{max-width:320px;margin:0 auto}
  .bento-wrap,.menu-wrap,.cta-wrap{padding:64px 24px}
  .bento-grid{grid-template-columns:1fr}
  .bento-card.b1,.bento-card.b2,.bento-card.b3,.bento-card.b4{grid-column:1}
  .menu-header{flex-direction:column;align-items:flex-start;gap:12px}
  .menu-sub{text-align:left;max-width:100%}
  .pizza-item{grid-template-columns:32px 1fr auto;gap:12px}
  .cta-top{grid-template-columns:1fr;gap:40px}
  footer{flex-direction:column;align-items:flex-start;gap:12px;padding:32px 24px}
  .overlay-close{right:24px}
}
@media(max-width:480px){
  .hero-float{left:-8px;bottom:-8px;padding:10px 14px}
  .hero-h1{font-size:2.4rem}
  .bento-card{padding:28px 22px}
}
