/*
 * Homepage - Digitale Menomale Styles
 * Custom CSS for front-page.php template
 */

:root {
  --y: #FFB800;
  --yd: #e6a000;
  --yl: #fff8e1;
  --p: #5B21B6;
  --pm: #7C3AED;
  --pd: #3B0764;
  --white: #fff;
  --dark: #0f0720;
}

html {
  scroll-behavior: smooth;
}

/* Apply to front page - using multiple selectors to ensure coverage */
/* High specificity to override Elementor */
body.home,
body.page,
body.page-template-default,
body.elementor-page,
body[class*="elementor"],
body,
.elementor *,
.elementor-element,
#page,
#content {
  font-family: 'Nunito', sans-serif !important;
}

/* Override Elementor container styles */
.elementor-section,
.elementor-container,
.elementor-column,
.elementor-widget-wrap {
  font-family: 'Nunito', sans-serif !important;
}

body.home,
body.page,
body.elementor-page {
  background: var(--dark) !important;
  color: var(--white) !important;
  overflow-x: hidden;
  /* cursor: none; */
}

/* ── CUSTOM CURSOR ── */
#cursor {
  width: 20px; height: 20px;
  background: var(--y);
  border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: transform 0.08s ease, width 0.2s, height 0.2s, background 0.2s;
  mix-blend-mode: exclusion;
}
#cursor-ring {
  width: 44px; height: 44px;
  border: 2px solid var(--y);
  border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: transform 0.18s ease;
  opacity: 0.5;
}
body:has(a:hover) #cursor,
body:has(button:hover) #cursor { width: 40px; height: 40px; background: var(--pm); }

/* ── CANVAS PARTICLES ── */
#particles-canvas {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 0; opacity: 0.35;
}



/* ── HERO ── */
.hero-home {
  min-height: 100vh;
  display: flex; align-items: center;
  padding: 120px 5% 80px;
  position: relative; z-index: 1;
  overflow: hidden;
}
.hero-bg-shapes {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
}
.shape {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: 0.4;
  animation: shapePulse 6s ease-in-out infinite alternate;
}
.s1 { width: 500px; height: 500px; background: var(--p); top: -100px; left: -100px; animation-delay: 0s; }
.s2 { width: 400px; height: 400px; background: var(--y); opacity: 0.15; top: 50%; right: -100px; animation-delay: 2s; }
.s3 { width: 300px; height: 300px; background: var(--pm); bottom: -50px; left: 30%; animation-delay: 4s; }

@keyframes shapePulse {
  from { transform: scale(1) translate(0,0); }
  to { transform: scale(1.15) translate(20px, -20px); }
}

.hero-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 3rem; align-items: center;
  position: relative; z-index: 1; width: 100%;
}

/* ANIMATED TEXT BADGE */
.hero-badge {
  display: inline-flex; align-items: center; gap: 0.6rem;
  background: rgba(255,184,0,0.12);
  border: 1.5px solid rgba(255,184,0,0.4);
  padding: 0.4rem 1.1rem; border-radius: 100px;
  font-size: 0.78rem; font-weight: 800; color: var(--y);
  letter-spacing: 0.06em; text-transform: uppercase;
  margin-bottom: 1.5rem;
  animation: badgePop 0.5s cubic-bezier(.34,1.56,.64,1) both;
}
.badge-dot {
  width: 8px; height: 8px; background: var(--y); border-radius: 50%;
  animation: dotBlink 1.5s ease infinite;
}
@keyframes dotBlink { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.7)} }
@keyframes badgePop { from{opacity:0;transform:scale(0.7)} to{opacity:1;transform:scale(1)} }

/* GIANT HEADLINE */
.hero-headline {
  font-family: 'Black Han Sans', 'Nunito', sans-serif;
  font-size: clamp(3rem, 6vw, 5.5rem);
  line-height: 1.05; letter-spacing: -2px;
  margin-bottom: 1rem;
  animation: slideUp 0.7s 0.1s cubic-bezier(.22,1,.36,1) both;
}
.hero-headline .line { display: block; overflow: hidden; }
.hero-headline .word {
  display: inline-block;
  animation: wordReveal 0.7s cubic-bezier(.22,1,.36,1) both;
}
.hero-headline .w1 { animation-delay: 0.15s; }
.hero-headline .w2 { animation-delay: 0.25s; }
.hero-headline .w3 { color: var(--y); animation-delay: 0.35s; }
.hero-headline .w4 { animation-delay: 0.45s; }
.hero-headline .w5 { animation-delay: 0.55s; }
@keyframes wordReveal { from{opacity:0;transform:translateY(60px) rotate(3deg)} to{opacity:1;transform:none} }

