/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }

/* ── VARIABILI ── */
:root {
  --bordeaux:   #7B2D2D;
  --bordeaux-d: #5c1f1f;
  --wine:       #2C1810;
  --oro:        #C8A96E;
  --oro-light:  #DAC69D;
  --crema:      #FFF7E6;
  --avorio:     #F5EDE0;
  --testo:      #3A2A20;
  --grigio:     #6B5E57;
  --bianco:     #FFFFFF;
  --r:          8px;
  --shadow:     0 4px 24px rgba(44,24,16,.12);
  --shadow-lg:  0 12px 48px rgba(44,24,16,.18);
}

/* ── BASE ── */
body { font-family:'Lato',sans-serif; background:var(--bianco); color:var(--testo); font-size:16px; line-height:1.7; }
h1,h2,h3,h4 { font-family:'Playfair Display',serif; line-height:1.25; }

/* ══════════════════════════════════════
   HEADER + HAMBURGER
══════════════════════════════════════ */
.nav-toggle-cb { display:none; position:absolute; }
header {
  background:var(--wine);
  position:sticky; top:0; z-index:200;
  box-shadow:0 2px 16px rgba(0,0,0,.35);
}
.header-inner {
  max-width:1200px; margin:0 auto;
  padding:0 24px; height:68px;
  display:flex; align-items:center; justify-content:space-between;
}
/* Logo */
.logo-wrap { display:flex; align-items:center; gap:14px; cursor:pointer; }
.logo-mark  { width:44px; height:44px; flex-shrink:0; }
.logo-text-block { display:flex; flex-direction:column; line-height:1; }
.logo-name { font-family:'Playfair Display',serif; font-size:22px; color:var(--oro); font-weight:700; letter-spacing:.03em; }
.logo-tagline { font-size:10px; color:var(--oro-light); letter-spacing:.18em; text-transform:uppercase; margin-top:3px; opacity:.8; }
/* Desktop Nav */
.desktop-nav { display:flex; align-items:center; gap:4px; }
.nav-item { position:relative; }
.nav-item > a {
  font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--oro-light); padding:8px 14px; border-radius:var(--r);
  transition:background .2s,color .2s; display:flex; align-items:center; gap:5px;
  white-space:nowrap; height:100%;
}
.nav-item > a:hover, .nav-item > a.active { background:rgba(200,169,110,.12); color:var(--oro); }
.nav-arrow { font-size:10px; opacity:.6; }
/* NAV BUTTON */
.nav-btn {
  background:var(--bordeaux); color:var(--bianco)!important;
  padding:8px 18px; border-radius:20px; font-size:13px; font-weight:700;
  letter-spacing:.06em; margin-left:8px; transition:background .2s,transform .15s;
  white-space:nowrap;
}
.nav-btn:hover { background:var(--bordeaux-d)!important; transform:scale(1.04); }
/* MEGA MENU */
.mega-panel {
  display:none; position:absolute; top:100%; left:50%;
  transform:translateX(-50%); padding-top:8px;
  background:var(--wine); border:1px solid rgba(200,169,110,.18);
  border-radius:12px; box-shadow:0 16px 48px rgba(0,0,0,.45);
  z-index:300; min-width:700px;
  animation:megaIn .18s ease;
}
@keyframes megaIn { from { opacity:0; transform:translateX(-50%) translateY(-6px); } to { opacity:1; transform:translateX(-50%) translateY(0); } }
.nav-item.has-mega:hover .mega-panel { display:block; }
/* Bridge: fills the 8px gap — keeps hover while mouse moves to panel */
.nav-item.has-mega::after,
.nav-item.has-dropdown::after {
  content:''; position:absolute; top:100%; left:0; right:0; height:16px;
}
.mega-inner { display:grid; padding:28px 24px; gap:0; }
.mega-4col  { grid-template-columns:repeat(4,1fr); }
.mega-3col  { grid-template-columns:repeat(3,1fr); }
.mega-col { padding:0 16px; border-right:1px solid rgba(200,169,110,.1); }
.mega-col:last-child { border-right:none; }
.mega-col-title {
  font-size:11px; font-weight:900; letter-spacing:.16em;
  text-transform:uppercase; color:var(--oro); margin-bottom:14px;
  padding-bottom:10px; border-bottom:1px solid rgba(200,169,110,.2);
}
.mega-col a {
  display:flex; align-items:center; justify-content:space-between;
  font-size:13px; color:rgba(255,247,230,.72);
  padding:6px 0; border-bottom:1px solid rgba(255,255,255,.04);
  transition:color .15s;
}
.mega-col a:hover { color:var(--oro); }
.badge-doc {
  font-size:10px; font-weight:700; padding:2px 6px;
  background:rgba(200,169,110,.15); color:var(--oro-light);
  border-radius:4px; letter-spacing:.04em;
}
/* Mega Featured column */
.mega-featured { background:rgba(200,169,110,.06); border-radius:8px; padding:20px 16px!important; border-right:none!important; }
.mega-feat-label { font-size:11px; font-weight:700; color:var(--oro); letter-spacing:.14em; text-transform:uppercase; margin-bottom:12px; }
.mega-feat-title { font-family:'Playfair Display',serif; font-size:15px; color:var(--crema); line-height:1.4; margin-bottom:8px; }
.mega-feat-sub { font-size:12px; color:rgba(255,247,230,.55); line-height:1.6; margin-bottom:14px; }
.mega-feat-link { font-size:12px; color:var(--oro)!important; font-weight:700; padding:0!important; border:none!important; display:inline!important; }
.mega-feat-stat { display:flex; gap:16px; margin-top:16px; padding-top:14px; border-top:1px solid rgba(200,169,110,.15); }
.mega-feat-stat-item { text-align:center; }
.mega-feat-stat-item span { display:block; font-size:18px; font-weight:700; color:var(--oro); }
.mega-feat-stat-item small { font-size:10px; color:rgba(255,247,230,.4); text-transform:uppercase; letter-spacing:.1em; }
/* DROPDOWN */
.drop-panel {
  display:none; position:absolute; top:100%; left:0;
  padding-top:8px; background:var(--wine); border:1px solid rgba(200,169,110,.18);
  border-radius:10px; box-shadow:0 12px 36px rgba(0,0,0,.4);
  z-index:300; min-width:220px; padding:10px 0;
  animation:megaIn .18s ease;
}
.nav-item.has-drop:hover .drop-panel { display:block; }
.drop-panel a {
  display:block; padding:9px 20px;
  font-size:13px; color:rgba(255,247,230,.75);
  transition:background .15s,color .15s;
}
.drop-panel a:hover { background:rgba(200,169,110,.1); color:var(--oro); }
.drop-sep { border-top:1px solid rgba(200,169,110,.12); margin:6px 0; }
/* HAMBURGER */
.hamburger {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  padding:8px; border-radius:6px; transition:background .2s;
}
.hamburger span { display:block; width:22px; height:2px; background:var(--oro-light); border-radius:2px; transition:transform .3s,opacity .3s; }
.hamburger:hover { background:rgba(200,169,110,.1); }
.nav-toggle-cb:checked + .header-inner .hamburger span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle-cb:checked + .header-inner .hamburger span:nth-child(2) { opacity:0; }
.nav-toggle-cb:checked + .header-inner .hamburger span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
/* MOBILE NAV */
.mobile-nav {
  display:none; flex-direction:column;
  background:var(--wine); border-top:1px solid rgba(200,169,110,.15);
  padding:16px 0 24px;
}
.mobile-nav a { padding:12px 24px; font-size:15px; color:rgba(255,247,230,.8); border-bottom:1px solid rgba(255,255,255,.05); }
.mobile-nav a:hover { background:rgba(200,169,110,.08); color:var(--oro); }
.nav-toggle-cb:checked ~ .mobile-nav { display:flex; }

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero {
  background:linear-gradient(135deg, var(--wine) 0%, #4a1c1c 50%, var(--bordeaux) 100%);
  padding:80px 24px 100px; position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C8A96E' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; gap:60px;
  position:relative; z-index:1;
}
.hero-copy { flex:1; max-width:600px; }
.hero-eyebrow { font-size:12px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--oro); margin-bottom:20px; }
.hero-copy h1 { font-size:clamp(36px,5vw,60px); color:var(--bianco); margin-bottom:20px; }
.hero-copy h1 em { color:var(--oro); font-style:italic; }
.hero-desc { font-size:17px; color:rgba(255,247,230,.78); line-height:1.75; max-width:520px; margin-bottom:36px; }
.hero-stats { display:flex; gap:36px; margin-bottom:40px; }
.hero-stat span { display:block; font-size:32px; font-weight:900; color:var(--oro); font-family:'Lato',sans-serif; line-height:1; }
.hero-stat small { font-size:12px; color:rgba(255,247,230,.55); letter-spacing:.1em; text-transform:uppercase; }
.hero-cta { display:flex; gap:16px; flex-wrap:wrap; }
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--oro); color:var(--wine); font-weight:800;
  font-size:14px; letter-spacing:.07em; text-transform:uppercase;
  padding:14px 28px; border-radius:28px;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 4px 16px rgba(200,169,110,.3);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(200,169,110,.4); }