.hero-tagline {
  font-size: 1.5rem; font-weight: 900;
  color: var(--y); margin-bottom: 1rem;
  animation: slideUp 0.7s 0.5s both;
  text-decoration: underline wavy rgba(255,184,0,0.5);
  text-underline-offset: 5px;
}
.hero-desc {
  font-size: 1rem; color: rgba(255,255,255,0.65);
  line-height: 1.7; max-width: 480px; margin-bottom: 2rem;
  animation: slideUp 0.7s 0.6s both;
}
.hero-desc em { color: var(--white); font-style: italic; font-weight: 800; }
@keyframes slideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:none} }

.hero-pills {
  display: flex; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 2rem;
  animation: slideUp 0.7s 0.7s both;
}
.hero-pill {
  background: rgba(91,33,182,0.3); border: 1.5px solid rgba(124,58,237,0.5);
  padding: 0.4rem 1rem; border-radius: 100px;
  font-size: 0.8rem; font-weight: 700; color: rgba(255,255,255,0.85);
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}
.hero-pill:hover { background: var(--pm); border-color: var(--pm); transform: scale(1.06); }

.hero-ctas {
  display: flex; gap: 1rem; flex-wrap: wrap;
  animation: slideUp 0.7s 0.8s both;
}

/* GLOW BUTTON */
.btn-glow {
  background: var(--y); color: var(--pd);
  font-family: 'Nunito',sans-serif; font-weight: 900; font-size: 1rem;
  padding: 0.85rem 2rem; border-radius: 14px; border: none; cursor: pointer;
  position: relative; overflow: hidden;
  box-shadow: 0 0 30px rgba(255,184,0,0.5);
  transition: transform 0.2s, box-shadow 0.2s;
  text-decoration: none; display: inline-block;
}
.btn-glow::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s;
}
.btn-glow:hover::before { transform: translateX(100%); }
.btn-glow:hover { color: #fff; transform: translateY(-3px) scale(1.03); box-shadow: 0 0 50px rgba(255,184,0,0.7); }

.btn-ghost {
  background: transparent; color: var(--white);
  border: 2px solid rgba(255,255,255,0.3);
  font-family: 'Nunito',sans-serif; font-weight: 800; font-size: 1rem;
  padding: 0.85rem 2rem; border-radius: 14px; cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
  text-decoration: none; display: inline-block;
}
.btn-ghost:hover { border-color: var(--y); color: var(--y); transform: translateY(-3px); }

/* HERO IMAGE SIDE */
.hero-visual {
  position: relative;
  animation: slideUp 0.8s 0.3s both;
}
.hero-img-frame {
  position: relative;
  background: linear-gradient(135deg, var(--p), var(--pm));
  border-radius: 28px;
  padding: 3px;
  box-shadow: 0 30px 80px rgba(91,33,182,0.5), 0 0 0 1px rgba(255,184,0,0.2);
  overflow: hidden;
}
.hero-img-frame::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,184,0,0.2), transparent, rgba(124,58,237,0.3));
  z-index: 1; pointer-events: none;
}
.hero-img-frame img {
  width: 100%; height: 340px; object-fit: cover; border-radius: 26px;
  display: block;
}

/* Floating badges on hero */
.float-badge {
  position: absolute;
  background: var(--white);
  border-radius: 14px;
  padding: 0.65rem 1rem;
  box-shadow: 0 10px 40px rgba(0,0,0,0.3);
  display: flex; align-items: center; gap: 0.6rem;
  font-size: 0.82rem; font-weight: 800; color: var(--pd);
  animation: floatAnim 3s ease-in-out infinite;
  z-index: 2;
}
.float-badge .fb-num { font-size: 1.2rem; font-weight: 900; color: var(--p); }
.fb1 { bottom: -20px; left: -30px; animation-delay: 0s; }
.fb2 { top: -15px; right: -20px; animation-delay: 1.5s; background: var(--y); color: var(--pd); }
@keyframes floatAnim {
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-10px) rotate(1deg)}
}

/* ── WAVE DIVIDER ── */
.wave { line-height: 0; position: relative; z-index: 1; }
.wave svg { display: block; width: 100%; }

/* ── STATS STRIP ── */
.stats-strip {
  background: var(--y);
  display: grid; grid-template-columns: repeat(4,1fr);
  position: relative; z-index: 1;
}
.stat-item {
  padding: 1.75rem 1rem; text-align: center;
  border-right: 1px solid rgba(0,0,0,0.1);
  transition: background 0.2s;
  cursor: default;
}
.stat-item:last-child { border-right: none; }
.stat-item:hover { background: var(--yd); }
.stat-num {
  font-family: 'Black Han Sans','Nunito',sans-serif;
  font-size: 2.2rem; color: var(--pd); line-height: 1;
}
.stat-label { font-size: 0.8rem; font-weight: 700; color: rgba(0,0,0,0.6); margin-top: 0.3rem; }

/* ── NUMERI SECTION ── */
.numeri-section {
  background: var(--y);
  padding: 5rem 5%;
  display: grid; grid-template-columns: 300px 1fr; gap: 4rem; align-items: center;
  position: relative; z-index: 1;
}
.numeri-char img {
  width: 100%; filter: drop-shadow(0 16px 32px rgba(0,0,0,0.2));
  animation: charFloat 4s ease-in-out infinite;
}
@keyframes charFloat {
  0%,100%{transform:translateY(0)} 50%{transform:translateY(-16px)}
}
.numeri-tag {
  font-size: 0.72rem; font-weight: 900; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--p); margin-bottom: 0.75rem;
  display: flex; align-items: center; gap: 0.5rem;
}
.numeri-tag::before { content:''; width:24px;height:3px;background:var(--p);border-radius:2px;display:inline-block; }
.numeri-text { font-size: 1rem; line-height: 1.7; color: var(--pd); margin-bottom: 0.85rem; }
.numeri-link { color: var(--p); font-weight: 700; text-decoration: underline; }

.counters-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 1.75rem;
}
.counter-card {
  background: var(--white);
  border-radius: 18px; padding: 1.5rem 1rem; text-align: center;
  box-shadow: 0 8px 32px rgba(0,0,0,0.1);
  border: 2px solid transparent;
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
  perspective: 600px;
}
.counter-card:hover {
  transform: translateY(-6px) rotateX(4deg);
  border-color: var(--p);
  box-shadow: 0 20px 50px rgba(91,33,182,0.2);
}
.counter-card .cn {
  font-family: 'Black Han Sans','Nunito',sans-serif;
  font-size: 2.2rem; color: var(--p); line-height: 1;
}
.counter-card .cl { font-size: 0.82rem; font-weight: 700; color: #666; margin-top: 0.35rem; }

/* ── SCOPRI SECTION ── */
.scopri-section {
  background: var(--dark);
  padding: 6rem 5%;
  position: relative; z-index: 1;
  overflow: hidden;
}
.scopri-section::before {
  content: '';
  position: absolute; top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(91,33,182,0.3) 0%, transparent 70%);
  pointer-events: none;
}
.scopri-inner {
  max-width: 800px; margin: 0 auto; text-align: center;
}
.section-tag-dark {
  display: inline-block;
  background: rgba(255,184,0,0.12); border: 1px solid rgba(255,184,0,0.3);
  color: var(--y); font-size: 0.72rem; font-weight: 900;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 0.35rem 1rem; border-radius: 100px; margin-bottom: 1rem;
}
.scopri-title {
  font-family: 'Black Han Sans','Nunito',sans-serif;
  font-size: clamp(2rem,4vw,3.5rem);
  line-height: 1.1; margin-bottom: 1.5rem;
  letter-spacing: -1px;
}
.scopri-title span { color: var(--y); }
.scopri-desc { font-size: 1rem; color: rgba(255,255,255,0.65); line-height: 1.75; margin-bottom: 2.5rem; }

/* VALUES 3D CARDS */
.values-row {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; margin-top: 1rem;
}
.value-card-wow {
  background: linear-gradient(135deg, rgba(91,33,182,0.4), rgba(124,58,237,0.2));
  border: 1.5px solid rgba(124,58,237,0.4);
  border-radius: 20px; padding: 2rem 1.5rem; text-align: center;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
  cursor: default;
  position: relative; overflow: hidden;
}
.value-card-wow::before {
  content:'';
  position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:conic-gradient(from 0deg at 50% 50%, transparent 0deg, rgba(255,184,0,0.08) 60deg, transparent 120deg);
  animation: rotateGlow 4s linear infinite;
  pointer-events:none;
}
@keyframes rotateGlow { to{transform:rotate(360deg)} }
.value-card-wow:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 24px 60px rgba(91,33,182,0.4);
  border-color: var(--y);
}
.value-icon-big { font-size: 3rem; margin-bottom: 1rem; display: block; }
.value-card-wow h3 { font-weight: 900; font-size: 1.2rem; margin-bottom: 0.6rem; color: var(--y); }
.value-card-wow p { font-size: 0.87rem; color: rgba(255,255,255,0.7); line-height: 1.65; }