.btn-outline {
  display:inline-flex; align-items:center;
  border:2px solid rgba(200,169,110,.5); color:var(--oro-light);
  font-weight:700; font-size:14px; letter-spacing:.07em; text-transform:uppercase;
  padding:12px 26px; border-radius:28px;
  transition:border-color .2s,color .2s,background .2s;
}
.btn-outline:hover { border-color:var(--oro); color:var(--oro); background:rgba(200,169,110,.08); }

/* HERO VISUAL */
.hero-visual { flex-shrink:0; width:340px; }
.wine-composition { position:relative; display:flex; align-items:flex-end; justify-content:center; gap:24px; padding:20px; }
.deco-circle { position:absolute; border-radius:50%; }
.deco-circle-1 { width:260px; height:260px; background:rgba(200,169,110,.07); top:10%; left:50%; transform:translateX(-50%); }
.deco-circle-2 { width:180px; height:180px; background:rgba(123,45,45,.15); top:20%; left:50%; transform:translateX(-50%); }

/* CSS Bottle */
.css-bottle { display:flex; flex-direction:column; align-items:center; position:relative; z-index:2; }
.bottle-neck { width:22px; height:60px; background:linear-gradient(180deg,#2d6e2d,#1a4a1a); border-radius:4px 4px 0 0; }
.bottle-shoulder { width:0; height:0; border-left:20px solid transparent; border-right:20px solid transparent; border-top:30px solid #1a4a1a; margin-top:-1px; }
.bottle-body {
  width:80px; height:180px; background:linear-gradient(180deg,#1a3d1a,#0d2d0d);
  border-radius:4px 4px 8px 8px; position:relative; overflow:hidden;
}
.bottle-label {
  position:absolute; top:30px; left:6px; right:6px; bottom:30px;
  background:linear-gradient(135deg,var(--crema),var(--avorio));
  border-radius:4px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; padding:8px;
}
.label-v { font-family:'Playfair Display',serif; font-size:26px; font-weight:700; color:var(--bordeaux); line-height:1; }
.label-name { font-size:8px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--wine); margin-top:4px; }
.label-year { font-size:9px; color:var(--grigio); margin-top:6px; }

/* CSS Wine Glass */
.css-glass { display:flex; flex-direction:column; align-items:center; position:relative; z-index:2; }
.glass-bowl {
  width:60px; height:70px;
  background:rgba(255,255,255,.08);
  border:2px solid rgba(255,255,255,.2);
  border-radius:0 0 30px 30px;
  clip-path:polygon(10% 0%,90% 0%,100% 60%,85% 100%,15% 100%,0% 60%);
}
.glass-stem { width:4px; height:40px; background:rgba(255,255,255,.15); }
.glass-base { width:36px; height:4px; background:rgba(255,255,255,.2); border-radius:2px; }

/* ══════════════════════════════════════
   CAT BANNER + STRIP
══════════════════════════════════════ */
.cat-banner { background:var(--wine); border-bottom:1px solid rgba(200,169,110,.15); padding:0 24px; }
.cat-scroll { max-width:1200px; margin:0 auto; display:flex; gap:4px; overflow-x:auto; padding:10px 0; }
.cat-scroll::-webkit-scrollbar { display:none; }
.cat-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 16px; border-radius:20px; font-size:13px; font-weight:700;
  color:rgba(255,247,230,.7); white-space:nowrap;
  transition:background .2s,color .2s;
}
.cat-pill:hover { background:rgba(200,169,110,.12); color:var(--oro); }
.cat-pill span { font-size:15px; }

/* VITIGNI STRIP */
.vitigni-strip { background:var(--avorio); border-top:1px solid rgba(123,45,45,.1); border-bottom:1px solid rgba(123,45,45,.1); padding:20px 24px; }
.vitigni-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.vitigni-label { font-size:12px; font-weight:900; letter-spacing:.15em; text-transform:uppercase; color:var(--bordeaux); white-space:nowrap; }
.vitigni-chips { display:flex; flex-wrap:wrap; gap:8px; }
.chip {
  display:inline-block; padding:5px 13px; border-radius:16px;
  background:rgba(123,45,45,.08); border:1px solid rgba(123,45,45,.2);
  font-size:13px; color:var(--bordeaux); font-weight:600;
  transition:background .2s,border-color .2s;
}
.chip:hover { background:var(--bordeaux); color:var(--bianco); border-color:var(--bordeaux); }
.chip.more { background:var(--bordeaux); color:var(--bianco); border-color:var(--bordeaux); }

/* ══════════════════════════════════════
   SEZIONI
══════════════════════════════════════ */
.section { padding:64px 24px; max-width:1200px; margin:0 auto; }
.section-bg { background:var(--avorio); padding:64px 24px; }
.section-inner { max-width:1200px; margin:0 auto; }
.section-title { font-size:clamp(24px,3.5vw,36px); color:var(--wine); text-align:center; margin-bottom:12px; }
.section-subtitle { text-align:center; color:var(--grigio); font-size:16px; max-width:600px; margin:0 auto 48px; }
.oro-line { width:60px; height:3px; background:linear-gradient(90deg,var(--bordeaux),var(--oro)); border-radius:2px; margin:0 auto 12px; }

/* ══════════════════════════════════════
   CAT CARDS (homepage 6 sezioni)
══════════════════════════════════════ */
.cat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.cat-card {
  background:var(--bianco); border-radius:14px; padding:28px 24px;
  border-top:4px solid var(--cat-color, var(--bordeaux));
  box-shadow:var(--shadow); transition:transform .25s,box-shadow .25s;
  position:relative; overflow:hidden;
  display:block;
}
.cat-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.cat-icon { font-size:36px; margin-bottom:16px; }
.cat-card h3 { font-size:20px; color:var(--wine); margin-bottom:10px; }
.cat-card p { font-size:14px; color:var(--grigio); line-height:1.65; margin-bottom:16px; }
.cat-meta { font-size:13px; font-weight:700; color:var(--bordeaux); }
.badge-soon {
  position:absolute; top:12px; right:12px;
  background:var(--oro); color:var(--wine); font-size:10px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; padding:3px 8px; border-radius:10px;
}

/* ══════════════════════════════════════
   WINE CARDS
══════════════════════════════════════ */
.wine-cards-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.wine-card {
  background:var(--bianco); border-radius:12px;
  overflow:hidden; box-shadow:var(--shadow);
  transition:transform .25s,box-shadow .25s; display:block;
}
.wine-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.wine-thumb {
  height:180px; position:relative; display:flex;
  align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--wine),var(--bordeaux));
}
.wt-barolo  { background:linear-gradient(135deg,#3d0a0a,#7b2d2d); }
.wt-bianco  { background:linear-gradient(135deg,#2a3d00,#4a6a10); }
.wt-spumant { background:linear-gradient(135deg,#0a2d3d,#1a5a7a); }
.wine-icon { font-size:48px; }
.wine-cover-img { width:100%; height:100%; object-fit:cover; }
.wine-denom-badge {
  position:absolute; top:10px; left:10px;
  background:rgba(0,0,0,.5); color:var(--oro-light);
  font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:3px 8px; border-radius:8px; backdrop-filter:blur(4px);
}
.wine-region-badge {
  position:absolute; bottom:10px; right:10px;
  background:rgba(0,0,0,.5); color:rgba(255,247,230,.8);
  font-size:10px; padding:3px 8px; border-radius:8px; backdrop-filter:blur(4px);
}
.wine-card-body { padding:14px 16px 18px; }
.wine-card-meta { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.wine-annata { font-size:12px; color:var(--grigio); font-weight:600; }
.wine-stars { color:var(--oro); font-size:13px; }
.wine-card-body h3 { font-size:15px; color:var(--wine); margin-bottom:6px; line-height:1.3; }
.wine-card-body p { font-size:12px; color:var(--grigio); line-height:1.55; }

/* ══════════════════════════════════════
   BLOG CARDS
══════════════════════════════════════ */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.post-card { background:var(--bianco); border-radius:12px; overflow:hidden; box-shadow:var(--shadow); transition:transform .25s,box-shadow .25s; display:block; }
.post-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.post-thumb { height:200px; position:relative; display:flex; align-items:center; justify-content:center; }
.thumb-barolo { background:linear-gradient(135deg,#3d0a0a,#7b2d2d); }
.thumb-icon { font-size:56px; }
.post-thumb img { width:100%; height:100%; object-fit:cover; }
.post-cat-badge {
  position:absolute; top:12px; left:12px;
  background:var(--bordeaux); color:var(--bianco);
  font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:4px 10px; border-radius:10px;
}
.post-body { padding:20px 20px 24px; }
.post-meta { font-size:12px; color:var(--grigio); margin-bottom:8px; }
.post-body h3 { font-size:17px; color:var(--wine); margin-bottom:10px; line-height:1.4; }
.post-body p { font-size:14px; color:var(--grigio); line-height:1.6; margin-bottom:14px; }
.post-link { font-size:13px; font-weight:700; color:var(--bordeaux); }

/* ══════════════════════════════════════
   MODAL RICERCA
══════════════════════════════════════ */
#search-overlay {
  position:fixed !important; inset:0; z-index:9998 !important;
  background:rgba(44,24,16,.96); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; align-items:center;
  padding:80px 24px 40px;
  opacity:0 !important; visibility:hidden !important; pointer-events:none !important;
  transition:opacity .3s ease, visibility .3s;
}
#search-overlay.open { opacity:1; visibility:visible; pointer-events:auto; }
.search-close {
  position:absolute; top:24px; right:28px;
  background:rgba(255,255,255,.08); border:none; color:var(--oro-light);
  font-size:22px; width:42px; height:42px; border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s; font-family:'Lato',sans-serif;
}
.search-close:hover { background:rgba(200,169,110,.2); }
.search-title { font-family:'Playfair Display',serif; font-size:clamp(22px,3vw,36px); color:var(--bianco); margin-bottom:32px; text-align:center; }
.search-title em { color:var(--oro); font-style:italic; }
.search-box-wrap { width:100%; max-width:640px; position:relative; margin-bottom:28px; }
.search-input { width:100%; padding:18px 56px 18px 22px; background:rgba(255,255,255,.08); border:2px solid rgba(200,169,110,.3); border-radius:32px; color:var(--bianco); font-size:18px; outline:none; transition:border-color .2s; font-family:'Lato',sans-serif; }
.search-input::placeholder { color:rgba(255,255,255,.35); }
.search-input:focus { border-color:var(--oro); background:rgba(255,255,255,.1); }
.search-go { position:absolute; right:8px; top:50%; transform:translateY(-50%); background:var(--bordeaux); border:none; color:var(--bianco); width:42px; height:42px; border-radius:50%; cursor:pointer; font-size:18px; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.search-go:hover { background:var(--bordeaux-d); }
.search-filters { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-bottom:32px; }
.search-filter-btn { background:rgba(255,255,255,.07); border:1px solid rgba(200,169,110,.25); color:rgba(255,247,230,.7); font-size:13px; padding:7px 16px; border-radius:20px; cursor:pointer; transition:background .2s,color .2s,border-color .2s; font-family:'Lato',sans-serif; }
.search-filter-btn:hover, .search-filter-btn.active { background:var(--bordeaux); color:var(--bianco); border-color:var(--bordeaux); }
.search-suggestions { width:100%; max-width:640px; }
.search-sugg-title { font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:rgba(200,169,110,.6); margin-bottom:14px; text-align:left; }
.search-sugg-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.search-sugg-item { background:rgba(255,255,255,.05); border:1px solid rgba(200,169,110,.15); border-radius:10px; padding:12px 14px; cursor:pointer; transition:background .2s,border-color .2s; }
.search-sugg-item:hover { background:rgba(200,169,110,.12); border-color:rgba(200,169,110,.35); }
.search-sugg-item .s-name { font-size:14px; font-weight:700; color:var(--crema); margin-bottom:2px; }
.search-sugg-item .s-type { font-size:11px; color:rgba(255,247,230,.45); text-transform:uppercase; letter-spacing:.08em; }

/* NEWSLETTER */
.newsletter-wrap { background:linear-gradient(135deg,var(--wine) 0%,var(--bordeaux-d) 100%); padding:64px 24px; text-align:center; }
.newsletter-inner { max-width:540px; margin:0 auto; }
.newsletter-wrap h2 { font-size:30px; color:var(--bianco); margin-bottom:12px; }
.newsletter-wrap p { color:rgba(255,247,230,.75); font-size:15px; margin-bottom:28px; }
.nl-form { display:flex; gap:10px; max-width:440px; margin:0 auto; }
.nl-input { flex:1; padding:12px 18px; border:1.5px solid rgba(200,169,110,.3); border-radius:26px; background:rgba(255,255,255,.07); color:var(--bianco); font-size:14px; outline:none; transition:border-color .2s; font-family:'Lato',sans-serif; }
.nl-input::placeholder { color:rgba(255,255,255,.4); }
.nl-input:focus { border-color:var(--oro); }

/* COOKIE BANNER */
#cookie-banner { position:fixed !important; bottom:0; left:0; right:0; z-index:9999; background:var(--wine); border-top:2px solid var(--bordeaux); box-shadow:0 -4px 24px rgba(0,0,0,.4); padding:16px 24px; display:flex; align-items:center; gap:20px; flex-wrap:wrap; font-size:13px; color:rgba(255,247,230,.8); transition:transform .4s ease, opacity .4s ease; }
#cookie-banner.hidden { transform:translateY(100%); opacity:0; pointer-events:none; }
#cookie-banner p { flex:1; min-width:240px; line-height:1.6; }
#cookie-banner p a { color:var(--oro-light); text-decoration:underline; }
.cookie-btns { display:flex; gap:10px; flex-shrink:0; flex-wrap:wrap; }
.cookie-btn-accept { background:var(--oro); color:var(--wine); font-weight:700; font-size:13px; letter-spacing:.06em; text-transform:uppercase; padding:9px 20px; border-radius:20px; cursor:pointer; border:none; font-family:'Lato',sans-serif; transition:transform .2s; }
.cookie-btn-accept:hover { transform:scale(1.04); }
.cookie-btn-decline { background:transparent; color:rgba(255,247,230,.6); font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:9px 16px; border-radius:20px; cursor:pointer; border:1px solid rgba(255,255,255,.2); font-family:'Lato',sans-serif; transition:border-color .2s,color .2s; }
.cookie-btn-decline:hover { border-color:rgba(255,255,255,.5); color:var(--crema); }

/* FOOTER */
footer { background:var(--wine); color:rgba(255,247,230,.65); padding:48px 24px 0; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-logo-name { font-family:'Playfair Display',serif; font-size:22px; color:var(--oro); margin-bottom:10px; display:flex; align-items:center; gap:10px; }
.footer-desc { font-size:14px; line-height:1.75; color:rgba(255,247,230,.55); max-width:240px; }
.footer-col h4 { font-family:'Lato',sans-serif; font-size:11px; font-weight:900; letter-spacing:.18em; text-transform:uppercase; color:var(--oro-light); margin-bottom:16px; }
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:9px; }
.footer-col a { font-size:14px; color:rgba(255,247,230,.55); transition:color .2s; }
.footer-col a:hover { color:var(--oro); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding:20px 0; display:flex; justify-content:space-between; align-items:center; font-size:12px; color:rgba(255,247,230,.35); flex-wrap:wrap; gap:8px; }
.footer-bottom a { color:var(--oro-light); }

/* RESPONSIVE */
@media (max-width:900px) {
  .hamburger { display:flex; }
  .desktop-nav { display:none; }
  .hero-inner { flex-direction:column; text-align:center; }
  .hero-visual { display:none; }
  .hero-copy { max-width:100%; }
  .hero-stats { justify-content:center; }
  .hero-cta { justify-content:center; }
  .cat-grid { grid-template-columns:repeat(2,1fr); }
  .wine-cards-grid { grid-template-columns:repeat(2,1fr); }
  .blog-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .header-inner { height:58px; padding:0 16px; }
  .logo-tagline { display:none; }
  .hero { padding:52px 16px 60px; }
  .hero h1 { font-size:28px; }
  .cat-grid { grid-template-columns:1fr; gap:16px; }
  .wine-cards-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .blog-grid { grid-template-columns:1fr; gap:20px; }
  .newsletter-wrap { padding:48px 16px; }
  .nl-form { flex-direction:column; gap:10px; }
  .footer-top { grid-template-columns:1fr; gap:28px; }
  #cookie-banner { flex-direction:column; align-items:flex-start; }
}