/* ── PRODOTTI ── */
.prodotti-section {
  background: var(--yl);
  padding: 5rem 5%;
  position: relative; z-index: 1;
}
.prod-section-header { text-align: center; margin-bottom: 2.5rem; }
.prod-section-tag {
  display: inline-block;
  background: var(--p); color: var(--y);
  font-size: 0.72rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.35rem 1rem; border-radius: 100px; margin-bottom: 1rem;
}
.prod-section-title {
  font-family: 'Black Han Sans','Nunito',sans-serif;
  font-size: clamp(2rem,3.5vw,3rem); color: var(--pd) !important; letter-spacing: -1px;
}

/* TABS */
.prod-tabs {
  display: flex; justify-content: center; gap: 0.5rem; margin-bottom: 2.5rem; flex-wrap: wrap;
}
.prod-tab {
  background: var(--white); color: var(--p);
  border: 2px solid var(--p);
  padding: 0.6rem 1.5rem; border-radius: 100px;
  font-family: 'Nunito',sans-serif; font-weight: 800; font-size: 0.875rem;
  cursor: pointer; transition: all 0.2s;
}
.prod-tab:hover { background: var(--p); color: var(--white); transform: scale(1.05); }
.prod-tab.active {
  background: var(--p); color: var(--y);
  box-shadow: 0 6px 24px rgba(91,33,182,0.35);
}

.prod-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem;
}

/* PRODUCT CARD WOW */
.prod-card-wow {
  background: var(--white);
  border-radius: 22px; overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.1);
  border: 2px solid transparent;
  transition: transform 0.3s cubic-bezier(.22,1,.36,1), box-shadow 0.3s, border-color 0.3s;
  display: flex; flex-direction: column;
  position: relative;
}
.prod-card-wow::after {
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(91,33,182,0), rgba(91,33,182,0.04));
  opacity:0; transition:opacity 0.3s;
  pointer-events:none;
}
.prod-card-wow:hover {
  transform: translateY(-10px) scale(1.02);
  box-shadow: 0 30px 70px rgba(91,33,182,0.22);
  border-color: var(--p);
}
.prod-card-wow:hover::after { opacity:1; }

.prod-img-wrap {
  position: relative; overflow: hidden; height: 200px;
  background: linear-gradient(135deg, #e8e0ff, #f5f0ff);
}
.prod-img-wrap img {
  width:100%;object-fit:cover;
  transition: transform 0.5s cubic-bezier(.22,1,.36,1);
}
.prod-card-wow:hover .prod-img-wrap img { transform: scale(1.08); }

.prod-cat-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--p); color: var(--y);
  font-size: 0.68rem; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.25rem 0.7rem; border-radius: 100px;
}
.prod-bestseller {
  position: absolute; top: 12px; right: 12px;
  background: var(--y); color: var(--pd);
  font-size: 0.68rem; font-weight: 900;
  padding: 0.25rem 0.7rem; border-radius: 100px;
}

.prod-body { padding: 1.25rem 1.25rem 0.75rem; flex:1; }
.prod-name { font-weight: 900; font-size: 1.05rem; color: var(--pd); margin-bottom: 0.5rem; }
.prod-stars { font-size: 0.85rem; color: var(--y); margin-bottom: 0.5rem; }
.prod-price {
  font-family: 'Black Han Sans','Nunito',sans-serif;
  font-size: 1.6rem; color: var(--p); line-height: 1;
}
.prod-price small { font-size: 0.75rem; font-weight: 400; color: #888; font-family:'Nunito',sans-serif; }

.prod-footer {
  display: flex; gap: 0.5rem; padding: 0.85rem 1.25rem;
  border-top: 1px solid #f0ecff;
}
.btn-add-wow {
  color: #fff;
  flex:1; background: var(--p); color: var(--white);
  border:none; border-radius: 10px; padding: 0.7rem;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:0.875rem;
  cursor:pointer; transition: background 0.2s, transform 0.15s;
  position:relative; overflow:hidden;
  text-decoration: none;
  display: inline-block;
  text-align: center;
}
.btn-add-row + .wc-forward {
  display: none;
}
.btn-add-wow::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
  transform: translateX(-100%); transition: transform 0.4s;
}
.btn-add-wow:hover::before { transform: translateX(100%); }
.btn-add-wow:hover { background: var(--pd); transform: scale(1.03); }

/* WooCommerce loading states for front-page buttons */
.btn-add-wow.loading,
.btn-add-wow.ajax_add_to_cart.loading {
  opacity: 0.6;
  cursor: wait;
  pointer-events: none;
}

.btn-add-wow.loading::after,
.btn-add-wow.ajax_add_to_cart.loading::after {
  content: '';
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  border: 2px solid var(--white);
  border-right-color: transparent;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

@keyframes spin {
  to { transform: translateY(-50%) rotate(360deg); }
}

/* WooCommerce added states for front-page buttons */
.btn-add-wow.added,
.btn-add-wow.ajax_add_to_cart.added {
  background: #10b981 !important;
  transform: scale(1.05);
}

/* Ensure WooCommerce ajax buttons maintain front-page design */
.btn-add-wow.ajax_add_to_cart {
  background: var(--pm);
  color: var(--white);
  border: none;
  border-radius: 10px;
  padding: 0.7rem 1rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 900;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.btn-add-wow.ajax_add_to_cart:hover {
  background: var(--pd);
  transform: scale(1.03);
}

/* .btn-add-wow.added::before {
  content: '✓ ';
} */

.btn-detail-wow {
  background: var(--y); color: var(--pd);
  border:none; border-radius:10px; padding:0.7rem 1rem;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:0.875rem;
  cursor:pointer; transition:background 0.2s, transform 0.15s;
  text-decoration: none;
  display: inline-block;
}
.btn-detail-wow:hover { background: var(--yd); color: #fff; transform: scale(1.03); }

/* ── COSA PUOI FARE (dark) ── */
.services-section {
  background: var(--dark);
  padding: 5rem 5%; position: relative; z-index: 1;
}
.services-section::before {
  content:'';position:absolute;bottom:-200px;left:-200px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(255,184,0,0.08) 0%,transparent 70%);
  pointer-events:none;
}
.services-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:2.5rem; }
.service-card-wow {
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(255,255,255,0.08);
  border-radius: 22px; padding: 2rem;
  transition: transform 0.3s, border-color 0.3s, background 0.3s;
  position:relative; overflow:hidden;
}
.service-card-wow.featured { border-color: rgba(255,184,0,0.4); background: rgba(255,184,0,0.04); }
.service-card-wow:hover { transform:translateY(-6px); border-color:var(--y); background:rgba(255,184,0,0.06); }
.sc-icon { font-size:2.5rem; margin-bottom:1.25rem; display:block; }
.service-card-wow h3 { font-weight:900; font-size:1.2rem; color:var(--y); margin-bottom:0.6rem; }
.service-card-wow p { font-size:0.88rem; color:rgba(255,255,255,0.6); line-height:1.65; margin-bottom:1.25rem; }
.sc-list { list-style:none; display:flex; flex-direction:column; gap:0.5rem; margin-bottom:1.5rem; }
.sc-list li { display:flex;align-items:flex-start;gap:0.6rem; font-size:0.85rem; color:rgba(255,255,255,0.75); font-weight:600; }
.sc-list li::before { content:'→';color:var(--y);font-weight:900;flex-shrink:0; }

/* CTA BUTTON (centered yellow) */
.btn-cta {
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--y);color:var(--pd);
  font-family:'Nunito',sans-serif;font-weight:900;font-size:0.9rem;
  padding:0.75rem 1.5rem;border-radius:12px;border:none;cursor:pointer;
  text-decoration:none;
  transition:background 0.2s,transform 0.2s,box-shadow 0.2s;
  box-shadow:0 4px 20px rgba(255,184,0,0.3);
}
.btn-cta:hover { color: #fff; background:var(--yd);transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,184,0,0.45); }
.btn-cta-outline {
  display:inline-flex;align-items:center;gap:0.5rem;
  background:transparent;color:var(--y);
  border:2px solid var(--y);
  font-family:'Nunito',sans-serif;font-weight:900;font-size:0.9rem;
  padding:0.75rem 1.5rem;border-radius:12px;cursor:pointer;
  text-decoration:none;
  transition:all 0.2s;
}
.btn-cta-outline:hover { background:var(--y);color:var(--pd);transform:translateY(-2px); }

/* ── ONLINE SECTION ── */
.online-section {
  background:var(--y);
  padding:5rem 5%;
  display:grid;grid-template-columns:1fr 280px;gap:3rem;align-items:center;
  position:relative;z-index:1;overflow:hidden;
}
.online-section::after {
  content:'';position:absolute;right:-100px;top:50%;transform:translateY(-50%);
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(91,33,182,0.12) 0%,transparent 70%);
  pointer-events:none;
}
.online-tag { font-size:0.72rem;font-weight:900;letter-spacing:0.14em;text-transform:uppercase;color:var(--p);margin-bottom:0.75rem;display:flex;align-items:center;gap:0.5rem; }
.online-tag::before { content:'';width:20px;height:3px;background:var(--p);border-radius:2px; }
.online-section h2 { font-family:'Black Han Sans','Nunito',sans-serif;font-size:clamp(1.8rem,3vw,2.5rem);color:var(--pd);margin-bottom:0.75rem;letter-spacing:-0.5px; }
.online-section p { font-size:0.95rem;color:var(--pd);line-height:1.7;margin-bottom:1rem; }
.online-list { list-style:none;display:flex;flex-direction:column;gap:0.5rem;margin-bottom:1.75rem; }
.online-list li { display:flex;align-items:center;gap:0.6rem;font-size:0.875rem;font-weight:700;color:var(--pd); }
.online-list li::before { content:'✓';color:var(--p);font-weight:900;font-size:1rem; }
.online-char img { width:100%;filter:drop-shadow(0 12px 28px rgba(0,0,0,0.15)); animation:charFloat 4s 1s ease-in-out infinite; }

/* ── NEWSLETTER ── */
.newsletter {
  background: linear-gradient(135deg, var(--pd), var(--p));
  padding:3.5rem 5%;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
  position:relative;z-index:1;overflow:hidden;
}
.newsletter::before {
  content:'';position:absolute;right:-100px;top:50%;transform:translateY(-50%);
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(255,184,0,0.1) 0%,transparent 70%);
  pointer-events:none;
}
.newsletter-left { position:relative; }
.newsletter-left p { font-size:1.05rem;font-weight:700;color:var(--white); margin-bottom: 0; }
.newsletter-left p span { color:var(--y); }
.newsletter-form { display:flex;gap:0.6rem;position:relative; }
.newsletter-form input {
  padding:0.75rem 1.1rem !important;border-radius:12px !important;
  border:1px solid var(--mf-background-primary-color) !important;
  background:rgba(255,255,255,0.08);color:var(--white);
  font-family:'Nunito',sans-serif;font-size:0.9rem;outline:none;
  transition:border-color 0.2s,box-shadow 0.2s;
}
/* .newsletter-form input[type="email"] {min-width:240px;} */
.newsletter-form input:focus { border-color:var(--y);box-shadow:0 0 20px rgba(255,184,0,0.2); }
.newsletter-form input::placeholder { color:rgba(255,255,255,0.4); }
.newsletter-form input[type="submit"] {
  background:var(--y);color:var(--pd);border:none; line-height: normal;
  padding:0.75rem 1.5rem;border-radius:12px;
  font-family:'Nunito',sans-serif;font-weight:900;cursor:pointer;font-size:0.9rem;
  transition:background 0.2s,transform 0.2s;
  box-shadow:0 4px 16px rgba(255,184,0,0.3);
}
.newsletter-form input[type="submit"]:hover { background:var(--yd);transform:scale(1.04); }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .hero-inner { grid-template-columns:1fr; }
  .hero-visual { display:none; }
  .hero-home { padding:100px 5% 60px; min-height:auto; }
  .numeri-section { grid-template-columns:1fr; }
  .numeri-char { display:none; }
  .counters-grid { grid-template-columns:1fr 1fr; }
  .values-row { grid-template-columns:1fr; }
  .prod-grid { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr; }
  .online-section { grid-template-columns:1fr; }
  .online-char { display:none; }
  .stats-strip { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .hero-headline { font-size:2.2rem; }
  .prod-grid { grid-template-columns:1fr; }
  .counters-grid { grid-template-columns:1fr; }
  .stats-strip { grid-template-columns:1fr 1fr; }
  .hero-badge { font-size:0.7rem; }
  .newsletter-form { flex-direction:column; width:100%; }
  .newsletter-form input { min-width:0; }
  .prod-tabs { justify-content:flex-start; }
}


.site-content {
    padding-bottom: 0 !important;
}


.header-layout-2 .site-header .primary-nav > ul > li {
    padding-left: 0;
    padding-right: 0;
}

.header-layout-2 .site-header .primary-nav > ul > li > a {
    padding: 10px 20px;
    border-radius: 6px;
    font-family: inherit;
}

.header-layout-2 .site-header .primary-nav > ul > li > a:hover,
.header-layout-2 .site-header .primary-nav > ul > li > a:focus {
    color: #fff;
    background: var(--p);
}

/* ── HIDE VIEW CART BUTTON ── */
.added_to_cart.wc-forward {
  display: none !important;
}

/* ── BREVO FORM CUSTOM STYLING ── */
.brevo-form-wrapper .sib-form {
  display: flex;
  gap: 0.6rem;
  position: relative;
}

.brevo-form-wrapper .sib-form input[type="email"],
.brevo-form-wrapper .sib-form input[type="text"] {
  padding: 0.75rem 1.1rem;
  border-radius: 12px;
  border: 1.5px solid rgba(255, 184, 0, 0.3);
  background: rgba(255, 255, 255, 0.08);
  color: var(--white);
  font-family: 'Nunito', sans-serif;
  font-size: 0.9rem;
  min-width: 240px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.brevo-form-wrapper .sib-form input[type="email"]:focus,
.brevo-form-wrapper .sib-form input[type="text"]:focus {
  border-color: var(--y);
  box-shadow: 0 0 20px rgba(255, 184, 0, 0.2);
}

.brevo-form-wrapper .sib-form input[type="email"]::placeholder,
.brevo-form-wrapper .sib-form input[type="text"]::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.brevo-form-wrapper .sib-form button[type="submit"],
.brevo-form-wrapper .sib-form input[type="submit"] {
  background: var(--y);
  color: var(--pd);
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 12px;
  font-family: 'Nunito', sans-serif;
  font-weight: 900;
  cursor: pointer;
  font-size: 0.9rem;
  transition: background 0.2s, transform 0.2s;
  box-shadow: 0 4px 16px rgba(255, 184, 0, 0.3);
}

.brevo-form-wrapper .sib-form button[type="submit"]:hover,
.brevo-form-wrapper .sib-form input[type="submit"]:hover {
  background: var(--yd);
  transform: scale(1.04);
}

/* Hide Brevo branding if present */
.brevo-form-wrapper .sib-form__declaration {
  display: none;
}

/* Success/Error messages */
.brevo-form-wrapper .sib-form-message-panel {
  margin-top: 0.5rem;
  font-size: 0.85rem;
}

.brevo-form-wrapper .sib-form-message-panel__text {
  color: var(--y);
  font-weight: 700;
}

/* Responsive for Brevo form */
@media (max-width: 600px) {
  .brevo-form-wrapper .sib-form {
    flex-direction: column;
    width: 100%;
  }

  .brevo-form-wrapper .sib-form input[type="email"],
  .brevo-form-wrapper .sib-form input[type="text"] {
    min-width: 0;
    width: 100%;
  }
}

.woocommerce-cart .view-cart-button {
    display: none;
}


.site-header .products-search .search-submit {
    background: #fff;
    color: var(--p);
    font-weight: 600;
    border: solid 1px #d9d9d9;
}


/* .sib-default-btn {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
} */

.wpcf7 input[type="email"] {
  color: #fff;
  border-radius: 12px;
}


.site-header .product-extra-search .search-field {
  color: var(--dark);
}

.mobile-version .site-header .mobile-menu {
  background-color: var(--mf-background-light-color);
  padding: 20px;
  --mf-background-light-color: #fcb800;
}

.mobile-version .site-header .header-main {
  padding-left: 20px;
  padding-right: 20px;
}

.site-header .product-extra-search .products-search.actived .search-wrapper .search-results {
  color: var(--dark);
}

@media (max-width: 768px) {
  .header-logo img.site-logo { max-width:150px; height:auto; }
}

.sib-email-area {
  margin-right: 15px;
}

.sib-newsletter-form p {
  margin-bottom: 0;
}