*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: "Inter", sans-serif;
  background: #ffffff;
  color: #1c2b3a;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  overflow-x: clip; /* 'clip' invece di 'hidden': blocca scroll globale ma permette overflow ai figli */
  position: relative;
}

:root {
  --nav-h:      64px;
  --ticker-h:   50px;
  --green:      #1a9e52;
  --green-mid:  #22b55e;
  --green-lite: #e6f4ed;
  --green-soft: #c4e8d2;
  --green-hi:   #4fcb7a;
  --green-dark: #137a3e;
  --green-deep: #0d5229;
  --ink:        #1c2b3a;
  --ink2:       #3e5568;
  --ink3:       #6b8299;
  --bg:         #f7f9f8;
  --bg2:        #eef4f0;
  --border:     #d8e6de;
  --white:      #ffffff;
  --sh:   0 2px 16px rgba(20,50,40,.07);
  --sh-m: 0 8px 32px rgba(20,50,40,.1);
  --sh-l: 0 20px 60px rgba(20,50,40,.13);
  --r:    10px;
  --r-lg: 14px;
  --r-xl: 18px;
  --ds-900:     #0F172A;
  --ds-800:     #1E293B;
  --ga-500:     #10B981;
  --ga-600:     #059669;
  --ga-700:     #047857;
  --lgb-50:     #F7FCF8;
  --lgb-75:     #F6FBF8;
  --lgb-100:    #F0FDF4;
  --lgb-150:    #ECFDF5;
  --lnb-0:      #FFFFFF;
  --lnb-50:     #F8FAFC;
  --lnb-25:     #FCFFFD;
}

.container { max-width: 1160px; margin: 0 auto; padding: 0 2rem; }
.container-tight { max-width: 820px; }
.tc { text-align: center; }

/* REVEAL */
.rv  { opacity:0; transform:translateY(24px); transition:opacity .6s ease,transform .6s ease; }
.rvl { opacity:0; transform:translateX(-24px); transition:opacity .6s ease,transform .6s ease; }
.rvr { opacity:0; transform:translateX(24px);  transition:opacity .6s ease,transform .6s ease; }
.rv.on,.rvl.on,.rvr.on { opacity:1; transform:none; }

/* SCROLL REVEAL ANIMATION SYSTEM */
.reveal-up, .reveal-left, .reveal-right, .reveal-scale {
  opacity: 0;
  will-change: opacity, transform;
}
.reveal-up    { transform: translateY(40px);    transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.reveal-left  { transform: translateX(-50px);   transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.reveal-right { transform: translateX(50px);    transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.reveal-scale { transform: scale(.93) translateY(24px); transition: opacity .75s cubic-bezier(.34,1.56,.64,1), transform .75s cubic-bezier(.34,1.56,.64,1); }
.reveal-up.visible, .reveal-left.visible, .reveal-right.visible, .reveal-scale.visible {
  opacity: 1; transform: none;
}


/* EYEBROW */
.eyebrow {
  display:inline-flex; align-items:center; gap:.45rem;
  font-size:.72rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--green); margin-bottom:.4rem;
}
.eyebrow::before {
  content:''; width:18px; height:2px; background:var(--green);
  border-radius:2px; display:block; flex-shrink:0;
}
.eyebrow.white { color:rgba(255,255,255,.8); }
.eyebrow.white::before { background:rgba(255,255,255,.6); }

/* SECTION TITLE */
.stitle {
  font-family:"Anton", sans-serif;
  font-size:clamp(1.9rem, 3.5vw, 3.2rem);
  line-height:1.05; letter-spacing:.02em;
  text-transform:uppercase; color:var(--ink);
}
.stitle .hi { color:var(--green); }
.stitle.ongreen { color:#ffffff; }
.slead { font-size:1rem; color:var(--ink2); line-height:1.75; max-width:520px; margin-top:.85rem; }
.slead.ongreen { color:rgba(255,255,255,.78); }
.sdesc { font-size:1rem; color:var(--ink2); line-height:1.75; max-width:580px; margin:0 auto; margin-top:.85rem; }

/* BUTTONS */
.btn-outline-green {
  display:inline-flex; align-items:center; gap:.4rem;
  background:transparent; color:var(--green);
  border:1.5px solid var(--green); border-radius:4px;
  font-size:.88rem; font-weight:700; padding:.72rem 1.5rem;
  text-decoration:none; transition:all .2s ease; margin-top:1.75rem;
}
.btn-outline-green:hover { background:var(--green); color:#fff; }
.btn-green {
  display:inline-flex; align-items:center; gap:.4rem;
  background:var(--green); color:#fff; border:none; border-radius:4px;
  font-size:.88rem; font-weight:700; padding:.78rem 1.6rem;
  text-decoration:none; transition:all .2s ease; margin-top:1.75rem; cursor:pointer;
}
.btn-green:hover { background:var(--green-dark); transform:translateY(-1px); }

/* NAVBAR */
nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  background:transparent; transition:background .35s, box-shadow .35s;
}
nav.stuck {
  background:rgba(255,255,255,.97);
  box-shadow:0 1px 0 var(--border), var(--sh);
  backdrop-filter:blur(12px);
}
.nav-wrap {
  max-width:1160px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between; height:64px;
}
.brand { display:flex; align-items:center; gap:.55rem; text-decoration:none; }
.brand-logo { height:28px; width:auto; transition:filter .35s; }
nav.stuck .brand-logo { filter: brightness(0) saturate(0); }
.brand-name { font-family:"Anton", sans-serif; font-size:1.25rem; color:#fff; letter-spacing:.05em; transition:color .35s; }
nav.stuck .brand-name { color:var(--ink); }
.nav-links { display:flex; align-items:center; gap:1.45rem; list-style:none; }
.nav-links a { text-decoration:none; color:rgba(255,255,255,.8); font-size:.82rem; font-weight:500; transition:color .2s; }
.nav-links a:hover { color:#fff; }
nav.stuck .nav-links a { color:var(--ink2); }
nav.stuck .nav-links a:hover { color:var(--ink); }
.nav-links a.active-link { color:#fff; font-weight:700; }
nav.stuck .nav-links a.active-link { color:var(--green-dark); }
.nav-right { display:flex; align-items:center; gap:1rem; }
.nav-btn {
  display:inline-flex; align-items:center;
  background:rgba(255,255,255,.18); border:1.5px solid rgba(255,255,255,.45);
  color:#fff; font-size:.84rem; font-weight:700;
  padding:.52rem 1.25rem; border-radius:4px;
  text-decoration:none; transition:all .2s;
}
.nav-btn:hover { background:rgba(255,255,255,.3); border-color:rgba(255,255,255,.75); }
nav.stuck .nav-btn { background:var(--green); border-color:var(--green); color:#fff; }
nav.stuck .nav-btn:hover { background:var(--green-dark); border-color:var(--green-dark); }
.nav-hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:.4rem;
}
.nav-hamburger span { display:block; width:22px; height:2px; background:rgba(255,255,255,.85); border-radius:2px; transition:all .25s ease; }
nav.stuck .nav-hamburger span { background:var(--ink); }
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.nav-mobile {
  display:none; position:absolute; top:64px; left:0; right:0;
  background:rgba(255,255,255,.98); border-bottom:1px solid var(--border);
  box-shadow:var(--sh-m); padding:1rem 2rem 1.5rem;
}
.nav-mobile.open { display:block; }
.nav-mobile ul { list-style:none; display:flex; flex-direction:column; gap:.1rem; }
.nav-mobile a { display:block; padding:.7rem 0; font-size:.9rem; font-weight:500; color:var(--ink2); text-decoration:none; border-bottom:1px solid var(--bg2); transition:color .15s; }
.nav-mobile a:hover { color:var(--green); }
.nav-mobile .nav-mobile-cta { margin-top:.5rem; border-bottom:none; display:inline-flex; background:var(--green); color:#fff; padding:.62rem 1.3rem; border-radius:4px; font-weight:700; }

/* HERO */
#hero {
  background: #effaf3;
  background-image:
    radial-gradient(ellipse 95% 75% at 50% -12%, rgba(22,163,74,0.40) 0%, transparent 80%),
    radial-gradient(circle at 18% 75%, rgba(22,163,74,0.25) 0%, transparent 45%),
    radial-gradient(circle at 82% 75%, rgba(22,163,74,0.25) 0%, transparent 45%),
    url("data:image/svg+xml,%3Csvg width='28' height='28' viewBox='0 0 28 28' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='%2316a34a' fill-opacity='0.18'/%3E%3C/svg%3E");
  background-size: auto, auto, auto, 28px 28px;
  display:flex; flex-direction:column;
  padding-top:calc(var(--nav-h) + 2rem);
  padding-bottom: 11rem;
  position:relative;
}
#hero::before {
  content: ""; position: absolute; top: -8%; right: -4%;
  width: 520px; height: 520px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(22,163,74,0.07) 0%, transparent 70%);
  z-index: 0; pointer-events: none;
}
#hero::after {
  content: "";
  position: absolute; bottom: 6rem; left: -3%;
  width: 400px; height: 400px;
  border-radius: 50%;
  border: 1.5px solid rgba(22,163,74,0.09);
  z-index: 0; pointer-events: none;
}

/* FLOATING CARDS */
.floating-cards { position:absolute; inset:0; pointer-events:none; z-index:2; overflow:hidden; }
.float-card {
  position:absolute; background:#ffffff;
  border: 1px solid rgba(22,163,74,0.13);
  border-top: 2.5px solid rgba(22,163,74,0.55);
  border-radius: 12px;
  padding: 14px; box-shadow: 0 16px 48px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.05);
  display: flex; align-items: center; gap: 12px;
  animation: floatCardAnim 6s ease-in-out infinite alternate;
}
.fc-1 { top: 12%; left: 10%; animation-delay: 0s; }
.fc-2 { top: 55%; right: 8%; animation-delay: -2s; padding:12px; }
.fc-3 { bottom: 35%; left: 14%; animation-delay: -4s; }
.fc-4 { top: 22%; right: 18%; animation-delay: -1s; padding:10px 14px; }

@keyframes floatCardAnim {
  0% { transform: translateY(0px) rotate(var(--rot, 0deg)); }
  100% { transform: translateY(-25px) rotate(var(--rot, 0deg)); }
}

.fc-icon-wrap { background:var(--green-hi); width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.fc-icon { color:#022c22; font-weight:900; font-size:14px; line-height:1; padding-top:2px; }
.fc-info { display:flex; flex-direction:column; gap:6px; width:50px; }
.fc-line { height:4px; background:rgba(22,163,74,0.18); border-radius:4px; }
.fc-line.w-full { width:100%; }
.fc-line.w-half { width:60%; }
.fc-barcode { display:flex; gap:4px; height:30px; align-items:center; }
.fc-barcode span { width:2px; height:100%; background:rgba(22,163,74,0.5); border-radius:1px; }
.fc-barcode span.thick { width:6px; }
.fc-chart { display:flex; gap:4px; align-items:flex-end; height:30px; }
.fc-bar { width:8px; background:rgba(22,163,74,0.35); border-radius:2px 2px 0 0; }
.fc-bar.h-1 { height:12px; }
.fc-bar.h-2 { height:20px; background:rgba(22,163,74,0.6); }
.fc-bar.h-3 { height:30px; background:var(--green); }
.fc-tag-chip { font-family:"Outfit",sans-serif; font-size:0.75rem; font-weight:800; color:var(--green-dark); letter-spacing:1px; white-space:nowrap; }

.hero-body { position:relative; z-index:3; }
.hero-stats { position:relative; z-index:3; }
.hero-body {
  flex:1; display:flex; flex-direction:column; align-items:center;
  justify-content:center; text-align:center; padding:1.5rem 2rem .95rem;
  width:100%; max-width:900px; margin:0 auto;
}
.hero-tag {
  display:inline-flex; align-items:center; gap:.4rem;
  background:rgba(22,163,74,0.08); border:1px solid rgba(22,163,74,0.25);
  color:var(--green-dark); font-size:.74rem; font-weight:600;
  letter-spacing:.08em; padding:.35rem .9rem; border-radius:100px;
  margin-bottom:.85rem; animation:fid .7s ease .1s both;
}
.hero-dot { width:5px; height:5px; background:var(--green); border-radius:50%; animation:blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.2} }
.hero-h1 {
  font-family:"Anton", sans-serif;
  font-size:5.8rem;
  line-height:1.08; letter-spacing:.015em; color:#0d1f12;
  overflow:visible; padding-bottom:.08em;
}
.hero-h1 .row { display:block; overflow:visible; }
.hero-h1 .row-in { display:block; animation:slup .8s cubic-bezier(.22,1,.36,1) both; }
.hero-h1 .row:nth-child(1) .row-in { animation-delay:.18s; }
.hero-h1 .row:nth-child(2) .row-in { animation-delay:.30s; }
.hero-h1 .row:nth-child(3) .row-in { animation-delay:.42s; }
@keyframes slup { from{transform:translateY(102%);opacity:0} to{transform:translateY(0);opacity:1} }
.hero-h1 .muted { color:var(--green); font-size:.78em; letter-spacing:.04em; white-space:nowrap; }
.hero-sub {
  font-size:clamp(1rem, 1.5vw, 1.2rem); color:#3a4e3f;
  max-width:740px; line-height:1.75; margin-top:.8rem;
  animation:fiu .8s ease .62s both;
}
.hero-ctas {
  display:flex; align-items:center; gap:.75rem; flex-wrap:wrap;
  flex-direction:column;
  justify-content:center; width:min(100%, 760px);
  margin-top:1.15rem; animation:fiu .8s ease .76s both;
}
.hero-trust-micro {
  display:flex; align-items:center; gap:.5rem 1rem;
  flex-wrap:wrap; justify-content:center;
  font-size:.78rem; color:#5a7a65; font-weight:500;
  margin-top:.1rem;
}
.hero-trust-micro span { white-space:nowrap; }
.hero-wa-btn {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:230px; padding:.95rem 1.7rem;
  border-radius:4px; border:2px solid var(--green);
  background:var(--green); color:#fff;
  text-decoration:none; font-size:.95rem; font-weight:700;
  box-shadow:0 4px 14px rgba(22,163,74,0.18);
  transition:transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.hero-wa-btn:hover {
  transform:translateY(-2px);
  background:var(--green-dark);
  border-color:var(--green-dark);
  box-shadow:0 14px 32px rgba(22,163,74,0.30);
}
.hero-wa-btn:focus-visible {
  outline:none;
  box-shadow:0 0 0 3px rgba(22,163,74,0.2);
}
.btn-w {
  display:inline-flex; align-items:center; gap:.4rem;
  background:#fff; color:var(--green-deep); font-size:.9rem; font-weight:700;
  padding:.8rem 1.9rem; border-radius:4px; border:2px solid #fff;
  text-decoration:none; box-shadow:0 4px 20px rgba(0,0,0,.14); transition:all .22s ease;
}
.btn-w:hover { background:transparent; color:#fff; transform:translateY(-1px); box-shadow:0 8px 28px rgba(0,0,0,.18); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:.4rem;
  background:transparent; color:rgba(255,255,255,.85); font-size:.875rem; font-weight:600;
  padding:.8rem 1.5rem; border-radius:4px; border:1.5px solid rgba(255,255,255,.35);
  text-decoration:none; transition:all .22s ease;
}
.btn-ghost:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.65); color:#fff; }
.btn-whatsapp {
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  background:#25d366; color:#fff; border:1.5px solid #25d366; border-radius:4px;
  font-size:.9rem; font-weight:700; padding:.82rem 1.5rem;
  text-decoration:none; box-shadow:0 10px 24px rgba(17,24,39,.16); transition:all .22s ease;
}
.btn-whatsapp:hover { background:#1fb457; border-color:#1fb457; transform:translateY(-1px); box-shadow:0 14px 28px rgba(17,24,39,.22); }
.btn-whatsapp svg { width:18px; height:18px; flex-shrink:0; }
.btn-whatsapp-light { box-shadow:0 12px 30px rgba(0,0,0,.18); }
.btn-whatsapp-outline {
  background:#fff; color:var(--green-dark); border-color:var(--border); box-shadow:none;
}
.btn-whatsapp-outline:hover { background:var(--bg); border-color:var(--green-soft); color:var(--green-dark); }
.cta-link-secondary {
  display:inline-flex; align-items:center; justify-content:center; gap:.4rem;
  color:rgba(255,255,255,.88); font-size:.88rem; font-weight:600; text-decoration:none;
  padding:.82rem 1.4rem; border-radius:4px; border:1.5px solid rgba(255,255,255,.24);
  transition:all .22s ease;
}
.cta-link-secondary:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.45); color:#fff; }
.page-hero-ctas,
.fz-hero-actions,
.page-cta-actions,
.fz-cta-strip-actions {
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
}
.whatsapp-float-wrap {
  position:fixed; left:1.35rem; bottom:1rem; z-index:980;
  display:flex; flex-direction:row-reverse; align-items:center; gap:.7rem;
  opacity:0; transform:translateY(10px) scale(.96); pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
}
.whatsapp-float-wrap.visible { opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.whatsapp-float-hint {
  max-width:220px; background:#fff; color:var(--ink); border:1px solid rgba(17,24,39,.08);
  border-radius:14px; padding:.72rem .85rem; font-size:.78rem; font-weight:600; line-height:1.4;
  box-shadow:0 14px 30px rgba(15,23,42,.12);
  opacity:0; transform:translateY(10px) scale(.96); pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
}
.whatsapp-float-hint.visible { opacity:1; transform:translateY(0) scale(1); }
.whatsapp-float {
  display:inline-flex; align-items:center; justify-content:center;
  width:58px; height:58px; background:transparent; color:inherit; border-radius:50%;
  text-decoration:none; box-shadow:none;
  transition:transform .18s ease, filter .18s ease;
}
.whatsapp-float:hover { transform:translateY(-2px) scale(1.03); filter:drop-shadow(0 16px 28px rgba(7,94,84,.22)); }
.whatsapp-float svg { width:100%; height:100%; flex-shrink:0; display:block; }
body:has(.nav-mobile.open) .whatsapp-float-wrap { opacity:.2; pointer-events:none; }
.hero-trust {
  display:flex; flex-wrap:wrap; gap:.35rem 1.15rem; justify-content:center;
  margin-top:.85rem; animation:fiu .8s ease .9s both;
}
.trust-item { display:flex; align-items:center; gap:.3rem; font-size:.77rem; color:#3a4e3f; font-weight:500; }
.trust-item::before { content:"\2713"; font-weight:800; color:var(--green); }
.hero-stats {
  margin:1.35rem auto 0;
  width:min(100%, 920px);
  border:1px solid rgba(22,163,74,0.12); display:grid;
  grid-template-columns:repeat(4,1fr); animation:fiu .8s ease 1.05s both;
  background:#ffffff; border-radius:22px;
  box-shadow:0 20px 48px rgba(15,23,42,0.08);
  overflow:hidden; backdrop-filter: blur(6px);
}
.hstat { padding:1.15rem 1.5rem; border-right:1px solid rgba(22,163,74,0.10); text-align:center; background: linear-gradient(180deg, #ffffff 0%, #f8fcf9 100%); }
.hstat:last-child { border-right:none; }
.hstat:nth-child(1) { background: linear-gradient(180deg, #effaf3 0%, #ffffff 100%); }
.hstat:nth-child(2) { background: linear-gradient(180deg, #f4fbf6 0%, #ffffff 100%); }
.hstat:nth-child(3) { background: linear-gradient(180deg, #f7fcf8 0%, #ffffff 100%); }
.hstat:nth-child(4) { background: linear-gradient(180deg, #eef8f1 0%, #ffffff 100%); }
.hstat-v { font-family:"Anton",sans-serif; font-size:clamp(1.5rem,2.8vw,2.4rem); color:var(--green-dark); line-height:1; letter-spacing:.02em; }
.hstat-l { font-size:.72rem; color:#5e7666; font-weight:700; margin-top:.34rem; letter-spacing:.03em; text-transform:uppercase; }
@keyframes fid { from{opacity:0;transform:translateY(-14px)} to{opacity:1;transform:none} }
@keyframes fiu { from{opacity:0;transform:translateY(18px)}  to{opacity:1;transform:none} }
#hero-watermark {
  position: absolute; bottom: 12%; right: 1%;
  width: clamp(250px, 35vw, 440px); height: auto;
  opacity: 0.06; pointer-events: none; z-index: 1; user-select: none;
  filter: brightness(0) saturate(0);
}

/* SCROLL HINT (solo mobile) */
@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(7px); }
}
.hero-scroll-hint {
  display: none; /* nascosto su desktop */
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  color: var(--ink2);
  z-index: 5;
  padding-bottom: 0.5rem;
  animation: scrollBounce 2s ease-in-out infinite;
}
.hero-scroll-label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.55;
}
.hero-scroll-hint svg {
  width: 28px;
  height: 28px;
  opacity: 0.45;
  stroke: var(--green-dark);
}


#hero-mockup {
  padding: 1rem 0 2rem;
  margin-top: -11rem;
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 10;
}
/* WRAPPER SFONDO CONTINUO TRA HERO MOCKUP E PROBLEMA */
#hero-problema-wrapper { position: relative; }
#hero-problema-wrapper::before {
  content: "";
  position: absolute;
  top: 11rem; left: 0; right: 0; bottom: 0;
  z-index: 0; pointer-events: none;
  background: #ffffff;
  background-image:
    radial-gradient(circle at 12% 16%, rgba(22,163,74,0.08) 0%, transparent 18%),
    radial-gradient(circle at 88% 10%, rgba(22,163,74,0.06) 0%, transparent 16%),
    linear-gradient(180deg, rgba(22,163,74,0.03) 0%, rgba(255,255,255,0) 26%),
    linear-gradient(180deg, #ffffff 0%, #fbfdfb 46%, #f6fbf8 100%);
  background-size: auto, auto, auto, auto;
}
#hero-problema-wrapper::after { display: none; }
#hero-mockup > .container {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1160px;
  padding: 0 2rem;
}
/* MOCKUP IMAGE FRAME (mobile) */
.mockup-img-frame {
  display: none; /* nascosto su desktop, visibile solo mobile */
  background: #fff;
  border-radius: 12px;
  border: 1px solid rgba(28,43,58,0.08);
  box-shadow: 0 28px 52px rgba(15,23,42,0.10), 0 10px 24px rgba(15,23,42,0.06);
  overflow: hidden;
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
}
.mif-header {
  background: #f1f3f5;
  border-bottom: 1px solid #e2e8f0;
  padding: 6px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.mif-dots { display: flex; gap: 5px; flex-shrink: 0; }
.mif-dots span { width: 8px; height: 8px; border-radius: 50%; }
.mif-dots span:nth-child(1) { background: #ff5f56; }
.mif-dots span:nth-child(2) { background: #ffbd2e; }
.mif-dots span:nth-child(3) { background: #27c93f; }
.mif-bar {
  flex: 1;
  background: #e2e8f0;
  border-radius: 4px;
  height: 14px;
}
.mif-body { background: #fff; }
.mif-scroll {
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
.mif-body img {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  transition: width 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  cursor: zoom-in;
}
.mif-body img.is-zoomed {
  width: 250%; /* Zoom 2.5x */
  max-width: none;
  cursor: zoom-out;
}
.mif-zoom-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,0.2);
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  color: rgba(28,43,58,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
  transition: transform 0.2s, background 0.2s, color 0.2s, opacity 0.3s;
  opacity: 0.7;
}
.mif-zoom-overlay:hover { transform: translate(-50%, -50%) scale(1.05); background: rgba(255,255,255,0.4); color: rgba(28,43,58,1); opacity: 1; }

/* Wrapper del mockup - clip dell'overflow scalato */
.mockup-scroll-outer {
  width: 100%;
  overflow: hidden;
}
.mockup-scroll-outer,
.hm-browser,
.dm-wrapper {
  user-select: none;
}
.hm-browser {
  background: #fff;
  border-radius: 12px;
  border: 1px solid rgba(28,43,58,0.08);
  box-shadow: 0 28px 52px rgba(15,23,42,0.10), 0 10px 24px rgba(15,23,42,0.06);
  overflow: hidden;
  width: 1100px;     /* Larghezza FISSA desktop - il layout non rifluisce mai */
  max-width: none;   /* Nessun limite: e' il scale a rimpicciolirlo */
  transform-origin: top left;  /* Scala partendo dall'angolo in alto a sinistra */
}
.hm-browser-header {
  background: #f1f3f5;
  border-bottom: 1px solid #e2e8f0;
  padding: 12px 16px;
  display: flex;
  align-items: center;
}
.hm-dots { display: flex; gap: 8px; }
.hm-dots span {
  width: 12px; height: 12px; border-radius: 50%;
  background: #cbd5e1;
}
.hm-dots span:nth-child(1) { background: #ff5f56; }
.hm-dots span:nth-child(2) { background: #ffbd2e; }
.hm-dots span:nth-child(3) { background: #27c93f; }
.hm-browser-body { background: #fff; }
.hm-browser-body img {
  width: 100%;
  display: block;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}

/* ABSTRACT DASHBOARD MOCKUP - minimal palette */
.dm-wrapper {
  display: flex;
  background: #f5f6f8;
  font-family: 'Inter', sans-serif;
  color: #374151;
  text-align: left;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  overflow: hidden;
  max-height: 520px;
}

/* Sidebar */
.dm-sidebar {
  width: 200px;
  background: #1a2332;
  color: #8b99b0;
  display: flex;
  flex-direction: column;
  padding: 1.25rem 0.85rem;
  flex-shrink: 0;
  overflow: hidden;
}
.dm-logo { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 1.4rem; padding: 0 0.25rem; }
.dm-logo svg { width: 18px; height: 18px; color: #6ee7b7; }
.dm-logo-text { color: #e2e8f0; font-weight: 800; font-size: 0.8rem; letter-spacing: 0.5px; line-height: 1.2; }
.dm-logo-text span { display: block; font-size: 0.56rem; color: #4b5e78; font-weight: 600; text-transform: uppercase; margin-top: 1px; }

.dm-nav-wrap { flex: 1; display: flex; flex-direction: column; gap: 0.1rem; overflow-y: auto; overflow-x: hidden; }
/* Scrollbar custom per la sidebar */
.dm-nav-wrap::-webkit-scrollbar { width: 3px; }
.dm-nav-wrap::-webkit-scrollbar-track { background: transparent; }
.dm-nav-wrap::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }

@media (min-width: 901px) {
  #mockupDesktop {
    pointer-events: none;
  }

  #mockupDesktop .dm-nav-wrap {
    overflow: hidden;
  }
}

.dm-nav-label { font-size: 0.53rem; font-weight: 700; color: #4b5e78; text-transform: uppercase; letter-spacing: 0.08em; padding: 0 0.65rem; margin-bottom: 0.35rem; }
.dm-nav-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.1rem; }
.dm-nav-list li { display: flex; align-items: center; gap: 0.55rem; padding: 0.35rem 1.8rem 0.35rem 0.65rem; border-radius: 5px; font-size: 0.72rem; font-weight: 500; cursor: default; white-space: nowrap; position: relative; }
.dm-nav-list li .dm-ic { display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.dm-nav-list li .dm-ic svg { width: 14px; height: 14px; opacity: 0.6; }
.dm-nav-list li.dm-active { background: rgba(255,255,255,0.06); color: #f8fafc; font-weight: 600; }
.dm-nav-list li.dm-active .dm-ic { position: relative; }
.dm-nav-list li.dm-active .dm-ic::after { content: ''; position: absolute; left: -14px; top: 50%; transform: translateY(-50%); width: 2px; height: 12px; background: #6ee7b7; border-radius: 0 2px 2px 0; }
.dm-nav-list li.dm-active .dm-ic svg { opacity: 1; color: #6ee7b7; }
.dm-chevron { position: absolute; right: 0.15rem; top: 50%; transform: translateY(-50%); width: 14px; height: 14px; opacity: 0.4; }

.dm-nav-badge { margin-left: auto; font-size: 0.55rem; font-weight: 700; padding: 0.15rem 0.3rem; border-radius: 4px; background: rgba(255,255,255,0.1); color: #cbd5e1; line-height: 1; }
.dm-nav-badge.dm-badge-warn { background: #f59e0b; color: #fff; }
.dm-nav-badge.dm-badge-alert { background: #ef4444; color: #fff; }
.dm-nav-footer { display: flex; justify-content: space-between; align-items: center; padding: 0.6rem 0.4rem 0; border-top: 1px solid rgba(255,255,255,0.06); margin-top: 0.5rem; }
.dm-footer-ic svg { width: 14px; height: 14px; color: #4b5e78; }
.dm-exit { display: flex; align-items: center; gap: 0.35rem; font-size: 0.68rem; color: #f87171; font-weight: 600; opacity: 0.7; }
.dm-exit svg { width: 13px; height: 13px; }

/* Main */
.dm-main { flex: 1; padding: 1.1rem 1.35rem; display: flex; flex-direction: column; gap: 0.85rem; overflow: hidden; min-width: 0; }
.dm-header { display: flex; justify-content: space-between; align-items: center; }
.dm-title { display: flex; align-items: center; gap: 0.55rem; }
.dm-title-ic { width: 26px; height: 26px; background: #ecfdf5; color: #34d399; border-radius: 7px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.dm-title-ic svg { width: 13px; height: 13px; }
.dm-title h2 { margin: 0; font-size: 1rem; font-weight: 700; color: #1e293b; letter-spacing: -0.02em; }
.dm-date { font-size: 0.66rem; color: #9ca3af; font-weight: 400; margin-top: 1px; }
.dm-user { display: flex; align-items: center; gap: 0.5rem; background: #fff; padding: 0.28rem 0.7rem 0.28rem 0.38rem; border-radius: 50px; border: 1px solid #e5e7eb; }
.dm-user-av { width: 22px; height: 22px; background: #f3f4f6; color: #9ca3af; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.dm-user-av svg { width: 11px; height: 11px; }
.dm-user-info { display: flex; flex-direction: column; }
.dm-user-info strong { font-size: 0.68rem; color: #1e293b; font-weight: 600; }
.dm-user-info span { font-size: 0.6rem; color: #9ca3af; }

/* KPI Cards */
.dm-metrics { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.6rem; }
.dm-card { background: #fff; border-radius: 8px; padding: 0.7rem 0.75rem; border: 1px solid #e5e7eb; display: flex; flex-direction: column; gap: 0.2rem; }
/* KPI colored tops and icons */
.dm-c-blue { border-top: 2px solid #3b82f6; border-top-left-radius: 4px; border-top-right-radius: 4px; }
.dm-c-blue .dm-c-ic { color: #3b82f6; background: #eff6ff; padding: 2px; border-radius: 4px; }
.dm-c-orange { border-top: 2px solid #f59e0b; border-top-left-radius: 4px; border-top-right-radius: 4px; }
.dm-c-orange .dm-c-ic { color: #f59e0b; background: #fef3c7; padding: 2px; border-radius: 4px; }
.dm-c-green { border-top: 2px solid #10b981; border-top-left-radius: 4px; border-top-right-radius: 4px; }
.dm-c-green .dm-c-ic { color: #10b981; background: #ecfdf5; padding: 2px; border-radius: 4px; }
.dm-c-purple { border-top: 2px solid #8b5cf6; border-top-left-radius: 4px; border-top-right-radius: 4px; }
.dm-c-purple .dm-c-ic { color: #8b5cf6; background: #f5f3ff; padding: 2px; border-radius: 4px; }
.dm-c-teal { border-top: 2px solid #14b8a6; border-top-left-radius: 4px; border-top-right-radius: 4px; }
.dm-c-teal .dm-c-ic { color: #14b8a6; background: #f0fdfa; padding: 2px; border-radius: 4px; }
.dm-c-ic { display: flex; align-items: center; margin-bottom: 0.1rem; }
.dm-c-ic svg { width: 13px; height: 13px; }
.dm-c-val { font-size: 1.25rem; font-weight: 700; color: #1e293b; line-height: 1; letter-spacing: -0.02em; }
.dm-c-lbl { font-size: 0.6rem; color: #9ca3af; font-weight: 400; line-height: 1.3; }
.dm-kpi-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.15rem; }
.dm-kpi-trend { font-size: 0.6rem; font-weight: 600; padding: 0.1rem 0.35rem; border-radius: 4px; }
.dm-up { color: #059669; background: #f0fdf4; }
.dm-down { color: #6b7280; background: #f3f4f6; }
.dm-kpi-status { font-size: 0.58rem; font-weight: 600; padding: 0.1rem 0.35rem; border-radius: 4px; }
.dm-ok { color: #059669; background: #f0fdf4; }
.dm-warn { color: #92400e; background: #fef9c3; }
.dm-c-den { font-size: 0.8rem; font-weight: 500; color: #9ca3af; }
.dm-c-bar { height: 2.5px; background: #f3f4f6; border-radius: 2px; margin-top: 0.3rem; overflow: hidden; }
.dm-c-bar-fill { height: 100%; border-radius: 2px; background: #d1d5db; }
.dm-spark { display: block; width: 100%; height: 16px; margin-top: 0.3rem; opacity: 0.4; }

/* Module table */
.dm-grid { display: grid; grid-template-columns: 2fr 1.2fr; gap: 0.8rem; min-height: 0; }
.dm-panel { background: #fff; border-radius: 8px; border: 1px solid #e5e7eb; padding: 0.85rem 1rem; min-height: 0; }
.dm-panel-side { display: flex; flex-direction: column; gap: 0; min-height: 0; }
.dm-panel-hd { font-size: 0.76rem; font-weight: 600; color: #374151; margin-bottom: 0.65rem; display: flex; justify-content: space-between; align-items: center; }
.dm-modtable { display: flex; flex-direction: column; }
.dm-modrow { display: grid; grid-template-columns: 1.3fr 1.8fr 0.6fr 0.5fr; align-items: center; gap: 0.5rem; padding: 0.4rem 0; border-bottom: 1px solid #f9fafb; }
.dm-modrow:last-child { border-bottom: none; }
.dm-modhd { font-size: 0.6rem; font-weight: 600; color: #9ca3af; text-transform: uppercase; letter-spacing: 0.07em; padding-bottom: 0.42rem; border-bottom: 1px solid #f3f4f6 !important; }
.dm-mod-name { display: flex; align-items: center; gap: 0.45rem; min-width: 0; }
.dm-mod-name strong { font-size: 0.73rem; font-weight: 500; color: #374151; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dm-mod-desc { font-size: 0.65rem; color: #9ca3af; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* Row icons - all uniform neutral */
.dm-r-ic { width: 24px; height: 24px; border-radius: 6px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: #f3f4f6; color: #9ca3af; }
.dm-r-ic svg { width: 11px; height: 11px; }
.dm-bg-blue, .dm-bg-orange, .dm-bg-purple, .dm-bg-green, .dm-bg-red { background: #f3f4f6 !important; color: #6b7280 !important; }
/* Tags - very muted */
.dm-tag { font-size: 0.58rem; font-weight: 600; padding: 0.12rem 0.4rem; border-radius: 4px; white-space: nowrap; background: #f3f4f6; color: #6b7280; }
.dm-tag-blue, .dm-tag-orange, .dm-tag-green, .dm-tag-purple { background: #f3f4f6 !important; color: #6b7280 !important; }
/* Buttons - neutral */
.dm-btn-sm { font-size: 0.62rem; font-weight: 600; color: #6b7280; background: #f9fafb; border: 1px solid #e5e7eb; padding: 0.18rem 0.45rem; border-radius: 4px; white-space: nowrap; flex-shrink: 0; }
.dm-btn-orange, .dm-btn-purple { color: #6b7280 !important; background: #f9fafb !important; border: 1px solid #e5e7eb !important; }
.dm-badge-red { font-size: 0.58rem; background: #fef2f2; color: #9ca3af; padding: 0.12rem 0.45rem; border-radius: 8px; font-weight: 600; }
.dm-badge-green { font-size: 0.58rem; background: #f0fdf4; color: #6b7280; padding: 0.12rem 0.45rem; border-radius: 8px; font-weight: 600; }

/* Right panel */
.dm-compliance-card { display: flex; align-items: center; gap: 0.7rem; background: #fff; border: 1px solid #e5e7eb; border-radius: 8px; padding: 0.65rem; margin-bottom: 0.5rem; }
.dm-ring-wrap { position: relative; flex-shrink: 0; width: 56px; height: 56px; }
.dm-ring-wrap svg { width: 56px; height: 56px; }
.dm-ring-val { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: 0.7rem; font-weight: 700; color: #374151; }
.dm-ring-info { display: flex; flex-direction: column; gap: 0.08rem; min-width: 0; }
.dm-ring-info strong { font-size: 0.73rem; font-weight: 600; color: #374151; }
.dm-ring-info span { font-size: 0.6rem; color: #9ca3af; }
.dm-ring-checks { display: flex; flex-direction: column; gap: 0.2rem; margin-top: 0.3rem; }
.dm-chk { display: flex; align-items: center; gap: 0.28rem; font-size: 0.6rem; font-weight: 500; }
.dm-chk svg { flex-shrink: 0; }
.dm-chk-ok { color: #34d399; }
.dm-chk-warn { color: #f59e0b; }
.dm-alert { background: #fafafa; border: 1px solid #f3f4f6; border-radius: 7px; padding: 0.6rem 0.7rem; display: flex; gap: 0.55rem; align-items: flex-start; margin-bottom: 0.5rem; }
.dm-al-ic { background: #f9fafb; color: #9ca3af; padding: 0.3rem; border-radius: 6px; flex-shrink: 0; }
.dm-al-ic svg { width: 12px; height: 12px; }
.dm-al-txt { display: flex; flex-direction: column; gap: 0.1rem; }
.dm-al-txt strong { font-size: 0.72rem; color: #374151; font-weight: 600; }
.dm-al-txt span { font-size: 0.63rem; color: #9ca3af; }
.dm-timeline { display: flex; flex-direction: column; gap: 0.5rem; }
.dm-tl-item { display: flex; align-items: center; gap: 0.55rem; position: relative; }
.dm-tl-item::before { content: ''; position: absolute; left: 4px; top: 12px; bottom: -8px; width: 1px; background: #f3f4f6; }
.dm-tl-item:last-child::before { display: none; }
.dm-tl-dot { width: 9px; height: 9px; border-radius: 50%; z-index: 1; background: #d1d5db; flex-shrink: 0; border: none !important; box-shadow: none !important; }
.dm-tl-txt { display: flex; flex: 1; justify-content: space-between; align-items: center; min-width: 0; gap: 0.4rem; }
.dm-tl-txt strong { font-size: 0.68rem; color: #4b5563; font-weight: 400; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dm-tl-txt span { font-size: 0.62rem; color: #9ca3af; flex-shrink: 0; }

/* Header extras */
.dm-sync { color: #34d399; font-weight: 500; }
.dm-haccp-badge { display: flex; align-items: center; gap: 0.28rem; font-size: 0.62rem; font-weight: 600; color: #6b7280; background: #f3f4f6; padding: 0.22rem 0.55rem; border-radius: 20px; }

/* Responsive */
@media (max-width: 900px) {
  .hm-browser { max-width: 100vw; border-radius: 8px; border-width: 0; border-top: 1px solid rgba(255,255,255,0.2); }
  .dm-wrapper { flex-direction: column; max-height: none; }
  .dm-sidebar { width: 100%; flex-direction: row; align-items: center; padding: 0.75rem 1rem; }
  .dm-nav { display: none; }
  .dm-nav-footer { display: none; }
  .dm-logo { margin: 0; }
  .dm-main { padding: 1rem; gap: 0.75rem; }
  .dm-metrics { grid-template-columns: repeat(2, 1fr); gap: 0.6rem; }
  .dm-grid { grid-template-columns: 1fr; gap: 0.75rem; }
}
@media (max-width: 500px) {
  .dm-sidebar { padding: 0.75rem; }
  .dm-main { padding: 0.75rem; }
  .dm-metrics { grid-template-columns: 1fr 1fr; }
  .dm-header { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
}



/* QUICK ACTIONS */
.dm-panel-sub { font-size: 0.6rem; font-weight: 400; color: #c4c9d4; margin-left: 0.35rem; text-transform: none; letter-spacing: 0; }
.dm-panel-hd--mt { margin-top: 0.9rem; margin-bottom: 0.45rem; }
.dm-qa-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.45rem; }
.dm-qa-btn { background: #f9fafb; border: 1px solid #eaecf0; border-radius: 4px; padding: 0.6rem 0.65rem; display: flex; flex-direction: column; gap: 0.08rem; cursor: default; }
.dm-qa-ic { width: 24px; height: 24px; background: #f3f4f6; border-radius: 4px; display: flex; align-items: center; justify-content: center; margin-bottom: 0.25rem; }
.dm-qa-ic svg { width: 12px; height: 12px; stroke: #6b7280; }
.dm-qa-lbl { font-size: 0.71rem; font-weight: 600; color: #374151; }
.dm-qa-sub { font-size: 0.59rem; color: #9ca3af; }
/* Icon color tints */
.dm-qa-ic-blue { background: #eff6ff !important; }
.dm-qa-ic-blue svg { stroke: #3b82f6 !important; }
.dm-qa-ic-amber { background: #fff7ed !important; }
.dm-qa-ic-amber svg { stroke: #f97316 !important; }
.dm-qa-ic-green { background: #f0fdf4 !important; }
.dm-qa-ic-green svg { stroke: #16a34a !important; }
.dm-qa-ic-purple { background: #faf5ff !important; }
.dm-qa-ic-purple svg { stroke: #9333ea !important; }
/* LOT EXPIRY */
.dm-exp-badge { font-size: 0.58rem; font-weight: 500; color: #92400e; background: #fef3c7; border: 1px solid #fde68a; border-radius: 10px; padding: 0.05rem 0.45rem; margin-left: 0.3rem; }
.dm-exp-table { display: flex; flex-direction: column; }
.dm-exp-row { display: grid; grid-template-columns: 2.2fr 1fr 1fr 0.75fr; gap: 0.3rem; align-items: center; padding: 0.35rem 0; border-bottom: 1px solid #f9fafb; }
.dm-exp-row:last-child { border-bottom: none; }
.dm-exp-hd { font-size: 0.57rem; font-weight: 600; color: #9ca3af; text-transform: uppercase; letter-spacing: 0.06em; border-bottom: 1px solid #f0f0f2 !important; padding-bottom: 0.35rem; }
.dm-exp-prod { font-size: 0.69rem; font-weight: 500; color: #374151; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dm-exp-lot { font-size: 0.62rem; color: #9ca3af; }
.dm-exp-date { font-size: 0.63rem; color: #6b7280; }
.dm-exp-days { font-size: 0.68rem; font-weight: 600; color: #9ca3af; text-align: right; }
.dm-days-crit { color: #d97706 !important; font-weight: 700; }
.dm-days-mid { color: #6b7280; }

/* ULTRA-MINIMAL OVERRIDES - strip all color */
/* Trend & status badges -> restore original soft colors from early lines */
/* Remove sparklines & progress bars */
/* Remove sparklines & progress bars */
.dm-spark { display: none !important; }
.dm-c-bar { display: none !important; }
/* Sync dot */
.dm-sync { color: #c4c9d4 !important; }
/* HACCP badge in header */
.dm-haccp-badge { background: transparent !important; color: #c4c9d4 !important; border: 1px solid #e5e7eb !important; font-weight: 400; }
/* Log dots - override all inline `style="background:..."` */
.dm-tl-dot { background: #dde1e8 !important; }
/* Compliance ring - use HTML stroke color (green) */
/* .dm-ring-wrap svg circle - leave to HTML */
.dm-ring-val { color: #374151 !important; font-weight: 700; }
/* Compliance checks */
.dm-chk-ok { color: #4ade80 !important; }
.dm-chk-warn { color: #fb923c !important; }
/* Alert -> barely visible */
.dm-al-txt strong { color: #6b7280 !important; font-weight: 500; }
.dm-al-txt span { color: #c4c9d4 !important; }
/* Badge "9 disponibili" */
.dm-badge-green { background: transparent !important; color: #c4c9d4 !important; border: 1px solid #e5e7eb !important; font-weight: 400; }
/* Cards: slightly more padding, no colored bottom */
.dm-card { gap: 0.15rem; }

/* SEZIONE PROBLEMA: padding ridotto */
#problema { padding-top: 0; padding-bottom: 5rem; }

/* TOGGLE MOCKUP */
.mockup-toggle-wrap { display: flex; justify-content: center; margin-top: 1.5rem; margin-bottom: 1.5rem; }
.mt-bar { background: rgba(0,0,0,0.15); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); padding: 5px; border-radius: 6px; display: inline-flex; gap: 4px; box-shadow: inset 0 2px 5px rgba(0,0,0,0.2); }
.mt-btn { background: transparent; border: none; padding: .65rem 1.25rem; border-radius: 4px; font-size: .88rem; font-weight: 600; color: rgba(255,255,255,0.6); cursor: pointer; transition: all .2s; display: flex; align-items: center; gap: 8px; font-family: 'Inter', sans-serif; }
.mt-btn svg { opacity: 0.6; transition: all .2s; }
.mt-btn:hover { color: rgba(255,255,255,0.9); }
.mt-btn.active { background: #fff; color: var(--green-deep); box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.mt-btn.active svg { opacity: 1; }
/* MOCKUP IPHONE IMAGE */
.hm-iphone-img {
  width: auto;
  height: 568px; /* Fixed height matching desktop */
  max-width: 100%;
  object-fit: contain;
  transform-origin: top center;
  transition: width 0.3s cubic-bezier(0.25, 1, 0.5, 1), filter .4s cubic-bezier(0.2, 0.8, 0.2, 1);
  filter: drop-shadow(0 24px 60px rgba(0,0,0,0.4));
  z-index: 10;
  position: relative;
  display: block;
  cursor: zoom-in;
}
.hm-iphone-img:hover {
  transform: translateY(-4px) scale(var(--hm-scale, 1));
  filter: drop-shadow(0 32px 70px rgba(0,0,0,0.45));
}
.iphone-scroll-box {
  width: 100%;
  overflow: visible;
  display: flex;
  justify-content: center;
  transition: width 0.32s cubic-bezier(0.25, 1, 0.5, 1);
}
.iphone-scroll-box::-webkit-scrollbar { display: none; }
#mockupMobileView {
  height: auto !important;
  min-height: 0;
  width: 100%;
  --mobile-mockup-base-width: 180px;
  --mobile-mockup-zoom-width: 280px;
  --mobile-mockup-target-height: auto;
}
#mockupMobileView .iphone-scroll-box {
  width: var(--mobile-mockup-base-width);
  margin: 0 auto;
  overflow: visible;
}
#mockupMobileView .hm-iphone-img {
  width: 100% !important;
  height: auto;
  max-width: none;
  transform: none !important;
  margin: 0 auto;
}
#mockupMobileView .hm-iphone-img:hover {
  transform: none !important;
}
#mockupMobileView .iphone-scroll-box.is-zoomed {
  width: var(--mobile-mockup-zoom-width);
}

@media (min-width: 901px) {
  #mockupMobileView {
    height: 568px !important;
    min-height: 568px;
    align-items: flex-start;
  }

  #mockupMobileView .iphone-scroll-box,
  #mockupMobileView .iphone-scroll-box.is-zoomed {
    width: auto;
  }

  #mockupMobileView .hm-iphone-img,
  #mockupMobileView .hm-iphone-img.is-zoomed-ip {
    width: auto !important;
    height: 568px;
    cursor: default;
    pointer-events: none;
  }

  #mockupMobileView .ip-zoom-btn {
    display: none !important;
  }
}

/* IPHONE ZOOM BUTTON */
.ip-zoom-btn { display: none; }
@media (max-width: 900px) {
  #mockupMobileView {
    height: var(--mobile-mockup-target-height) !important;
    min-height: var(--mobile-mockup-target-height);
    align-items: flex-start;
  }

  .ip-zoom-btn {
    display: flex;
    position: absolute;
    top: 45%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 36px;
    height: 36px;
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    color: rgba(28,43,58,0.7);
    cursor: pointer;
    z-index: 100;
    transition: all 0.2s;
  }
  .ip-zoom-btn svg { width: 15px; height: 15px; stroke-width: 2.5px; opacity: 0.8; }
}

/* BENEFIT CARDS */
#benefit-cards {
  position: relative;
  z-index: 10;
  padding-bottom: 5rem;
}
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.benefit-card {
  background: linear-gradient(180deg, #ffffff 0%, #f7fcf8 100%);
  border: 1px solid rgba(22, 163, 74, 0.12);
  border-top: 1px solid rgba(22, 163, 74, 0.18);
  border-left: 1px solid rgba(22, 163, 74, 0.16);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 1.8rem 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
.benefit-card:hover {
  transform: translateY(-5px);
  background: linear-gradient(180deg, #ffffff 0%, #eef9f1 100%);
  border-color: rgba(22, 163, 74, 0.22);
}
.bc-ic {
  width: 48px;
  height: 48px;
  background: linear-gradient(180deg, #effaf3 0%, #dff3e6 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.2rem;
  color: var(--green-dark);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.75), 0 8px 18px rgba(22,163,74,0.12);
}
.bc-ic svg {
  width: 24px;
  height: 24px;
}
.bc-val {
  font-family: "Anton", sans-serif;
  font-size: 2.8rem;
  color: var(--green-dark);
  line-height: 1;
  letter-spacing: 0.02em;
  margin-bottom: 0.4rem;
}
.bc-lbl {
  font-size: 0.9rem;
  font-weight: 700;
  color: #587261;
  letter-spacing: 0.01em;
}

@media (max-width: 900px) {
  .hero-stats { display: none; }
  #benefit-cards { display: block; }
  .benefits-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .benefit-card { padding: 1.5rem 1.25rem; text-align: left; align-items: flex-start; }
  .bc-ic { margin-bottom: 1rem; width: 42px; height: 42px; }
  .bc-ic svg { width: 22px; height: 22px; }
  .bc-val { font-size: 2.2rem; }
  #benefit-cards { margin-top: 1rem; padding-top: .35rem; }
}
@media (max-width: 500px) {
  .bc-val { font-size: 2rem; }
  #benefit-cards { margin-top: 1.25rem; padding-top: .5rem; padding-bottom: 3.5rem; }
  .benefits-grid { grid-template-columns: repeat(2, 1fr); gap: .85rem; }
  .benefit-card { padding: 1.2rem 1rem; border-radius: 14px; }
  .bc-lbl { font-size: .84rem; }
}
@media (min-width: 901px) {
  .hero-stats { display: grid; }
  #benefit-cards { display: none; }
}
#mockupMobileView .hm-iphone-img.is-zoomed-ip {
  width: 100% !important;
  max-width: none;
  z-index: 50;
  filter: drop-shadow(0 40px 100px rgba(0,0,0,0.6)) !important;
  cursor: zoom-out;
  transform: none !important;
}

/* TICKER */
.ticker {
  background:var(--green-deep);
  min-height:var(--ticker-h);
  padding:0;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.ticker-t { display:flex; gap:2.5rem; align-items:center; white-space:nowrap; animation:tick 38s linear infinite; }
.titem { display:flex; align-items:center; gap:.5rem; font-size:.73rem; font-weight:600; letter-spacing:.09em; text-transform:uppercase; color:rgba(255,255,255,.5); flex-shrink:0; }
.tdot { width:4px; height:4px; background:var(--green-hi); border-radius:50%; }
@keyframes tick { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* PROBLEMA / SOLUZIONE */
#problema { 
  background: #EEF2F7;
  padding: 4rem 2rem 6.5rem 2rem; 
  position: relative; 
}
#problema::after {
  content: ""; position: absolute; bottom: 2.5rem; right: 2.5rem;
  width: 168px; height: 168px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%231a9e52' fill-opacity='0.08'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
#problema > .container { position:relative; z-index:2; }
#problema .eyebrow { color: var(--green); }
#problema .eyebrow::before { background: var(--green); }
#problema .stitle { color: var(--ink); }
#problema .stitle .hi { color: var(--green); }

.ps-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.55rem; margin-top:1.9rem; align-items:stretch; }
.ps-panel {
  padding:3rem 3rem 2.8rem;
  border-radius:30px;
  position:relative;
  overflow:hidden;
  min-height:100%;
  display:flex;
  flex-direction:column;
}
.ps-panel.bad {
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.92) 0%, rgba(255,255,255,.45) 30%, rgba(255,255,255,0) 62%),
    linear-gradient(180deg,#fff7f5 0%,#fdf0ee 100%);
  border:2px solid rgba(239,178,170,.9);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.78), 0 18px 44px rgba(124,48,37,.08);
}
.ps-panel.good {
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.9) 0%, rgba(255,255,255,.4) 32%, rgba(255,255,255,0) 64%),
    linear-gradient(180deg,#eef9f0 0%,#e4f4e7 100%);
  border:2px solid rgba(189,231,200,.95);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.76), 0 18px 44px rgba(20,96,52,.08);
}
.ps-panel::before {
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:radial-gradient(circle at 50% 0%, rgba(255,255,255,.28) 0%, rgba(255,255,255,0) 58%);
}
.ps-ptag {
  width:max-content;
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.11em;
  text-transform:uppercase;
  margin-bottom:2rem;
  display:flex;
  align-items:center;
  gap:.7rem;
}
.ps-panel.bad  .ps-ptag { color:#b03a2e; }
.ps-panel.good .ps-ptag { color:var(--green-dark); }
.ps-panel.bad  .ps-ptag::before { content:""; width:14px; height:14px; border-radius:50%; background:#cc4333; flex-shrink:0; }
.ps-panel.good .ps-ptag::before { content:""; width:14px; height:14px; border-radius:50%; background:var(--green); flex-shrink:0; }
.ps-ptitle { font-size:clamp(1.9rem, 2.4vw, 2.25rem); line-height:1.12; font-weight:800; margin-bottom:2.05rem; max-width:13ch; }
.ps-panel.bad  .ps-ptitle { color:#7b241c; }
.ps-panel.good .ps-ptitle { color:var(--green-deep); }
.ps-list { display:flex; flex-direction:column; gap:2rem; }
.ps-row {
  display:grid;
  grid-template-columns:48px minmax(0,1fr);
  align-items:flex-start;
  gap:1.15rem;
  padding:0;
}
.ps-bul {
  width:42px;
  height:42px;
  border-radius:50%;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top:.12rem;
}
.ps-panel.bad  .ps-bul { background:#ffe7e1; border:2px solid rgba(232,150,140,.9); }
.ps-panel.good .ps-bul { background:#d8f1df; border:2px solid rgba(180,224,191,.95); }
.ps-row > div:not(.ps-bul) { font-size:1rem; line-height:1.62; }
.ps-row strong { display:block; font-weight:800; margin:0 0 .32rem; font-size:clamp(1.15rem, 1.4vw, 1.35rem); line-height:1.22; }
.ps-row span { display:block; }
.ps-panel.bad  .ps-row strong { color:#7b241c; }
.ps-panel.good .ps-row strong { color:var(--green-deep); }
.ps-panel.bad  .ps-row > div:not(.ps-bul) { color:#a4655d; }
.ps-panel.good .ps-row > div:not(.ps-bul) { color:#3f8465; }
.ps-note {
  margin-top:1rem;
  padding-top:1rem;
  font-size:.86rem;
  font-weight:700;
  letter-spacing:.01em;
  border-top:1px solid rgba(0,0,0,.08);
}
.ps-panel.bad .ps-note { color:#8a3e33; border-top-color:rgba(192,57,43,.14); }
.ps-panel.good .ps-note { color:var(--green-deep); border-top-color:rgba(26,158,82,.14); }
.ps-mobile-compare { display:none; }

@media (min-width: 901px) {
  #problema {
    padding-top: 2.4rem;
    padding-bottom: 3.8rem;
  }

  #problema .eyebrow {
    margin-bottom: .3rem;
  }

  #problema .stitle {
    font-size: clamp(1.7rem, 2.5vw, 2.5rem);
  }

  .ps-grid {
    gap: 1.1rem;
    margin-top: 1.25rem;
  }

  .ps-panel {
    padding: 2.15rem 2.2rem 2rem;
    border-radius: 24px;
  }

  .ps-ptag {
    font-size: .7rem;
    margin-bottom: 1.3rem;
    gap: .55rem;
  }

  .ps-ptag::before {
    width: 12px;
    height: 12px;
  }

  .ps-ptitle {
    font-size: clamp(1.55rem, 1.8vw, 1.9rem);
    margin-bottom: 1.35rem;
    max-width: 14ch;
  }

  .ps-list {
    gap: 1.2rem;
  }

  .ps-row {
    grid-template-columns: 40px minmax(0,1fr);
    gap: .9rem;
  }

  .ps-bul {
    width: 34px;
    height: 34px;
    margin-top: .05rem;
  }

  .ps-row > div:not(.ps-bul) {
    font-size: .92rem;
    line-height: 1.52;
  }

  .ps-row strong {
    font-size: 1rem;
    margin-bottom: .22rem;
  }
}

/* OVERVIEW */
#overview { background:var(--bg); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:2rem 2rem 2rem 2rem; position:relative; }
#overview::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(ellipse 80% 70% at 50% 0%, rgba(26, 158, 82, 0.12) 0%, transparent 70%),
                    radial-gradient(circle at 10% 90%, rgba(26, 158, 82, 0.08) 0%, transparent 40%);
}
.overview-bridge-card {
  background: #ffffff;
  border-radius: 20px;
  padding: 3.5rem 2rem;
  box-shadow: 0 16px 48px rgba(0,0,0,0.06);
  border: 1px solid rgba(0,0,0,0.04);
  margin-top: -8rem;
  margin-bottom: 3.5rem;
  position: relative;
  z-index: 10;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.overview-watermark {
  position:absolute; opacity:0.06; pointer-events:none; z-index:0; user-select:none;
  filter:brightness(0); mix-blend-mode:multiply;
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%, black 20%, transparent 80%);
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%, black 20%, transparent 80%);
}
.wm-1 { top:-2%; left:-10%; width:clamp(200px, 35vw, 450px); transform:rotate(-15deg); }
.wm-2 { top:45%; right:-5%; width:clamp(220px, 38vw, 480px); transform:rotate(12deg); }
.wm-3 { bottom:0%; left:12%; width:clamp(200px, 35vw, 450px); transform:rotate(-8deg); }
#overview > .container { position:relative; z-index:1; }
.mx-auto { margin-left: auto; margin-right: auto; max-width: 680px; }

.ov-points { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3.5rem; text-align:left; }
.ov-point { display:flex; flex-direction:column; gap:1rem; padding:1.8rem 1.6rem; background:#ffffff; border:1px solid rgba(0,0,0,.08); border-radius:16px; box-shadow:0 6px 20px rgba(0,0,0,.04); transition:box-shadow .3s, transform .3s, border-color .3s; }
.ov-point:hover { box-shadow:0 12px 30px rgba(26,158,82,.08); transform:translateY(-4px); border-color:var(--green-soft); }
.ov-p-ico { width:48px; height:48px; flex-shrink:0; background:var(--green-lite); border-radius:12px; display:flex; align-items:center; justify-content:center; color:var(--green); transition:transform .3s, background .3s, color .3s; }
.ov-point:hover .ov-p-ico { transform:scale(1.05); background:var(--green); color:#fff; }
.ov-point strong { display:block; font-size:1.05rem; font-weight:700; color:var(--ink); margin-bottom:.4rem; }
.ov-point p { font-size:.92rem; color:var(--ink); line-height:1.6; margin:0; }

.container-large { max-width:1160px; margin-left:auto; margin-right:auto; margin-top:4.5rem; }
.ov-mockup-wrapper { position:relative; width:100%; display:flex; justify-content:center; }
.ov-mockup-browser { width:100%; max-width:1160px; position:relative; z-index:2; transition:transform .4s; }
.ov-mockup-browser:hover { transform:translateY(-4px); }
.ov-mockup-browser img { display:block; width:100%; height:auto; object-fit: cover; }

.float-badge { position:absolute; z-index:5; background:rgba(238,246,241,.85); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid rgba(26,158,82,.15); box-shadow:0 12px 30px rgba(0,0,0,.1); padding:.6rem .95rem; border-radius:100px; font-size:.75rem; font-weight:700; color:var(--ink); display:flex; align-items:center; gap:.5rem; animation: floatBadge 4s ease-in-out infinite alternate; }
.fb-2 { top:42%; left:2%; }
.fb-3 { top:4%; right:15%; }
.fb-4 { top:42%; right:2%; }
.fb-6 { bottom:30%; left:35%; }
.fb-7 { top:37%; left:45%; transform:translate(-50%, -50%); }
.fb-icon { background:var(--green); color:#fff; width:24px; height:24px; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; font-size:.85rem; flex-shrink:0; }

@keyframes floatBadge { 0% { transform:translateY(0); } 100% { transform:translateY(-15px); } }
@keyframes pulseG { 0% { box-shadow:0 0 0 0 rgba(26,158,82,.4); } 70% { box-shadow:0 0 0 6px rgba(26,158,82,0); } 100% { box-shadow:0 0 0 0 rgba(26,158,82,0); } }
.mock-header { background:var(--ink); padding:.7rem 1.1rem; display:flex; align-items:center; gap:.75rem; }
.mock-dots { display:flex; gap:5px; }
.mock-dots span { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.2); }
.mock-dots span:first-child { background:#ff5f57; }
.mock-dots span:nth-child(2) { background:#febc2e; }
.mock-dots span:nth-child(3) { background:#28c840; }
.mock-title { font-size:.73rem; color:rgba(255,255,255,.5); font-weight:500; }
.mock-body { padding:1.25rem; }
.mock-kpi-row { display:grid; grid-template-columns:repeat(3,1fr); gap:.7rem; margin-bottom:1.1rem; }
.mock-kpi { padding:.75rem .9rem; border-radius:9px; text-align:center; }
.mock-kpi.green  { background:var(--green-lite); border:1px solid var(--green-soft); }
.mock-kpi.orange { background:#fff7ed; border:1px solid #fed7aa; }
.mock-kpi.blue   { background:#eff6ff; border:1px solid #bfdbfe; }
.mkpi-v { font-family:"Anton",sans-serif; font-size:1.55rem; line-height:1; letter-spacing:.01em; }
.mock-kpi.green  .mkpi-v { color:var(--green-dark); }
.mock-kpi.orange .mkpi-v { color:#c2410c; }
.mock-kpi.blue   .mkpi-v { color:#1d4ed8; }
.mkpi-l { font-size:.63rem; color:var(--ink3); font-weight:500; margin-top:.2rem; line-height:1.3; }
.mock-section-label { font-size:.62rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink3); margin-bottom:.48rem; }
.mock-actions { display:grid; grid-template-columns:1fr 1fr; gap:.4rem; margin-bottom:1rem; }
.mock-action { background:var(--bg); border:1px solid var(--border); border-radius:7px; padding:.45rem .65rem; font-size:.7rem; font-weight:600; color:var(--ink2); }
.mock-feed { display:flex; flex-direction:column; gap:.35rem; }
.mock-feed-item { display:flex; align-items:center; gap:.55rem; background:var(--bg); border-radius:6px; padding:.35rem .62rem; }
.mf-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.mf-green  { background:var(--green); }
.mf-blue   { background:#3b82f6; }
.mf-orange { background:#f97316; }
.mf-text { font-size:.69rem; color:var(--ink2); flex:1; }
.mf-time { font-size:.63rem; color:var(--ink3); font-weight:600; }

/* FUNZIONALITA' */
#funzionalita { 
  background: #ffffff;
  background-image: none;
  padding: 5rem 2rem 6rem 2rem; 
  overflow: hidden; 
  position: relative; 
}
#funzionalita::before {
  content: ""; position: absolute; top: -8%; right: -4%;
  width: 520px; height: 520px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(22,163,74,0.07) 0%, transparent 70%);
  z-index: 0; pointer-events: none;
  display: none;
}
#funzionalita::after {
  content: "";
  position: absolute; bottom: 6rem; left: -3%;
  width: 400px; height: 400px;
  border-radius: 50%;
  border: 1.5px solid rgba(22,163,74,0.09);
  z-index: 0; pointer-events: none;
  display: none;
}
#funzionalita > .container { position:relative; z-index:1; }
#funzionalita .eyebrow { color: var(--green); }
#funzionalita .eyebrow::before { background: var(--green); }
#funzionalita .stitle { color: var(--ink); }
#funzionalita .stitle .hi { color: var(--green); }
#funzionalita .slead { color: var(--ink2); }
.feat-hdr { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:2.75rem; flex-wrap:wrap; gap:1.5rem; }
.bento { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }

/* --- COMPACT FEATURE TABS --- */
.feat-interactive { display: flex; flex-direction: column; gap: 1.5rem; }
@media(min-width: 900px) { .feat-interactive { flex-direction: row; align-items: stretch; gap: 2.2rem; } }
.feat-nav { display: flex; overflow-x: auto; gap: 0.6rem; padding-bottom: 0.5rem; scrollbar-width: none; }
.feat-nav::-webkit-scrollbar { display: none; }
@media(min-width: 900px) { .feat-nav { flex-direction: column; width: 330px; flex-shrink: 0; padding-bottom: 0; } }
.feat-nav-hint { display:none; }
.feat-btn { background: rgba(255,255,255,0.96); border: 1px solid rgba(28,43,58,0.1); border-radius: 4px; padding: 0.85rem 1rem; color: var(--ink); display: flex; align-items: center; gap: 0.9rem; cursor: pointer; transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1); text-align: left; white-space: nowrap; font-family: inherit; font-size: 0.9rem; font-weight: 600; box-shadow: 0 10px 24px rgba(19, 38, 32, 0.08); }
@media(min-width: 900px) { .feat-btn { white-space: normal; line-height: 1.3; padding: 1.1rem 1.25rem; font-size: 0.95rem; } }
.feat-btn:hover { background: rgba(255,255,255,0.96); color: var(--ink); border-color: rgba(28,43,58,0.1); transform: none; box-shadow: 0 10px 24px rgba(19, 38, 32, 0.08); }
.feat-btn.active { background: var(--green); border-color: var(--green-hi); color: #fff; box-shadow: 0 8px 24px rgba(26,158,82,0.3); }
@media(min-width: 900px) { .feat-btn.active { transform: translateX(8px); } }
.feat-btn-ic { width: 34px; height: 34px; background: rgba(26,158,82,0.1); color: var(--green-deep); border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background 0.3s, color 0.3s; }
.feat-btn.active .feat-btn-ic { background: rgba(255,255,255,0.25); color: #fff; }
.feat-btn-ic svg { width: 18px; height: 18px; stroke-width: 2.5; }
.feat-content-area { flex: 1; min-width: 0; display: flex; align-items: stretch; height: 540px; }
.feat-panel { display: none !important; width: 100%; min-height: 100%; animation: pFadeIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
.feat-panel.active { display: flex !important; }
@keyframes pFadeIn { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } }
.fc { background:rgba(255,255,255,0.85); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border:1px solid rgba(255,255,255,0.4); border-radius:var(--r-lg); padding:1.55rem; position:relative; overflow:hidden; transition:box-shadow .4s cubic-bezier(0.16, 1, 0.3, 1), border-color .4s ease, transform .4s cubic-bezier(0.16, 1, 0.3, 1); display:flex; flex-direction:column; box-shadow: 0 8px 32px rgba(0,0,0,0.08); z-index:1; }
.fc::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at top left, rgba(26,158,82,0.06), transparent 45%); opacity:0; transition:opacity .4s ease; z-index:0; pointer-events:none; }
.fc:hover { box-shadow:var(--sh-m); border-color:var(--green-soft); transform:translateY(-4px); }
.fc:hover::before { opacity:1; }
.fc::after { content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--green),var(--green-hi)); transform:scaleX(0); transform-origin:left; transition:transform .4s ease; border-radius:var(--r-lg) var(--r-lg) 0 0; z-index:1; }
.fc:hover::after { transform:scaleX(1); }
.fc-wide { grid-column:span 2; display:grid; grid-template-columns:56px 1fr; grid-template-rows:auto auto auto; gap:0 1.5rem; align-items:start; }
@media (max-width: 900px) { .fc-wide { grid-column:span 1; display:flex; flex-direction:column; } }
.fc-wide .fc-n { right:1.5rem; top:1.5rem; font-size:5rem; }
.fc-wide .fc-ico { grid-column:1; grid-row:1 / span 3; width:56px; height:56px; margin:0; }
.fc-wide .fc-title { grid-column:2; grid-row:1; margin-bottom:0.3rem; margin-top:0.3rem; }
.fc-wide .fc-desc { grid-column:2; grid-row:2; }
.fc-wide .fc-chips { grid-column:2; grid-row:3; margin-top:1.1rem; }
@media (max-width: 900px) { .fc-wide .fc-ico { width:48px; height:48px; margin-bottom:1.2rem; } .fc-wide .fc-title, .fc-wide .fc-desc, .fc-wide .fc-chips { margin:0; } .fc-wide .fc-title { margin-bottom:0.5rem; } .fc-wide .fc-chips { margin-top:1.4rem; } }
@media (max-width: 900px) { .fc-wide { grid-column:span 1; } }
.fc-n { position:absolute; top:20px; right:20px; font-size:4rem; font-family:"Anton",sans-serif; letter-spacing:0.02em; color:rgba(26,158,82,0.06); margin:0; line-height:1; user-select:none; z-index:0; transition:color 0.4s ease; transform:translate(0, 0); }
.fc:hover .fc-n { color:rgba(26,158,82,0.11); transform:translate(2px, -2px); }
.fc-ico { position:relative; z-index:1; width:46px; height:46px; background:var(--green-lite); color:var(--green); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:0.95rem; transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1), background 0.3s, color 0.3s; }
.fc:hover .fc-ico { transform:scale(1.1) translateY(-2px); background:var(--green); color:#fff; box-shadow:0 8px 20px rgba(26,158,82,0.25); }
.fc-title { position:relative; z-index:1; font-size:1.05rem; font-weight:800; color:var(--ink); margin-bottom:.4rem; transition:color 0.3s ease; }
.fc-desc  { position:relative; z-index:1; font-size:.85rem; color:var(--ink2); line-height:1.55; flex:0 0 auto; }
.fc-chips { position:relative; z-index:1; display:flex; flex-wrap:wrap; gap:.4rem; margin-top:auto; padding-top:0.95rem; }
.chip { background:var(--green-lite); border:1px solid var(--green-soft); color:var(--green-dark); font-size:.68rem; font-weight:600; padding:.26rem .72rem; border-radius:100px; letter-spacing:.02em; transition:border-color .2s, color .2s, background .2s; }
.chip:hover { background:var(--green); border-color:var(--green); color:#fff; }

.fc-hero { background:var(--green-deep); border-color:rgba(255,255,255,0.12); box-shadow:0 12px 40px rgba(13,82,41,0.25); }
.fc-hero::before { background:radial-gradient(circle at bottom right, rgba(255,255,255,0.12), transparent 60%); }
.fc-hero:hover { border-color:rgba(255,255,255,0.25); }
.fc-hero .fc-n { color:rgba(255,255,255,0.06); }
.fc-hero:hover .fc-n { color:rgba(255,255,255,0.1); }
.fc-hero .fc-title { color:#ffffff; }
.fc-hero .fc-desc { color:rgba(255,255,255,0.7); }
.fc-hero .fc-ico { background:rgba(255,255,255,0.1); color:var(--green-hi); }
.fc-hero:hover .fc-ico { background:#ffffff; color:var(--green-deep); box-shadow:0 8px 24px rgba(255,255,255,0.2); }
.fc-hero .chip { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.2); color:#ffffff; }
.fc-hero .chip:hover { background:var(--green-hi); border-color:var(--green-hi); color:var(--green-deep); }
.fc-hero::after { background:linear-gradient(90deg,var(--green-hi),#ffffff); }
.fc-dashboard-embed { position:relative; z-index:1; margin-top:0.9rem; padding:0.8rem; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.07) 100%); border:1px solid rgba(255,255,255,0.16); box-shadow:inset 0 1px 0 rgba(255,255,255,0.08); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.fc-dash-head { display:flex; align-items:center; justify-content:space-between; gap:0.75rem; margin-bottom:0.65rem; }
.fc-dash-kicker { display:inline-flex; align-items:center; gap:0.45rem; font-size:0.68rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#ffffff; }
.fc-dash-kicker::before { content:""; width:8px; height:8px; border-radius:50%; background:#7ef0aa; box-shadow:0 0 0 4px rgba(126,240,170,0.14); }
.fc-dash-sync { font-size:0.64rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:rgba(255,255,255,0.74); padding:0.25rem 0.55rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.fc-dash-kpis { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:0.55rem; }
.fc-dash-kpi { display:flex; flex-direction:column; gap:0.22rem; padding:0.7rem; border-radius:14px; background:rgba(8,31,18,0.28); border:1px solid rgba(255,255,255,0.08); }
.fc-dash-kpi-label { font-size:0.66rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:rgba(255,255,255,0.56); }
.fc-dash-kpi strong { font-family:"Anton",sans-serif; font-size:1.55rem; line-height:0.95; letter-spacing:0.02em; color:#ffffff; font-weight:400; }
.fc-dash-kpi-trend { display:inline-flex; width:max-content; align-items:center; padding:0.2rem 0.5rem; border-radius:999px; font-size:0.62rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; }
.fc-dash-kpi-trend.is-up { color:var(--green-deep); background:#7ef0aa; }
.fc-dash-kpi-trend.is-warn { color:#8a4b00; background:#ffd166; }
.fc-dash-feed { display:flex; flex-direction:column; gap:0.35rem; margin-top:0.7rem; }
.fc-dash-row { display:grid; grid-template-columns:auto minmax(0, 1fr) auto; gap:0.5rem; align-items:center; padding:0.52rem 0.62rem; border-radius:12px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.08); }
.fc-dash-row span:nth-child(2) { font-size:0.69rem; font-weight:600; color:rgba(255,255,255,0.88); min-width:0; }
.fc-dash-dot { width:9px; height:9px; border-radius:50%; display:block; }
.fc-dash-dot.is-green { background:#7ef0aa; box-shadow:0 0 0 4px rgba(126,240,170,0.14); }
.fc-dash-dot.is-blue { background:#7dc4ff; box-shadow:0 0 0 4px rgba(125,196,255,0.14); }
.fc-dash-dot.is-amber { background:#ffd166; box-shadow:0 0 0 4px rgba(255,209,102,0.14); }
.fc-dash-time { font-size:0.63rem; font-weight:800; letter-spacing:0.08em; color:rgba(255,255,255,0.62); text-transform:uppercase; }
.fc-stock-embed { position:relative; z-index:1; margin-top:0.9rem; padding:0.8rem; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.07) 100%); border:1px solid rgba(255,255,255,0.16); box-shadow:inset 0 1px 0 rgba(255,255,255,0.08); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.fc-stock-head { display:flex; align-items:center; justify-content:space-between; gap:0.75rem; margin-bottom:0.65rem; }
.fc-stock-kicker { display:inline-flex; align-items:center; gap:0.45rem; font-size:0.68rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#ffffff; }
.fc-stock-kicker::before { content:""; width:8px; height:8px; border-radius:50%; background:#7ef0aa; box-shadow:0 0 0 4px rgba(126,240,170,0.14); }
.fc-stock-status { font-size:0.64rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:rgba(255,255,255,0.74); padding:0.25rem 0.55rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.fc-stock-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:0.55rem; }
.fc-stock-card { display:flex; flex-direction:column; gap:0.22rem; padding:0.7rem; border-radius:14px; background:rgba(8,31,18,0.28); border:1px solid rgba(255,255,255,0.08); }
.fc-stock-label { font-size:0.66rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:rgba(255,255,255,0.56); }
.fc-stock-card strong { font-family:"Anton",sans-serif; font-size:1.55rem; line-height:0.95; letter-spacing:0.02em; color:#ffffff; font-weight:400; }
.fc-stock-note { display:inline-flex; width:max-content; align-items:center; padding:0.2rem 0.5rem; border-radius:999px; font-size:0.62rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; color:var(--green-deep); background:#7ef0aa; }
.fc-stock-note.is-warn { color:#8a4b00; background:#ffd166; }
.fc-stock-list { display:flex; flex-direction:column; gap:0.35rem; margin-top:0.7rem; }
.fc-stock-row { display:grid; grid-template-columns:auto minmax(0, 1fr) auto; gap:0.5rem; align-items:center; padding:0.52rem 0.62rem; border-radius:12px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.08); }
.fc-stock-row span:nth-child(2) { font-size:0.69rem; font-weight:600; color:rgba(255,255,255,0.88); min-width:0; }
.fc-stock-pill { display:inline-flex; align-items:center; justify-content:center; min-width:38px; padding:0.2rem 0.38rem; border-radius:999px; font-size:0.58rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:var(--green-deep); background:#7ef0aa; }
.fc-stock-pill.is-blue { color:#0b3e6f; background:#7dc4ff; }
.fc-stock-pill.is-amber { color:#8a4b00; background:#ffd166; }
.fc-stock-qty { font-size:0.63rem; font-weight:800; letter-spacing:0.08em; color:rgba(255,255,255,0.62); text-transform:uppercase; }
.fc-prod-embed { position:relative; z-index:1; margin-top:0.9rem; padding:0.8rem; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.07) 100%); border:1px solid rgba(255,255,255,0.16); box-shadow:inset 0 1px 0 rgba(255,255,255,0.08); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.fc-prod-head { display:flex; align-items:center; justify-content:space-between; gap:0.75rem; margin-bottom:0.65rem; }
.fc-prod-kicker { display:inline-flex; align-items:center; gap:0.45rem; font-size:0.68rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#ffffff; }
.fc-prod-kicker::before { content:""; width:8px; height:8px; border-radius:50%; background:#7ef0aa; box-shadow:0 0 0 4px rgba(126,240,170,0.14); }
.fc-prod-status { font-size:0.64rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:rgba(255,255,255,0.74); padding:0.25rem 0.55rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.fc-prod-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:0.55rem; }
.fc-prod-card { display:flex; flex-direction:column; gap:0.22rem; padding:0.7rem; border-radius:14px; background:rgba(8,31,18,0.28); border:1px solid rgba(255,255,255,0.08); }
.fc-prod-label { font-size:0.66rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:rgba(255,255,255,0.56); }
.fc-prod-card strong { font-family:"Anton",sans-serif; font-size:1.55rem; line-height:0.95; letter-spacing:0.02em; color:#ffffff; font-weight:400; }
.fc-prod-note { display:inline-flex; width:max-content; align-items:center; padding:0.2rem 0.5rem; border-radius:999px; font-size:0.62rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; color:var(--green-deep); background:#7ef0aa; }
.fc-prod-note.is-blue { color:#0b3e6f; background:#7dc4ff; }
.fc-prod-steps { display:flex; flex-direction:column; gap:0.35rem; margin-top:0.7rem; }
.fc-prod-row { display:grid; grid-template-columns:auto minmax(0, 1fr) auto; gap:0.5rem; align-items:center; padding:0.52rem 0.62rem; border-radius:12px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.08); }
.fc-prod-row span:nth-child(2) { font-size:0.69rem; font-weight:600; color:rgba(255,255,255,0.88); min-width:0; }
.fc-prod-pill { display:inline-flex; align-items:center; justify-content:center; min-width:38px; padding:0.2rem 0.38rem; border-radius:999px; font-size:0.58rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:var(--green-deep); background:#7ef0aa; }
.fc-prod-pill.is-blue { color:#0b3e6f; background:#7dc4ff; }
.fc-prod-pill.is-amber { color:#8a4b00; background:#ffd166; }
.fc-prod-tag { font-size:0.63rem; font-weight:800; letter-spacing:0.08em; color:rgba(255,255,255,0.62); text-transform:uppercase; }
.fc-prod-tag.is-live { color:#7ef0aa; }
.fc-order-embed { position:relative; z-index:1; margin-top:0.9rem; padding:0.8rem; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.07) 100%); border:1px solid rgba(255,255,255,0.16); box-shadow:inset 0 1px 0 rgba(255,255,255,0.08); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.fc-order-head { display:flex; align-items:center; justify-content:space-between; gap:0.75rem; margin-bottom:0.65rem; }
.fc-order-kicker { display:inline-flex; align-items:center; gap:0.45rem; font-size:0.68rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#ffffff; }
.fc-order-kicker::before { content:""; width:8px; height:8px; border-radius:50%; background:#7ef0aa; box-shadow:0 0 0 4px rgba(126,240,170,0.14); }
.fc-order-status { font-size:0.64rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:rgba(255,255,255,0.74); padding:0.25rem 0.55rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.fc-order-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:0.55rem; }
.fc-order-card { display:flex; flex-direction:column; gap:0.22rem; padding:0.7rem; border-radius:14px; background:rgba(8,31,18,0.28); border:1px solid rgba(255,255,255,0.08); }
.fc-order-label { font-size:0.66rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:rgba(255,255,255,0.56); }
.fc-order-card strong { font-family:"Anton",sans-serif; font-size:1.55rem; line-height:0.95; letter-spacing:0.02em; color:#ffffff; font-weight:400; }
.fc-order-note { display:inline-flex; width:max-content; align-items:center; padding:0.2rem 0.5rem; border-radius:999px; font-size:0.62rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; color:var(--green-deep); background:#7ef0aa; }
.fc-order-note.is-blue { color:#0b3e6f; background:#7dc4ff; }
.fc-order-list { display:flex; flex-direction:column; gap:0.35rem; margin-top:0.7rem; }
.fc-order-row { display:grid; grid-template-columns:auto minmax(0, 1fr) auto; gap:0.5rem; align-items:center; padding:0.52rem 0.62rem; border-radius:12px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.08); }
.fc-order-row span:nth-child(2) { font-size:0.69rem; font-weight:600; color:rgba(255,255,255,0.88); min-width:0; }
.fc-order-pill { display:inline-flex; align-items:center; justify-content:center; min-width:38px; padding:0.2rem 0.38rem; border-radius:999px; font-size:0.58rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:var(--green-deep); background:#7ef0aa; }
.fc-order-pill.is-blue { color:#0b3e6f; background:#7dc4ff; }
.fc-order-pill.is-amber { color:#8a4b00; background:#ffd166; }
.fc-order-tag { font-size:0.63rem; font-weight:800; letter-spacing:0.08em; color:rgba(255,255,255,0.62); text-transform:uppercase; }
.fc-haccp-embed { position:relative; z-index:1; margin-top:0.9rem; }
.fc-haccp-embed .haccp-mock { border-radius:14px; border:1px solid rgba(255,255,255,0.16); box-shadow:none; overflow:hidden; }
.fc-haccp-embed .hm-header { padding:0.75rem 0.9rem; gap:0.65rem; }
.fc-haccp-embed .hm-icon { font-size:1.1rem; }
.fc-haccp-embed .hm-title { font-size:0.74rem; }
.fc-haccp-embed .hm-sub { font-size:0.6rem; }
.fc-haccp-embed .hm-progress { padding:0.7rem 0.9rem; }
.fc-haccp-embed .hm-prog-label { font-size:0.62rem; margin-bottom:0.35rem; }
.fc-haccp-embed .hm-prog-bar { height:6px; }
.fc-haccp-embed .hm-checks { padding:0.7rem 0.9rem; gap:0.32rem; }
.fc-haccp-embed .hm-check { padding:0.42rem 0.52rem; gap:0.5rem; }
.fc-haccp-embed .hmc-ico { width:18px; height:18px; font-size:0.62rem; }
.fc-haccp-embed .hm-check span:last-child { font-size:0.67rem; }
.fc-haccp-embed .hm-footer { padding:0.65rem 0.9rem; }
.fc-haccp-embed .hm-footer-tag { font-size:0.63rem; }
.fc-haccp-embed .hm-footer-status { font-size:0.58rem; padding:0.16rem 0.48rem; }
.fc-label-embed { position:relative; z-index:1; margin-top:0.9rem; }
.fc-label-embed .etich-mock { border-radius:14px; border:1px solid rgba(255,255,255,0.16); box-shadow:none; overflow:hidden; background:#ffffff; }
.fc-label-embed .em-header { padding:0.62rem 0.82rem; }
.fc-label-embed .em-title { font-size:0.69rem; }
.fc-label-embed .em-sub { font-size:0.57rem; }
.fc-label-embed .em-badge { font-size:0.55rem; padding:0.18rem 0.48rem; }
.fc-label-embed .em-preview { padding:0.72rem; }
.fc-label-embed .em-label { padding:0.72rem 0.78rem; }
.fc-label-embed .em-prod { font-size:0.78rem; margin-bottom:0.26rem; }
.fc-label-embed .em-info { font-size:0.58rem; line-height:1.45; }
.fc-label-embed .em-ingr { font-size:0.6rem; margin-top:0.3rem; }
.fc-label-embed .em-row-ft { margin-top:0.35rem; padding-top:0.35rem; }
.fc-label-embed .em-allerg span { font-size:0.55rem; }
.fc-label-embed .em-lot { font-size:0.56rem; }
.fc-label-embed .em-barcode { margin-top:0.38rem; }
.fc-label-embed .barcode { height:16px; }
.fc-label-embed .em-chips { padding:0.62rem 0.72rem; gap:0.32rem; }
.fc-label-embed .em-chip { font-size:0.54rem; padding:0.18rem 0.42rem; }
.fc-report-embed { position:relative; z-index:1; margin-top:0.9rem; padding:0.8rem; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.07) 100%); border:1px solid rgba(255,255,255,0.16); box-shadow:inset 0 1px 0 rgba(255,255,255,0.08); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.fc-report-topline { display:flex; align-items:center; justify-content:space-between; gap:0.75rem; margin-bottom:0.65rem; }
.fc-report-kicker { display:inline-flex; align-items:center; gap:0.45rem; font-size:0.68rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#ffffff; }
.fc-report-kicker::before { content:""; width:8px; height:8px; border-radius:50%; background:var(--green-hi); box-shadow:0 0 0 4px rgba(79,203,122,0.18); }
.fc-report-export { font-size:0.64rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:rgba(255,255,255,0.74); padding:0.25rem 0.55rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.fc-report-widget { display:grid; grid-template-columns:minmax(0, 1.4fr) minmax(112px, 0.9fr); gap:0.7rem; align-items:stretch; }
.fc-report-chart { padding:0.72rem 0.72rem 0.55rem; border-radius:14px; background:rgba(8, 31, 18, 0.28); border:1px solid rgba(255,255,255,0.08); }
.fc-report-bars { height:68px; display:grid; grid-template-columns:repeat(7, 1fr); gap:0.4rem; align-items:end; }
.fc-report-bars span { display:block; width:100%; border-radius:999px 999px 4px 4px; background:linear-gradient(180deg, #7ef0aa 0%, #30c56e 100%); box-shadow:0 8px 16px rgba(48,197,110,0.22); min-height:16px; }
.fc-report-bars span:nth-child(3n) { background:linear-gradient(180deg, #ffffff 0%, #d7f7e3 100%); }
.fc-report-axis { display:grid; grid-template-columns:repeat(7, 1fr); gap:0.4rem; margin-top:0.45rem; font-size:0.56rem; font-weight:700; color:rgba(255,255,255,0.46); text-align:center; }
.fc-report-side { display:flex; flex-direction:column; justify-content:center; padding:0.75rem; border-radius:14px; background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.06) 100%); border:1px solid rgba(255,255,255,0.12); }
.fc-report-score { font-family:"Anton",sans-serif; font-size:1.8rem; line-height:0.95; letter-spacing:0.02em; color:#ffffff; }
.fc-report-score-label { margin-top:0.25rem; font-size:0.66rem; line-height:1.4; color:rgba(255,255,255,0.72); }
.fc-report-score-chip { margin-top:0.55rem; display:inline-flex; width:max-content; align-items:center; padding:0.22rem 0.52rem; border-radius:999px; font-size:0.58rem; font-weight:800; letter-spacing:0.07em; text-transform:uppercase; color:var(--green-deep); background:var(--green-hi); }
.fc-report-list { display:flex; flex-direction:column; gap:0.35rem; margin-top:0.7rem; }
.fc-report-row { display:grid; grid-template-columns:auto minmax(0, 1fr) auto; gap:0.5rem; align-items:center; padding:0.52rem 0.62rem; border-radius:12px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.08); color:#ffffff; }
.fc-report-row span:nth-child(2) { font-size:0.69rem; font-weight:600; color:rgba(255,255,255,0.88); min-width:0; }
.fc-report-dot { width:9px; height:9px; border-radius:50%; display:block; }
.fc-report-dot.is-ok { background:#7ef0aa; box-shadow:0 0 0 4px rgba(126,240,170,0.14); }
.fc-report-dot.is-warn { background:#ffd166; box-shadow:0 0 0 4px rgba(255,209,102,0.14); }
.fc-report-file { font-size:0.6rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:rgba(255,255,255,0.74); padding:0.2rem 0.42rem; border-radius:999px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.1); }
.feat-cta-row { margin-top:2.5rem; display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:1.5rem; }
.cta-link-text { color:var(--green); font-weight:700; text-decoration:none; transition:opacity .2s; }
.cta-link-text:hover { opacity:0.8; text-decoration:underline; }

/* FUNZIONALITA: tema chiaro coerente */
.fc-hero {
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, #f4fbf7 100%);
  border-color: rgba(26,158,82,.14);
  box-shadow: 0 18px 42px rgba(20,50,40,.10);
}
.fc-hero::before { background:radial-gradient(circle at top left, rgba(26,158,82,0.10), transparent 48%); opacity:1; }
.fc-hero:hover { border-color: rgba(26,158,82,.22); }
.fc-hero .fc-n { color:rgba(26,158,82,0.08); }
.fc-hero:hover .fc-n { color:rgba(26,158,82,0.14); }
.fc-hero .fc-title { color:var(--ink); }
.fc-hero .fc-desc { color:var(--ink2); }
.fc-hero .fc-ico { background:var(--green-lite); color:var(--green); }
.fc-hero:hover .fc-ico { background:var(--green); color:#fff; box-shadow:0 8px 22px rgba(26,158,82,0.22); }
.fc-hero .chip { background:#eef8f2; border-color:var(--green-soft); color:var(--green-dark); }
.fc-hero .chip:hover { background:var(--green); border-color:var(--green); color:#fff; }
.fc-hero::after { background:linear-gradient(90deg,var(--green),var(--green-hi)); }

.fc-dashboard-embed,
.fc-stock-embed,
.fc-prod-embed,
.fc-order-embed,
.fc-report-embed {
  background: linear-gradient(180deg, #fbfefd 0%, #eff8f3 100%);
  border: 1px solid rgba(26,158,82,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.fc-dash-kicker,
.fc-stock-kicker,
.fc-prod-kicker,
.fc-order-kicker,
.fc-report-kicker {
  color: var(--green-deep);
}

.fc-dash-kicker::before,
.fc-stock-kicker::before,
.fc-prod-kicker::before,
.fc-order-kicker::before,
.fc-report-kicker::before {
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(26,158,82,.12);
}

.fc-dash-sync,
.fc-stock-status,
.fc-prod-status,
.fc-order-status,
.fc-report-export {
  color: var(--ink2);
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(26,158,82,.12);
}

.fc-dash-kpi,
.fc-stock-card,
.fc-prod-card,
.fc-order-card,
.fc-report-chart,
.fc-report-side {
  background: #ffffff;
  border: 1px solid rgba(28,43,58,.08);
  box-shadow: 0 8px 18px rgba(20,50,40,.04);
}

.fc-dash-kpi-label,
.fc-stock-label,
.fc-prod-label,
.fc-order-label,
.fc-report-axis,
.fc-report-score-label {
  color: var(--ink3);
}

.fc-dash-kpi strong,
.fc-stock-card strong,
.fc-prod-card strong,
.fc-order-card strong,
.fc-report-score {
  color: var(--ink);
}

.fc-dash-row,
.fc-stock-row,
.fc-prod-row,
.fc-order-row,
.fc-report-row {
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(28,43,58,.08);
  color: var(--ink);
}

.fc-dash-row span:nth-child(2),
.fc-stock-row span:nth-child(2),
.fc-prod-row span:nth-child(2),
.fc-order-row span:nth-child(2),
.fc-report-row span:nth-child(2) {
  color: var(--ink2);
}

.fc-dash-time,
.fc-stock-qty,
.fc-prod-tag,
.fc-order-tag,
.fc-report-file {
  color: var(--ink3);
}

.fc-report-file {
  background: rgba(255,255,255,.88);
  border-color: rgba(28,43,58,.08);
}

.fc-report-bars span:nth-child(3n) {
  background: linear-gradient(180deg, #dff4e7 0%, #bce8cb 100%);
}

.fc-haccp-embed .haccp-mock,
.fc-label-embed .etich-mock {
  border-color: rgba(28,43,58,.08);
  box-shadow: 0 10px 24px rgba(20,50,40,.06);
}

/* KILLER FEATURES */
#haccp-kf { 
  background: #fff; 
  padding: 6rem 2rem; 
  position: relative; 
  overflow: hidden; 
  border-bottom: 1px solid var(--border);
}
#haccp-kf::after {
  content: ""; position: absolute; top:0; left:0; right:0; height:460px;
  background: var(--green-deep);
  z-index: 0; pointer-events: none;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 80%); 
}
#haccp-kf > .container { position:relative; z-index:2; }

#etichette { 
  background: #fff; 
  padding: 6rem 2rem; 
  position: relative; 
  overflow: hidden; 
  border-bottom: 1px solid var(--border);
}
#etichette::after {
  content: ""; position: absolute; top:0; left:0; right:0; height:400px;
  background: var(--ink);
  z-index: 0; pointer-events: none;
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0 100%);
}
#etichette > .container { position:relative; z-index:2; }

.kf-wrap { position:relative; border-radius:20px; padding:3rem; overflow:hidden; }
.kf-haccp { 
  background: #fff; 
  border: 1px solid var(--green-soft); 
  box-shadow: 0 15px 50px rgba(13, 82, 41, 0.15); 
}
.kf-etich { 
  background: #fff; 
  border: 1px solid var(--border); 
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.08); 
}
.kf-badge { display:inline-flex; align-items:center; background:var(--green); color:#fff; font-size:.68rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; padding:.3rem .9rem; border-radius:100px; margin-bottom:1.75rem; }
.kf-badge-alt { background: var(--green-hi); }
.kf-mobile-header { display: none; }
.kf-desktop-header { display: block; }
.kf-grid { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.kf-grid-rev { direction:rtl; }
.kf-grid-rev > * { direction:ltr; }
.kf-title { font-family:"Anton",sans-serif; font-size:clamp(1.7rem,3vw,2.7rem); line-height:1.05; letter-spacing:.02em; text-transform:uppercase; color:var(--ink); margin-bottom:1rem; }
.kf-lead { font-size:.95rem; color:var(--ink2); line-height:1.78; margin-bottom:1.5rem; }
.kf-points { display:flex; flex-direction:column; gap:1rem; }
.kf-point { display:flex; gap:.9rem; align-items:flex-start; padding:.9rem 1rem; background:rgba(255,255,255,.7); border:1px solid var(--border); border-radius:var(--r); }
.kfp-ico { font-size:1.1rem; width:38px; height:38px; flex-shrink:0; background:var(--green-lite); border-radius:9px; display:flex; align-items:center; justify-content:center; }
.kf-point strong { display:block; font-size:.86rem; font-weight:700; color:var(--ink); margin-bottom:.2rem; }
.kf-point p { font-size:.8rem; color:var(--ink2); line-height:1.65; }

/* HACCP Mock */
.haccp-mock { background:#fff; border-radius:16px; border:1px solid var(--border); box-shadow:var(--sh-l); overflow:hidden; }
.hm-header { background:var(--green); padding:1.1rem 1.4rem; display:flex; align-items:center; gap:.85rem; }
.hm-icon { font-size:1.5rem; }
.hm-title { font-size:.88rem; font-weight:700; color:#fff; }
.hm-sub { font-size:.72rem; color:rgba(255,255,255,.7); margin-top:.08rem; }
.hm-progress { padding:1.1rem 1.4rem; border-bottom:1px solid var(--border); }
.hm-prog-label { display:flex; justify-content:space-between; font-size:.73rem; font-weight:600; color:var(--ink2); margin-bottom:.5rem; }
.hm-prog-pct { color:var(--green); font-weight:800; }
.hm-prog-bar { background:var(--bg); border-radius:100px; height:8px; overflow:hidden; }
.hm-prog-fill { background:linear-gradient(90deg,var(--green),var(--green-hi)); height:100%; border-radius:100px; }
.hm-checks { padding:1rem 1.4rem; display:flex; flex-direction:column; gap:.45rem; }
.hm-check { display:flex; align-items:center; gap:.65rem; padding:.55rem .75rem; border-radius:8px; }
.hm-check.done { background:var(--green-lite); }
.hm-check.pending { background:#fffbeb; border:1px dashed #fbbf24; }
.hmc-ico { width:22px; height:22px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:800; }
.hm-check.done .hmc-ico { background:var(--green); color:#fff; }
.hm-check.pending .hmc-ico { background:#fef3c7; color:#d97706; border:1.5px solid #fbbf24; }
.hm-check span:last-child { font-size:.82rem; font-weight:500; }
.hm-check.done span:last-child { color:var(--green-deep); }
.hm-check.pending span:last-child { color:#92400e; }
.hm-footer { padding:.9rem 1.4rem; background:var(--bg); border-top:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.hm-footer-tag { font-size:.75rem; color:var(--ink3); font-weight:500; }
.hm-footer-status { font-size:.7rem; font-weight:700; color:#d97706; background:#fffbeb; border:1px solid #fde68a; padding:.2rem .6rem; border-radius:100px; }

/* Etichette mock */
.etich-mock { background:#fff; border-radius:16px; border:1px solid var(--border); box-shadow:var(--sh-l); overflow:hidden; }
.em-header { background:var(--ink); padding:.85rem 1.2rem; display:flex; align-items:center; justify-content:space-between; }
.em-hd-left {}
.em-title { font-size:.78rem; font-weight:600; color:rgba(255,255,255,.7); }
.em-sub { font-size:.65rem; color:rgba(255,255,255,.4); margin-top:.1rem; }
.em-badge { font-size:.62rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; background:var(--green); color:#fff; padding:.22rem .65rem; border-radius:100px; white-space:nowrap; }
.em-preview { padding:1.2rem; border-bottom:1px solid var(--border); }
.em-label { background:#f8f8f8; border:1px solid #ddd; border-radius:8px; padding:1rem 1.1rem; }
.em-prod { font-size:.97rem; font-weight:800; color:var(--ink); margin-bottom:.4rem; }
.em-info { font-size:.7rem; color:var(--ink3); line-height:1.55; }
.em-ingr { font-size:.72rem; color:var(--ink2); margin-top:.4rem; }
.em-row-ft { display:flex; justify-content:space-between; align-items:center; margin-top:.5rem; padding-top:.5rem; border-top:1px solid #e0e0e0; flex-wrap:wrap; gap:.3rem; }
.em-allerg span { font-size:.65rem; font-weight:700; background:#fef3c7; color:#92400e; padding:.1rem .4rem; border-radius:4px; text-transform:uppercase; }
.em-lot { font-size:.65rem; color:var(--ink3); font-weight:600; }
.em-barcode { margin-top:.55rem; }
.barcode { display:flex; align-items:flex-end; gap:1px; height:22px; }
.barcode span { display:block; background:var(--ink); width:2px; height:100%; }
.barcode span:nth-child(3n+1) { width:1px; height:75%; }
.barcode span:nth-child(5n+2) { width:3px; }
.em-chips { padding:.85rem 1.2rem; display:flex; flex-wrap:wrap; gap:.4rem; }
.em-chip { font-size:.65rem; font-weight:700; letter-spacing:.04em; background:var(--green-lite); color:var(--green-dark); border:1px solid var(--green-soft); padding:.22rem .65rem; border-radius:100px; }

/* PIATTAFORMA */
#piattaforma { 
  background: var(--ink);
  background-image:
    radial-gradient(ellipse 70% 60% at 50% -10%, rgba(26,158,82,.15) 0%, transparent 80%),
    radial-gradient(circle at 95% 90%, rgba(26,158,82,0.06) 0%, transparent 40%);
  padding: 6rem 2rem; 
  position: relative;
  overflow: hidden;
}
#piattaforma::before {
  content: ""; position: absolute; bottom: 2.5rem; left: 2.5rem;
  width: 144px; height: 144px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.08'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
#piattaforma::after {
  content: ""; position: absolute; top: -60px; right: -60px;
  width: 320px; height: 320px;
  border-radius: 50%;
  border: 1.5px solid rgba(26,158,82,0.1);
  box-shadow: inset 0 0 0 60px rgba(26,158,82,0.03);
  z-index: 0; pointer-events: none;
}
#piattaforma > .container { position:relative; z-index:2; }
#piattaforma .eyebrow { color:rgba(255,255,255,.5); }
#piattaforma .eyebrow::before { background:rgba(255,255,255,.3); }
#piattaforma .stitle { color:#fff; }
#piattaforma .slead { color:rgba(255,255,255,.6); }
.plat-main-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; margin-top:3.5rem; max-width:960px; margin-left:auto; margin-right:auto; }
.plat-main-card { display:flex; flex-direction:column; gap:1.5rem; padding:2.5rem; border-radius:var(--r-xl); background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); box-shadow:0 8px 32px rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.1); transition:all .4s ease; align-items:flex-start; }
.plat-main-card:hover { background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.2); box-shadow:0 14px 40px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.2); transform:translateY(-6px); }
.pmc-ico { font-size:2.4rem; width:64px; height:64px; background:linear-gradient(135deg, rgba(26,158,82,0.2) 0%, rgba(255,255,255,0.05) 100%); border:1px solid rgba(26,158,82,.3); color:var(--green-hi); border-radius:16px; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .4s; }
.plat-main-card:hover .pmc-ico { background:var(--green); border-color:var(--green-hi); color:#fff; transform:scale(1.08); box-shadow:0 8px 24px rgba(26,158,82,.4); }
.pmc-content h3 { font-size:1.35rem; font-weight:700; color:#fff; margin-bottom:.6rem; letter-spacing:-.01em; }
.pmc-content p { font-size:.92rem; color:rgba(255,255,255,.65); line-height:1.75; margin:0; }
.pmc-content strong { color:rgba(255,255,255,.95); }
.plat-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:.8rem; margin-top:3rem; position:relative; z-index:2; }
.p-chip { display:inline-flex; align-items:center; font-size:.78rem; font-weight:600; background:rgba(255,255,255,.04); color:rgba(255,255,255,.65); padding:.5rem 1.1rem; border-radius:100px; border:1px solid rgba(255,255,255,.1); transition:all .3s ease; backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.p-chip:hover { background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.3); box-shadow:0 6px 16px rgba(0,0,0,.2); transform:translateY(-2px); }
.p-chip::before { content:"\2713"; margin-right:.4rem; color:var(--green); font-weight:900; }


/* COME FUNZIONA */
#come-funziona { 
  background: #EEF2F7;
  border-top: 1px solid var(--green-soft); 
  border-bottom: 1px solid var(--green-soft); 
  padding: 6rem 2rem;
  position: relative;
  overflow: hidden;
}
#come-funziona::before {
  content: ""; position: absolute; top: -40px; left: -40px;
  width: 280px; height: 280px;
  border-radius: 50%;
  border: 1.5px solid rgba(26,158,82,0.12);
  box-shadow: inset 0 0 0 50px rgba(26,158,82,0.04);
  z-index: 0; pointer-events: none;
}
#come-funziona::after {
  content: ""; position: absolute; bottom: 2rem; right: 2.5rem;
  width: 144px; height: 144px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%231a9e52' fill-opacity='0.15'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
.steps-hint { display:none; }
.steps-g { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; margin-top:2.75rem; }
.step { background:rgba(255,255,255,0.65); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border:1px solid rgba(255,255,255,0.5); border-radius:var(--r-xl); padding:2.5rem 2rem; position:relative; overflow:hidden; transition:box-shadow .25s, transform .25s; }
.step:hover { box-shadow:var(--sh-m); transform:translateY(-2px); }
.step-bignum { font-family:"Anton",sans-serif; font-size:clamp(4rem,7vw,7rem); line-height:1; color:var(--green-soft); position:absolute; top:.75rem; right:1.25rem; letter-spacing:-.02em; transition:color .25s; z-index:0; }
.step:hover .step-bignum { color:var(--green-hi); }
.step-lbl { font-size:.68rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--green); margin-bottom:1.1rem; }
.step-t { font-size:1.05rem; font-weight:700; color:var(--ink); margin-bottom:.65rem; position:relative; z-index:1; }
.step-d { font-size:.875rem; color:var(--ink2); line-height:1.68; position:relative; z-index:1; }

/* RISULTATI */
#risultati { 
  background: var(--green);
  background-image:
    linear-gradient(135deg, var(--green) 0%, #15864a 40%, var(--green-dark) 100%),
    radial-gradient(circle at 90% 10%, rgba(255,255,255,0.07) 0%, transparent 40%);
  padding: 6rem 2rem;
  position: relative;
  overflow: hidden;
}
#risultati::before {
  content: ""; position: absolute; top: 2rem; left: 2.5rem;
  width: 168px; height: 168px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.12'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
#risultati::after {
  content: ""; position: absolute; bottom: -60px; right: -60px;
  width: 300px; height: 300px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.08);
  box-shadow: inset 0 0 0 50px rgba(255,255,255,0.03);
  z-index: 0; pointer-events: none;
}
#risultati > .container { position: relative; z-index: 1; }
.res-g { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.75rem; }
.res-card { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:var(--r-xl); padding:2.5rem; transition:background .25s, transform .25s; }
.res-card:hover { background:rgba(255,255,255,.18); transform:translateY(-2px); }
.res-v { font-family:"Anton",sans-serif; font-size:clamp(2.5rem,5vw,4.5rem); color:#fff; line-height:1; letter-spacing:.02em; margin-bottom:.4rem; }
.res-t { font-size:.95rem; font-weight:700; color:rgba(255,255,255,.95); margin-bottom:.4rem; }
.res-d { font-size:.83rem; color:rgba(255,255,255,.72); line-height:1.65; }

/* TESTIMONIANZE */
#testimonianze { 
  background: #EEF2F7;
  padding: 6rem 2rem;
  position: relative;
  overflow: hidden;
}
#testimonianze::after {
  content: ""; position: absolute; top: -50px; right: -50px;
  width: 250px; height: 250px;
  border-radius: 50%;
  border: 1.5px solid rgba(26,158,82,0.1);
  box-shadow: inset 0 0 0 40px rgba(26,158,82,0.04);
  z-index: 0; pointer-events: none;
}
.testi-g { display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.75rem; }
.testi { background:rgba(255,255,255,0.65); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border:1px solid rgba(255,255,255,0.4); border-radius:var(--r-xl); padding:2.1rem; display:flex; flex-direction:column; gap:1rem; transition:box-shadow .25s, transform .25s; }
.testi:hover { box-shadow:var(--sh-m); transform:translateY(-2px); }
.testi-stars { font-size:.8rem; color:#f59e0b; letter-spacing:.05em; }
.testi-txt { font-size:.9rem; color:var(--ink2); line-height:1.75; flex:1; }
.testi-by { display:flex; align-items:center; gap:.72rem; }
.testi-av { width:38px; height:38px; background:var(--green-lite); border:2px solid var(--green-soft); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.7rem; font-weight:800; color:var(--green-dark); flex-shrink:0; }
.testi-name { font-size:.86rem; font-weight:700; color:var(--ink); }
.testi-role { font-size:.75rem; color:var(--ink3); }

/* PREZZI (Piano Illimitato B2B Premium) */
#prezzi { 
  background: var(--ink);
  background-image:
    linear-gradient(145deg, #1c2b3a 0%, #152130 60%, #1a2e26 100%),
    radial-gradient(ellipse 60% 60% at 50% 30%, rgba(26,158,82,.12) 0%, transparent 80%);
  padding: 8rem 2rem; 
  position: relative; 
  overflow: hidden; 
}
#prezzi::before {
  content: ""; position: absolute; top: 3rem; right: 3rem;
  width: 168px; height: 168px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.05'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
#prezzi::after {
  content: ""; position: absolute; bottom: -80px; left: -80px;
  width: 360px; height: 360px;
  border-radius: 50%;
  border: 1.5px solid rgba(26,158,82,0.08);
  box-shadow: inset 0 0 0 80px rgba(26,158,82,0.03);
  z-index: 0; pointer-events: none;
}
#prezzi .eyebrow { background: rgba(255,255,255,.1); color: rgba(255,255,255,.8); border-color: rgba(255,255,255,.2); }
#prezzi .eyebrow::before { background: rgba(255,255,255,.4); }
#prezzi .stitle { color: #fff; }
#prezzi .slead { color: rgba(255,255,255,.65); }

.sp-box {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  max-width: 900px;
  margin: 4rem auto 0;
  padding: 3.5rem;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  box-shadow: 0 30px 60px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.1);
}
.sp-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.sp-list li {
  display: flex;
  align-items: flex-start;
  gap: 1.2rem;
  font-size: .95rem;
  color: rgba(255,255,255,.8);
  line-height: 1.5;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.05);
  padding: 1.5rem;
  border-radius: 16px;
  transition: all .3s ease;
}
.sp-list li:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.15);
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(0,0,0,.2);
}
.sp-ic {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, rgba(26,158,82,0.2) 0%, rgba(255,255,255,0.05) 100%);
  border: 1px solid rgba(26,158,82,.3);
  color: var(--green-hi);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -2px;
}
.sp-ic svg { width: 16px; height: 16px; }

/* FAQ */
#faq { 
  background: linear-gradient(155deg, var(--bg) 0%, #eef4f2 100%);
  padding: 6rem 2rem;
  position: relative;
  overflow: hidden;
}
#faq::before {
  content: ""; position: absolute; top: 2rem; left: 2.5rem;
  width: 120px; height: 120px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%231a9e52' fill-opacity='0.12'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
.faq-list { max-width:740px; margin:2.5rem auto 0; display:flex; flex-direction:column; gap:.45rem; }
.faq-item { background:#fff; border:1px solid var(--border); border-radius:var(--r); overflow:hidden; transition:border-color .2s; }
.faq-item.open { border-color:var(--green-soft); }
.faq-q { width:100%; background:none; border:none; padding:1.15rem 1.35rem; text-align:left; font-size:.9rem; font-weight:600; color:var(--ink); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:1rem; font-family:inherit; transition:color .2s; }
.faq-q:hover { color:var(--green); }
.faq-item.open .faq-q { color:var(--green); }
.faq-ch { font-size:.72rem; color:var(--ink3); transition:transform .25s, color .2s; flex-shrink:0; }
.faq-item.open .faq-ch { transform:rotate(180deg); color:var(--green); }
.faq-a { display:none; padding:0 1.35rem 1.15rem; font-size:.875rem; color:var(--ink2); line-height:1.75; }
.faq-item.open .faq-a { display:block; }

/* CTA FINALE */
#cta-finale, #contattaci {
  background: var(--green); 
  background-image:
    linear-gradient(135deg, var(--green) 0%, #15864a 50%, var(--green-dark) 100%),
    radial-gradient(ellipse 65% 55% at 30% 55%, rgba(255,255,255,.09) 0%, transparent 65%);
  padding: 7rem 2rem; 
  position: relative; 
  overflow: hidden;
}
#cta-finale::before, #contattaci::before {
  content: ""; position: absolute; top: 2rem; right: 2.5rem;
  width: 168px; height: 168px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.12'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  z-index: 0; pointer-events: none;
}
#cta-finale::after, #contattaci::after {
  content: ""; position: absolute; bottom: -80px; left: -80px;
  width: 340px; height: 340px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.08);
  box-shadow: inset 0 0 0 80px rgba(255,255,255,0.03);
  z-index: 0; pointer-events: none;
}
.cta-g { display:grid; grid-template-columns:1fr 1.1fr; gap:4rem; align-items:start; max-width:1060px; margin:0 auto; }
.cta-h2 { font-family:"Anton",sans-serif; font-size:clamp(2rem,4.2vw,4rem); line-height:1; letter-spacing:.02em; text-transform:uppercase; color:#fff; margin-bottom:1rem; }
.cta-h2 .muted { color:rgba(255,255,255,.72); }
.cta-p { font-size:.97rem; color:rgba(255,255,255,.8); margin-bottom:1.7rem; line-height:1.7; }
.cta-actions { display:flex; align-items:center; gap:.9rem; flex-wrap:wrap; margin-top:1.6rem; }
.cta-checks { display:flex; flex-direction:column; gap:.5rem; }
.cta-ck { display:flex; align-items:center; gap:.48rem; font-size:.85rem; color:rgba(255,255,255,.8); font-weight:500; }
.cta-ck::before { content:"\2713"; font-weight:900; color:rgba(255,255,255,.9); }
.cta-contacts { margin-top:2rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.2); }
.cta-cl { font-size:.67rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:.45rem; }
.cta-cs { display:flex; flex-direction:column; gap:.28rem; font-size:.86rem; color:rgba(255,255,255,.72); }
.cta-cs a { color:#fff; text-decoration:none; }
.cta-cs a:hover { text-decoration:underline; }
.btn-white-outline {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.95rem 1.8rem;
  border-radius:8px;
  border:1px solid rgba(191, 219, 254, 0.42);
  background:rgba(255,255,255,.08);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  transition:background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.btn-white-outline:hover {
  background:#fff;
  color:var(--green);
  border-color:#fff;
  transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(15,23,42,.22);
}
.form-box { background:#fff; border-radius:8px; padding:2.25rem; box-shadow:0 20px 60px rgba(0,0,0,.15); }
.form-kicker { font-size:.72rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--green); margin-bottom:.55rem; }
.form-title { font-size:1.02rem; font-weight:700; color:var(--ink); margin-bottom:1.4rem; }
.form-lead { font-size:.88rem; color:var(--ink2); line-height:1.7; margin:-.6rem 0 1.2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:.72rem; }
.fg { margin-bottom:.72rem; }
.fg label { display:block; font-size:.73rem; font-weight:600; color:var(--ink2); margin-bottom:.3rem; }
.fg input,.fg textarea,.fg-select { width:100%; padding:.62rem .88rem; background:var(--bg); border:1.5px solid var(--border); border-radius:4px; color:var(--ink); font-size:.86rem; font-family:inherit; outline:none; transition:border-color .18s, box-shadow .18s; }
.fg input:focus,.fg textarea:focus,.fg-select:focus { border-color:var(--green); background:#fff; box-shadow:0 0 0 3px rgba(26,158,82,.1); }
.fg textarea { resize:vertical; min-height:68px; }
.form-consent { display:flex; align-items:flex-start; gap:.7rem; margin:.25rem 0 .15rem; color:var(--ink2); font-size:.84rem; line-height:1.6; }
.form-consent input { margin-top:.18rem; accent-color:var(--green); }
.form-consent a { color:var(--green); text-decoration:none; font-weight:700; }
.form-consent a:hover { color:var(--green-dark); }
.form-actions { display:flex; flex-direction:column; gap:.75rem; margin-top:.35rem; }
.form-meta { font-size:.8rem; color:var(--ink3); line-height:1.6; margin-top:.25rem; }
.btn-sub { width:100%; padding:.88rem; background:var(--green); color:#fff; border:none; border-radius:4px; font-size:.9rem; font-weight:700; cursor:pointer; font-family:inherit; transition:background .2s; margin-top:.2rem; }
.btn-sub:hover { background:var(--green-dark); }

/* FOOTER */
footer { background:var(--ink); padding:4rem 2rem 2rem; }
.ft { max-width:1160px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:1.75rem; }
.ft-brand { display:flex; align-items:center; gap:.48rem; margin-bottom:.75rem; }
.ft-logo { height:24px; width:auto; opacity:.65; }
.ft-bname { font-size:.95rem; font-weight:700; color:rgba(255,255,255,.55); letter-spacing:.04em; }
.ft-tag { font-size:.82rem; color:rgba(255,255,255,.32); line-height:1.7; max-width:230px; }
.ft-col h4 { font-size:.66rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.26); margin-bottom:.82rem; }
.ft-col ul { list-style:none; display:flex; flex-direction:column; gap:.48rem; }
.ft-col a { text-decoration:none; color:rgba(255,255,255,.42); font-size:.86rem; transition:color .15s; }
.ft-col a:hover { color:rgba(255,255,255,.8); }
.ft-bot { max-width:1160px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; font-size:.76rem; color:rgba(255,255,255,.22); flex-wrap:wrap; gap:.85rem; }
.ft-links { display:flex; gap:1.3rem; }
.ft-links a { color:rgba(255,255,255,.22); text-decoration:none; transition:color .15s; }
.ft-links a:hover { color:rgba(255,255,255,.55); }

/* CONTATTACI HOMEPAGE REFRESH */
#contattaci {
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%, rgba(16,185,129,.16) 0%, transparent 24%),
    radial-gradient(circle at 85% 22%, rgba(59,130,246,.16) 0%, transparent 22%),
    linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
  padding:6.5rem 2rem;
}
#contattaci::before {
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.05) 0, rgba(255,255,255,.05) 1px, transparent 1px, transparent 100%),
    linear-gradient(180deg, rgba(255,255,255,.04) 0, rgba(255,255,255,.04) 1px, transparent 1px, transparent 100%);
  background-size:36px 36px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.36), transparent 85%);
  opacity:.22;
  pointer-events:none;
}
.contattaci-shell {
  max-width:900px;
  margin:0 auto;
  position:relative;
  z-index:2;
}
.contattaci-card {
  padding:3rem;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,.05) 100%);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 32px 80px rgba(15,23,42,.28);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}
.contattaci-eyebrow {
  margin:0 auto 1.5rem;
}
.contattaci-lead {
  margin-left:auto;
  margin-right:auto;
  max-width:640px;
  color:#cbd5e1;
  line-height:1.8;
}
.contattaci-checks {
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:.7rem;
  margin:1.75rem auto 0;
  padding:1.25rem 1.35rem;
  border-radius:16px;
  background:rgba(15,23,42,.28);
  border:1px solid rgba(255,255,255,.08);
}
.cta-ck {
  color:rgba(255,255,255,.84);
}
.cta-ck::before {
  color:#86efac;
}
.contattaci-actions {
  justify-content:center;
  margin-top:2rem;
}
.contattaci-actions .btn-whatsapp,
.contattaci-secondary {
  min-width:240px;
  padding:1rem 2rem;
  border-radius:8px;
}
.contattaci-secondary {
  background:rgba(255,255,255,.08);
  color:#fff;
}
.contattaci-contacts {
  margin-top:2.4rem;
  padding-top:1.4rem;
  border-top:1px solid rgba(255,255,255,.14);
}
.contattaci-direct {
  align-items:center;
}
.contattaci-direct span {
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.7rem 1rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.88);
}
.contattaci-direct a {
  color:#fff;
}

.seo-cluster {
  padding:5.25rem 0 5.5rem;
  position: relative;
  background: var(--green-deep);
  background-image: 
    radial-gradient(circle at 8% 18%, rgba(255,255,255,0.08) 0%, transparent 26%),
    radial-gradient(circle at 92% 14%, rgba(79,203,122,0.10) 0%, transparent 24%),
    linear-gradient(180deg, #0d5229 0%, #0b4723 52%, #11723a 100%);
  background-size: auto, auto, auto;
  border-top:none;
  border-bottom:none;
}
.seo-cluster::before {
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 0, rgba(255,255,255,.06) 1px, transparent 1px, transparent 100%),
    linear-gradient(180deg, rgba(255,255,255,.04) 0, rgba(255,255,255,.04) 1px, transparent 1px, transparent 100%);
  background-size: 36px 36px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.5), transparent 78%);
  opacity:.18;
  pointer-events:none;
}
.seo-cluster > .container { position: relative; z-index: 2; }
.seo-cluster-disclosure {
  display:block;
}
.seo-cluster-summary {
  list-style:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1rem;
  cursor:pointer;
}
.seo-cluster-summary::-webkit-details-marker {
  display:none;
}
.seo-cluster-toggle {
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.72rem 1rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:0 12px 26px rgba(0,0,0,.12);
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
}
.seo-cluster-summary:hover .seo-cluster-toggle {
  transform:translateY(-1px);
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.24);
}
.seo-cluster-toggle-close {
  display:none;
}
.seo-cluster-disclosure[open] .seo-cluster-toggle-open {
  display:none;
}
.seo-cluster-disclosure[open] .seo-cluster-toggle-close {
  display:inline;
}
.seo-cluster-toggle-ic {
  width:.72rem;
  height:.72rem;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  transition:transform .25s ease;
}
.seo-cluster-disclosure[open] .seo-cluster-toggle-ic {
  transform:rotate(-135deg) translateY(-1px);
}
.seo-cluster-panel {
  display:grid;
  grid-template-rows:1fr;
  opacity:1;
  margin-top:1.2rem;
  transition:grid-template-rows .35s ease, opacity .25s ease, margin-top .25s ease;
}
.seo-cluster-panel > * {
  min-height:0;
  overflow:hidden;
}
.seo-cluster-disclosure:not([open]) .seo-cluster-panel {
  grid-template-rows:0fr;
  opacity:0;
  margin-top:.2rem;
}

.seo-cluster .eyebrow { color:rgba(255,255,255,.72); }
.seo-cluster .eyebrow::before { background:rgba(255,255,255,.42); }
.seo-cluster .stitle { color:#fff; }
.seo-cluster .slead { color:rgba(255,255,255,.78); }
.seo-cluster .steps-hint { color:rgba(255,255,255,.56); }
.seo-cluster-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.9rem;
  margin-top:1.7rem;
}
.seo-cluster-row {
  display:contents;
}
.seo-cluster-card {
  display:flex;
  flex-direction:column;
  text-decoration:none;
  min-height:100%;
  position:relative;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:1rem;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
.seo-cluster-card-arrow {
  position:absolute;
  top:.85rem;
  right:.9rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:2rem;
  height:2rem;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:1rem;
  font-weight:800;
  line-height:1;
  box-shadow:0 8px 20px rgba(0,0,0,.10);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.seo-cluster-card:hover {
  transform:translateY(-3px);
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.20);
  box-shadow:0 14px 28px rgba(0,0,0,.16);
}
.seo-cluster-card:hover .seo-cluster-card-arrow {
  transform:translateX(2px);
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.24);
}
.seo-cluster-card-featured {
  min-height:auto;
  padding:1rem;
}
.seo-cluster-card-featured strong {
  font-size: 1.02rem;
  line-height: 1.25;
  max-width:none;
}
.seo-cluster-card-featured p {
  font-size: .84rem;
  line-height: 1.55;
  max-width:none;
}
.seo-cluster-card-compact {
  min-height:auto;
  padding:1rem;
  border-radius:18px;
}
.seo-cluster-card-compact strong {
  margin-top:0;
  font-size: 1.02rem;
  line-height: 1.25;
}
.seo-cluster-card-compact p {
  margin-top:.45rem;
  font-size: .84rem;
  line-height: 1.55;
}
.seo-cluster-card-compact .seo-cluster-kicker { display:inline; }
.seo-cluster-card strong {
  display:block;
  margin-top:0;
  color:#fff;
  font-size:1.02rem;
  line-height:1.25;
}
.seo-cluster-card p {
  margin-top:.45rem;
  color:rgba(255,255,255,.74);
  font-size:.84rem;
  line-height:1.55;
}
.seo-cluster-links {
  display:flex;
  flex-wrap:wrap;
  gap:.35rem;
  margin-top:.7rem;
}
.seo-cluster-links span {
  display:inline-flex;
  align-items:center;
  padding:.22rem .5rem;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.62);
  font-size:.64rem;
  font-weight:700;
}

@media (min-width:901px) {
  .seo-cluster-row {
    display:contents;
  }
  .seo-cluster-card-compact {
    background:rgba(255,255,255,.10);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 10px 24px rgba(0,0,0,.12);
  }
}

@media (min-width:901px) {
  #hero {
    background: #c9edd4;
    background-image: none;
  }
  #hero::before,
  #hero::after {
    content: none;
  }
  #hero-problema-wrapper::before {
    background: #ffffff;
    background-image:
      radial-gradient(circle at 14% 18%, rgba(22,163,74,.08) 0%, transparent 18%),
      radial-gradient(circle at 82% 12%, rgba(22,163,74,.06) 0%, transparent 20%),
      linear-gradient(180deg, rgba(22,163,74,0.03) 0%, rgba(255,255,255,0) 26%),
      linear-gradient(180deg, #ffffff 0%, #fbfdfb 52%, #f6fbf8 100%);
    background-size: auto, auto, auto, auto;
  }
  #problema {
    background: #EEF2F7;
  }
  #problema::after {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%2310b981' fill-opacity='0.06'/%3E%3C/svg%3E");
  }
  #overview {
    background: var(--lgb-75);
    border-top-color: rgba(16,185,129,.10);
    border-bottom-color: rgba(16,185,129,.10);
  }
  #overview::before {
    background-image:
      radial-gradient(ellipse 76% 68% at 50% 0%, rgba(16,185,129,.10) 0%, transparent 72%),
      radial-gradient(circle at 10% 88%, rgba(16,185,129,.05) 0%, transparent 38%);
  }
  .overview-bridge-card {
    border-color: rgba(15,23,42,.04);
    box-shadow: 0 18px 52px rgba(15,23,42,.06);
  }
  #funzionalita {
    background: #ffffff;
    background-image: none;
    border-top: none;
    border-bottom: none;
  }
  #haccp-kf {
    background: var(--lnb-0);
    border-bottom-color: rgba(15,23,42,.06);
  }
  #haccp-kf::after {
    background: linear-gradient(180deg, rgba(15,23,42,.96) 0%, rgba(30,41,59,.94) 68%, rgba(11,59,46,.90) 100%);
  }
  #etichette {
    background: var(--lgb-75);
    border-bottom-color: rgba(15,23,42,.06);
  }
  #etichette::after {
    background: linear-gradient(180deg, rgba(248,250,252,0) 0%, rgba(16,185,129,.03) 100%);
  }
  #piattaforma {
    background: var(--ds-900);
    background-image:
      radial-gradient(ellipse 68% 56% at 50% -10%, rgba(16,185,129,.14) 0%, transparent 78%),
      radial-gradient(circle at 92% 88%, rgba(16,185,129,.05) 0%, transparent 34%),
      radial-gradient(circle at 12% 20%, rgba(59,130,246,.06) 0%, transparent 22%);
  }
  #piattaforma::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.05'/%3E%3C/svg%3E");
  }
  #piattaforma::after {
    border-color: rgba(16,185,129,.10);
    box-shadow: inset 0 0 0 60px rgba(16,185,129,.025);
  }
  #come-funziona {
    background: #EEF2F7;
    border-top-color: rgba(15,23,42,.05);
    border-bottom-color: rgba(15,23,42,.05);
  }
  #come-funziona::before {
    border-color: rgba(16,185,129,.06);
    box-shadow: inset 0 0 0 50px rgba(16,185,129,.012);
  }
  #come-funziona::after {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%2310b981' fill-opacity='0.05'/%3E%3C/svg%3E");
  }
  #risultati {
    background: var(--ga-600);
    background-image:
      linear-gradient(135deg, var(--ga-600) 0%, var(--ga-500) 55%, var(--ga-700) 100%),
      radial-gradient(circle at 88% 14%, rgba(255,255,255,.08) 0%, transparent 40%);
  }
  #risultati::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.10'/%3E%3C/svg%3E");
  }
  #risultati::after {
    border-color: rgba(255,255,255,.10);
    box-shadow: inset 0 0 0 50px rgba(255,255,255,.025);
  }
  #testimonianze {
    background: #EEF2F7;
  }
  #testimonianze::after {
    border-color: rgba(16,185,129,.08);
    box-shadow: inset 0 0 0 40px rgba(16,185,129,.025);
  }
  #prezzi {
    background: var(--ds-900);
    background-image:
      linear-gradient(145deg, var(--ds-900) 0%, var(--ds-800) 64%, #0b3b2e 100%),
      radial-gradient(ellipse 60% 60% at 50% 30%, rgba(16,185,129,.12) 0%, transparent 80%);
  }
  #prezzi::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.04'/%3E%3C/svg%3E");
  }
  #prezzi::after {
    border-color: rgba(16,185,129,.08);
    box-shadow: inset 0 0 0 60px rgba(16,185,129,.02);
  }
  #faq {
    background: linear-gradient(155deg, var(--lnb-50) 0%, var(--lgb-100) 100%);
  }
  #faq::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%2310b981' fill-opacity='0.08'/%3E%3C/svg%3E");
  }
}

/* LEGAL PAGES */
.legal-hero {
  position: relative;
  overflow: hidden;
  padding: calc(var(--nav-h) + 3.25rem) 0 4.2rem;
  background: var(--green);
  background-image:
    radial-gradient(ellipse 82% 56% at 50% -5%, rgba(255,255,255,.16) 0%, transparent 66%),
    radial-gradient(circle at 88% 24%, rgba(255,255,255,.08) 0%, transparent 24%),
    linear-gradient(180deg, #1a9e52 0%, #137a3e 100%);
}
.legal-hero::before {
  content: "";
  position: absolute;
  inset: auto -90px -90px auto;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: inset 0 0 0 80px rgba(255,255,255,.04);
  pointer-events: none;
}
.legal-hero::after {
  content: "";
  position: absolute;
  top: 14%;
  left: 4%;
  width: 150px;
  height: 150px;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.12'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  opacity: .65;
  pointer-events: none;
}
.legal-hero .container {
  position: relative;
  z-index: 1;
}
.legal-hero-copy {
  max-width: 760px;
}
.legal-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  margin-top: 1.2rem;
}
.legal-hero-meta span {
  display: inline-flex;
  align-items: center;
  padding: .45rem .78rem;
  border-radius: 999px;
  font-size: .76rem;
  font-weight: 700;
  color: rgba(255,255,255,.88);
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
}
.legal-shell {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 2rem 5rem;
}
.legal-grid {
  display: grid;
  grid-template-columns: minmax(240px, 285px) minmax(0, 1fr);
  gap: 1.4rem;
  align-items: start;
  margin-top: -2rem;
}
.legal-side,
.legal-main {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 24px;
  box-shadow: 0 18px 45px rgba(15,23,42,.06);
}
.legal-side {
  position: sticky;
  top: calc(var(--nav-h) + 1rem);
  padding: 1.25rem;
}
.legal-side-label {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: .9rem;
}
.legal-side-links {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.legal-side-links a {
  display: block;
  padding: .62rem .75rem;
  border-radius: 12px;
  text-decoration: none;
  color: var(--ink2);
  font-size: .88rem;
  line-height: 1.5;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
.legal-side-links a:hover {
  background: var(--green-lite);
  color: var(--green-dark);
  transform: translateX(3px);
}
.legal-side-note {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--bg2);
  font-size: .84rem;
  line-height: 1.7;
  color: var(--ink3);
}
.legal-main {
  padding: 2rem;
}
.legal-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
  margin-bottom: 1.8rem;
}
.legal-summary-card {
  padding: 1rem 1.05rem;
  border-radius: 18px;
  background: var(--bg);
  border: 1px solid var(--border);
}
.legal-summary-card h3 {
  font-size: .94rem;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: .35rem;
}
.legal-summary-card p {
  font-size: .88rem;
  line-height: 1.7;
  color: var(--ink2);
}
.legal-section + .legal-section {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid var(--bg2);
}
.legal-section h2 {
  font-size: 1.34rem;
  line-height: 1.2;
  color: var(--ink);
}
.legal-section h3 {
  font-size: 1rem;
  line-height: 1.35;
  color: var(--ink);
  margin-top: 1.3rem;
}
.legal-section p {
  margin-top: .9rem;
  font-size: .95rem;
  line-height: 1.8;
  color: var(--ink2);
}
.legal-section ul {
  list-style: none;
  display: grid;
  gap: .72rem;
  margin-top: 1rem;
}
.legal-section li {
  position: relative;
  padding-left: 1rem;
  font-size: .94rem;
  line-height: 1.72;
  color: var(--ink2);
}
.legal-section li::before {
  content: "";
  position: absolute;
  top: .67rem;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
}
.legal-callout {
  margin-top: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 18px;
  background: var(--green-lite);
  border: 1px solid var(--green-soft);
  color: var(--green-deep);
}
.legal-callout p,
.legal-callout li {
  color: var(--green-deep);
}
.legal-callout p:first-child {
  margin-top: 0;
}
.legal-table-wrap {
  margin-top: 1rem;
  overflow-x: auto;
}
.legal-table {
  width: 100%;
  min-width: 640px;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
}
.legal-table th,
.legal-table td {
  padding: .95rem 1rem;
  text-align: left;
  vertical-align: top;
  font-size: .9rem;
  line-height: 1.65;
  border-bottom: 1px solid var(--border);
}
.legal-table th {
  background: var(--bg);
  color: var(--ink);
  font-weight: 800;
}
.legal-table td {
  color: var(--ink2);
  background: #fff;
}
.legal-table tr:last-child td {
  border-bottom: none;
}
.legal-note {
  margin-top: .85rem;
  font-size: .84rem;
  line-height: 1.7;
  color: var(--ink3);
}
.legal-inline-links {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1rem;
}
.legal-inline-links a,
.legal-section a,
.legal-side-note a {
  color: var(--green);
  text-decoration: none;
  font-weight: 700;
}
.legal-inline-links a:hover,
.legal-section a:hover,
.legal-side-note a:hover {
  color: var(--green-dark);
}

/* RESPONSIVE */
/* MOCKUP: scale preciso per mostrare l'intera schermata desktop su mobile
   Formula: scale = viewport_width / 1100 (larghezza fissa del browser)
   Altezza wrapper = 568px (height reale) x scale_factor
   568px = 48px header + 520px body
*/
#mockupMobileView { height: 568px; }

@media (max-width: 1100px) {
  /* scale ~ 1100/1100 -> 0.92 (margini compresi) */
  .hm-browser, .hm-iphone-img { --hm-scale: 0.92; transform: scale(0.92); }
  .hm-iphone-img:hover { transform: translateY(-4px) scale(0.92); }
  .mockup-scroll-outer, #mockupMobileView { height: 523px; } /* 568 * 0.92 */
}
@media (max-width: 900px) {
  /* scale ~ 900/1100 -> 0.82 */
  .hm-browser, .hm-iphone-img { --hm-scale: 0.82; transform: scale(0.82); }
  .hm-iphone-img:hover { transform: translateY(-4px) scale(0.82); }
  .mockup-scroll-outer, #mockupMobileView { height: 466px; } /* 568 * 0.82 */
}
@media (max-width: 700px) {
  /* scale ~ 700/1100 -> 0.63 */
  .hm-browser, .hm-iphone-img { --hm-scale: 0.63; transform: scale(0.63); }
  .hm-iphone-img:hover { transform: translateY(-4px) scale(0.63); }
  .mockup-scroll-outer, #mockupMobileView { height: 358px; } /* 568 * 0.63 */
}
@media (max-width: 520px) {
  /* scale ~ 520/1100 -> 0.47 */
  .hm-browser, .hm-iphone-img { --hm-scale: 0.47; transform: scale(0.47); }
  .hm-iphone-img:hover { transform: translateY(-4px) scale(0.47); }
  .mockup-scroll-outer, #mockupMobileView { height: 267px; } /* 568 * 0.47 */
}
@media (max-width: 420px) {
  /* scale ~ 420/1100 -> 0.38 */
  .hm-browser, .hm-iphone-img { --hm-scale: 0.38; transform: scale(0.38); }
  .hm-iphone-img:hover { transform: translateY(-4px) scale(0.38); }
  .mockup-scroll-outer, #mockupMobileView { height: 216px; } /* 568 * 0.38 */
}
@media (max-width: 360px) {
  /* scale ~ 360/1100 -> 0.33 */
  .hm-browser, .hm-iphone-img { --hm-scale: 0.33; transform: scale(0.33); }
  .hm-iphone-img:hover { transform: translateY(-4px) scale(0.33); }
  .mockup-scroll-outer, #mockupMobileView { height: 187px; } /* 568 * 0.33 */
}

/* SWITCH MOCKUP: immagine su mobile, HTML su desktop */
/* Desktop: mostra HTML, nascondi immagine */
.mockup-img-frame { display: none; }
.mockup-scroll-outer { display: block; }

/* Mobile (<= 900px): mostra immagine, nascondi HTML e rimuovi l'onda decorativa per uno sfondo continuo con la hero */
@media (max-width: 900px) {
  #hero { 
    height: calc(var(--vh, 1vh) * 100);
    min-height: calc(var(--vh, 1vh) * 100);
    max-height: calc(var(--vh, 1vh) * 100);
    padding-top: calc(var(--nav-h) + 1.25rem);
    padding-bottom: 4rem;
    justify-content: center;
    overflow: hidden;
    background: #c9edd4;
    background-image: none;
    background-size: auto;
    background-attachment: local;
  }
  #hero::before,
  #hero::after {
    content: none;
  }
  .hero-bg-shapes { display: none; }
  .hero-body {
    flex: 0 0 auto;
    justify-content: center;
    padding-top: 0;
    padding-bottom: 0;
  }
  .hero-scroll-hint {
    display: flex;
    position: absolute;
    left: 0;
    right: 0;
    bottom: .15rem;
    width: max-content;
    margin: 0 auto;
    padding-bottom: 0;
  }
  #hero-mockup {
    margin-top: 0;
    transform: none;
    padding: 0 0 1.35rem;
  }
  #hero-mockup > .container {
    padding-left: .9rem;
    padding-right: .9rem;
  }
  .floating-cards { display: block; }
  .mockup-img-frame { 
    display: block; 
    width: 100%;
    margin: 0 auto;
    border-radius: 12px;
  }
  .mockup-scroll-outer { display: none; }
  #benefit-cards {
    margin-top: 1rem;
    padding-top: .35rem;
    background: transparent;
  }
  #hero-problema-wrapper::before { 
    background: #c9edd4;
    background-image: none;
    top: 0; 
  }
  #hero-problema-wrapper::after { display: none; }
}


@media (max-width:1024px) {
  .bento { grid-template-columns:repeat(2,1fr); }
  .kf-grid { gap:2.5rem; }
}
@media (max-width:900px) {
  #funzionalita .feat-hdr .slead { display: none; }
  #problema {
    background: #EEF2F7;
  }
  #overview {
    background: var(--lgb-75);
    border-top-color: rgba(16,185,129,.10);
    border-bottom-color: rgba(16,185,129,.10);
  }
  #overview::before {
    background-image:
      radial-gradient(ellipse 76% 68% at 50% 0%, rgba(16,185,129,.08) 0%, transparent 72%);
  }
  #funzionalita {
    background: #ffffff;
    background-image: none;
    border-top: none;
    border-bottom: none;
    padding: 4.4rem 1rem 5rem;
  }
  #funzionalita::before,
  #funzionalita::after {
    opacity: .38;
  }
  .feat-hdr {
    margin-bottom: 1.45rem;
    gap: .95rem;
    align-items: flex-start;
  }
  .feat-hdr .stitle {
    font-size: clamp(1.95rem, 8vw, 2.55rem);
    line-height: 1.02;
  }
  .feat-hdr .slead {
    margin-top: 0;
    max-width: none;
    font-size: .92rem;
    line-height: 1.65;
    padding: .95rem 1rem;
    border-radius: 16px;
    background: rgba(255,255,255,.74);
    border: 1px solid rgba(26,158,82,.10);
    box-shadow: 0 10px 24px rgba(20,50,40,.05);
  }
  .feat-interactive { gap: .9rem; }
  .feat-nav { display:none !important; }
  .feat-nav-hint {
    display:flex !important;
    align-items:center;
    gap:.45rem;
    width:max-content;
    padding:.44rem .72rem;
    border-radius:999px;
    background:rgba(255,255,255,.78);
    border:1px solid rgba(26,158,82,.12);
    box-shadow:0 8px 18px rgba(20,50,40,.05);
    font-size:.68rem;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--green-dark);
  }
  .feat-nav-hint::before {
    content:"";
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--green);
    box-shadow:0 0 0 4px rgba(26,158,82,.12);
  }
  .feat-content-area {
    height:auto;
    min-height:0;
    display:grid;
    grid-auto-flow:column;
    grid-auto-columns:minmax(86%, 1fr);
    gap:.9rem;
    overflow-x:auto;
    padding:.15rem .15rem .45rem;
    margin:0 -.15rem;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .feat-content-area::-webkit-scrollbar { display:none; }
  .feat-content-area .feat-panel {
    display:flex !important;
    min-height:320px;
    height:auto !important;
    overflow:visible;
    animation:none;
    scroll-snap-align:center;
    scroll-snap-stop:always;
  }
  .fc {
    padding:1.2rem 1.05rem 1rem;
    border-radius:22px;
    min-height:320px;
    box-shadow:0 18px 34px rgba(20,50,40,.08);
  }
  .fc-n {
    top: 14px;
    right: 14px;
    font-size: 2.45rem;
    color: rgba(26,158,82,.10);
  }
  .fc-ico {
    width: 44px;
    height: 44px;
    margin-bottom: .9rem;
  }
  .fc-title {
    font-size:1.08rem;
    line-height:1.18;
    margin-bottom:.45rem;
    padding-right:2.7rem;
    max-width:15ch;
  }
  .fc-desc {
    font-size:.84rem;
    line-height:1.58;
    max-width:28ch;
  }
  .fc-chips {
    padding-top:1rem;
    margin-top:auto;
    gap:.45rem;
  }
  .chip {
    font-size:.62rem;
    font-weight:700;
    padding:.28rem .6rem;
    letter-spacing:.03em;
  }
  .fc-dashboard-embed,
  .fc-stock-embed,
  .fc-prod-embed,
  .fc-order-embed,
  .fc-report-embed,
  .fc-haccp-embed,
  .fc-label-embed {
    margin-top: .8rem;
  }
  .fc-dashboard-embed,
  .fc-stock-embed,
  .fc-prod-embed,
  .fc-order-embed,
  .fc-report-embed,
  .fc-haccp-embed,
  .fc-label-embed {
    display: none;
  }
  .fc-hero {
    background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, #f2fbf6 100%);
    border-color: rgba(26,158,82,.12);
  }
  .fc-hero::before {
    opacity: 1;
    background:
      radial-gradient(circle at 12% 16%, rgba(26,158,82,.12) 0%, transparent 28%),
      radial-gradient(circle at 88% 88%, rgba(79,203,122,.10) 0%, transparent 22%);
  }
  .nav-links { display:none; }
  .nav-right { display:none; }
  .nav-hamburger { display:flex; }
  .nav-wrap { width:100%; max-width:100%; padding:0 1rem; box-sizing:border-box; }
  .ps-grid,.cta-g { grid-template-columns:1fr; }
  .page-hero-ctas,
  .fz-hero-actions,
  .page-cta-actions,
  .fz-cta-strip-actions,
  .cta-actions { gap:.8rem; }
  .testi-g { display:grid; grid-template-columns:1fr; gap:1rem; padding:0; margin-top:2.25rem; margin-right:0; overflow:visible; -webkit-mask-image:none; mask-image:none; }
  .testi { flex:none; max-width:none; touch-action:auto; -webkit-user-select:auto; user-select:auto; }
  .price-g { grid-template-columns:1fr; }
  .ft { grid-template-columns:1fr 1fr; }
  #haccp-kf {
    background: var(--lnb-0);
    border-bottom-color: rgba(15,23,42,.06);
  }
  #haccp-kf::after {
    background: linear-gradient(180deg, rgba(15,23,42,.94) 0%, rgba(30,41,59,.92) 72%, rgba(11,59,46,.88) 100%);
  }
  #etichette {
    background: var(--lgb-75);
    border-bottom-color: rgba(15,23,42,.06);
  }
  #etichette::after {
    background: linear-gradient(180deg, rgba(248,250,252,0) 0%, rgba(16,185,129,.03) 100%);
  }
  #piattaforma {
    background: var(--ds-900);
    background-image:
      radial-gradient(circle at 20% 14%, rgba(16,185,129,.12) 0%, transparent 20%),
      linear-gradient(180deg, var(--ds-900) 0%, var(--ds-800) 100%);
  }
  #piattaforma::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.04'/%3E%3C/svg%3E");
  }
  #piattaforma::after {
    border-color: rgba(16,185,129,.08);
    box-shadow: inset 0 0 0 40px rgba(16,185,129,.02);
  }
  #come-funziona {
    background: #EEF2F7;
    border-top-color: rgba(15,23,42,.05);
    border-bottom-color: rgba(15,23,42,.05);
  }
  #risultati {
    background: var(--ga-600);
    background-image:
      linear-gradient(180deg, var(--ga-600) 0%, var(--ga-500) 55%, var(--ga-700) 100%);
  }
  #risultati::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.08'/%3E%3C/svg%3E");
  }
  #risultati::after {
    border-color: rgba(255,255,255,.08);
    box-shadow: inset 0 0 0 36px rgba(255,255,255,.02);
  }
  #testimonianze {
    background: #EEF2F7;
  }
  #prezzi {
    background: var(--ds-900);
    background-image:
      linear-gradient(180deg, var(--ds-900) 0%, var(--ds-800) 70%, #0b3b2e 100%);
  }
  #prezzi::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%23ffffff' fill-opacity='0.03'/%3E%3C/svg%3E");
  }
  #prezzi::after {
    border-color: rgba(16,185,129,.06);
    box-shadow: inset 0 0 0 40px rgba(16,185,129,.015);
  }
  #faq {
    background: linear-gradient(180deg, var(--lnb-50) 0%, var(--lgb-100) 100%);
  }
  #faq::before {
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='5' height='5' x='0' y='0' fill='%2310b981' fill-opacity='0.06'/%3E%3C/svg%3E");
  }
  #contattaci {
    background:
      radial-gradient(circle at 18% 18%, rgba(16,185,129,.14) 0%, transparent 24%),
      radial-gradient(circle at 84% 18%, rgba(59,130,246,.12) 0%, transparent 22%),
      linear-gradient(180deg, var(--ds-900) 0%, var(--ds-800) 100%);
  }
  .contattaci-shell {
    max-width: none;
    width: 100%;
  }
  .contattaci-card {
    padding: 2.35rem 1.15rem;
    border-radius: 20px;
  }
  .seo-cluster {
    padding: 4.2rem 0 4.8rem;
  }
  .seo-cluster-summary {
    gap: .8rem;
  }
  .seo-cluster-toggle {
    padding: .68rem .92rem;
    font-size: .68rem;
    letter-spacing: .07em;
  }
  .seo-cluster-panel {
    margin-top: 1rem;
  }
  .seo-cluster .slead {
    max-width: none !important;
    font-size: .96rem;
    line-height: 1.7;
  }
  .seo-cluster .steps-hint {
    display: none;
  }
  .seo-cluster .steps-hint::before {
    content: none;
  }
  .seo-cluster-grid { 
    display: grid;
    grid-template-columns: 1fr;
    gap: .7rem;
    overflow: visible;
    white-space: normal;
    padding: 0;
    margin: 1rem 0 0;
  }
  .seo-cluster-row {
    display: contents;
  }
  .seo-cluster-grid::-webkit-scrollbar { display: none; }
  .seo-cluster-card {
    display: flex;
    flex: 1 1 auto;
    max-width: none;
    min-height: 0;
    padding: .95rem;
    border-radius: 16px;
    white-space: normal;
  }
  .seo-cluster-card-arrow {
    top: .75rem;
    right: .78rem;
    width: 1.8rem;
    height: 1.8rem;
    font-size: .95rem;
  }
  .seo-cluster-card-featured,
  .seo-cluster-card-compact {
    min-height: 0;
    padding: .95rem;
    border-radius: 16px;
    display: flex;
  }
  .seo-cluster-card strong {
    font-size: .98rem;
    line-height: 1.28;
  }
  /* Steps: stack verticale su mobile */
  #come-funziona { padding: 5rem 0; }
  .steps-hint { display:none; }
  .steps-g {
    display:grid;
    grid-template-columns:1fr;
    gap: .85rem;
    padding: 0;
    margin-right:0;
    margin-top: 2rem;
    overflow:visible;
    -webkit-mask-image:none;
    mask-image:none;
  }
  .step {
    flex:none;
    max-width:none;
    touch-action:auto;
    -webkit-user-select:auto;
    user-select:auto;
    display:grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: .1rem .8rem;
    align-items:start;
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .step:hover { box-shadow:none; transform:none; }
  .step-bignum {
    position: static;
    grid-column: 1;
    grid-row: 1 / span 3;
    font-family: "Outfit", sans-serif;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--green-dark);
    letter-spacing: 0;
  }
  .step-lbl { display:none; }
  .step-t {
    grid-column: 2;
    margin-bottom: .28rem;
    font-size: 1rem;
    line-height: 1.35;
  }
  .step-d {
    grid-column: 2;
    font-size: .9rem;
    line-height: 1.62;
  }
  .plat-main-grid { grid-template-columns:1fr 1fr; }
  .kf-mobile-header { display: block; margin-bottom: 1rem; }
  .kf-desktop-header { display: none; }
  .kf-grid,.kf-grid-rev { display:flex; flex-direction:column; gap:1.5rem; }
  .kf-visual { order: 1; }
  .kf-content { order: 2; }
  .kf-points { display: none; }
  .ov-points { grid-template-columns:repeat(2,1fr); }
  .float-badge { display:none; }
  .mobile-zoom-indicator { display:flex !important; pointer-events:none; z-index:99; }
  
  .ov-mockup-wrapper { overflow:hidden; position:relative; width:100%; display:flex; justify-content:center; align-items:center; scroll-behavior: smooth; }
  .ov-mockup-browser { width:100%; flex-shrink:0; }
  
  .ov-mockup-wrapper.is-expanded { overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none; justify-content:flex-start; }
  .ov-mockup-wrapper.is-expanded::-webkit-scrollbar { display:none; }
  .ov-mockup-wrapper.is-expanded .ov-mockup-browser { width:240%; max-width:none; scroll-snap-align:start; }
  .fc-dash-kpis { grid-template-columns:1fr; }
  .fc-dash-kpi { padding:0.75rem; }
  .fc-stock-grid { grid-template-columns:1fr; }
  .fc-stock-card { padding:0.75rem; }
  .fc-prod-grid { grid-template-columns:1fr; }
  .fc-prod-card { padding:0.75rem; }
  .fc-order-grid { grid-template-columns:1fr; }
  .fc-order-card { padding:0.75rem; }
  .fc-report-widget { grid-template-columns:1fr; }
  .fc-report-side { align-items:flex-start; }
}
@media (max-width:980px) {
  .legal-grid { grid-template-columns:1fr; margin-top:-1.4rem; }
  .legal-side { position:static; }
  .legal-summary { grid-template-columns:1fr; }
  .whatsapp-float-wrap { left:auto; right:1rem; flex-direction:row; align-items:center; }
}
@media (max-width:700px) {
  :root { --ticker-h: 46px; }
  .steps-hint { display:none; }
  .steps-g { padding:0; margin-right:0; -webkit-mask-image:none; mask-image:none; }
  .step { flex-basis:auto; max-width:none; }
  .feat-nav,
  .feat-nav-hint { display:none !important; }
  .feat-content-area { height:auto; }
  .fc { padding:0.95rem; }
  .fc-ico { width:40px; height:40px; margin-bottom:0.7rem; }
  .fc-title { font-size:0.92rem; padding-right:2.35rem; }
  .fc-desc { font-size:0.72rem; line-height:1.35; }
  .fc-chips { padding-top:0.65rem; gap:0.32rem; }
  .chip { font-size:0.58rem; padding:0.18rem 0.48rem; }
  .bento { grid-template-columns:1fr; }
  .ov-points { grid-template-columns:1fr; }
  .res-g { grid-template-columns:1fr; }
  .hero-stats { grid-template-columns:repeat(2,1fr); }
  .hstat:nth-child(3) { border-right:none; }
  .hstat:nth-child(4) { border-top:1px solid rgba(22,163,74,0.10); }
  .testi-g { padding:0; margin-right:0; -webkit-mask-image:none; mask-image:none; }
  .testi { flex-basis:auto; max-width:none; padding:1.7rem 1.45rem; }
  .kf-wrap { padding:2rem 1.5rem; }
  .ticker-t { gap:1.8rem; }
  .titem { font-size:.67rem; letter-spacing:.08em; }
  
  /* Hero Floating Cards su mobile: ne mostriamo solo due per non affollare */
  .fc-1 { top: 12%; left: -2%; scale: 0.75; display: flex !important; }
  .fc-2 { display: none; }
  .fc-3 { display: none; }
  .fc-4 { top: 88%; right: -2%; display: flex !important; scale: 0.85; }
  .fc-dashboard-embed { padding:0.85rem; }
  .fc-dash-head { align-items:flex-start; flex-direction:column; }
  .fc-dash-row { grid-template-columns:auto 1fr; }
  .fc-dash-time { justify-self:start; }
  .fc-stock-embed { padding:0.85rem; }
  .fc-stock-head { align-items:flex-start; flex-direction:column; }
  .fc-stock-row { grid-template-columns:auto 1fr; }
  .fc-stock-qty { justify-self:start; }
  .fc-prod-embed { padding:0.85rem; }
  .fc-prod-head { align-items:flex-start; flex-direction:column; }
  .fc-prod-row { grid-template-columns:auto 1fr; }
  .fc-prod-tag { justify-self:start; }
  .fc-order-embed { padding:0.85rem; }
  .fc-order-head { align-items:flex-start; flex-direction:column; }
  .fc-order-row { grid-template-columns:auto 1fr; }
  .fc-order-tag { justify-self:start; }
  .fc-haccp-embed .hm-footer { flex-direction:column; align-items:flex-start; gap:0.35rem; }
  .fc-report-embed { padding:0.85rem; }
  .fc-report-topline { align-items:flex-start; flex-direction:column; }
  .fc-report-row { grid-template-columns:auto 1fr; }
  .fc-report-file { justify-self:start; }
  .legal-shell { padding:0 1rem 4rem; }
  .legal-main { padding:1.3rem; }
  .legal-hero { padding:calc(var(--nav-h) + 2.8rem) 0 3rem; }
  .legal-hero-meta { flex-direction:column; align-items:flex-start; }
  .legal-table { min-width:560px; }
}
@media (max-width:520px) {
  .form-row { grid-template-columns:1fr; }
  .ft { grid-template-columns:1fr; }
  .ft-bot { flex-direction:column; align-items:flex-start; }
  /* .seo-cluster-grid handled in 900px break via flex scroll */
  .hero-ctas { flex-direction:column; align-items:stretch; gap:.8rem; }
  .hero-ctas a { justify-content:center; }
  .hero-wa-btn { width:100%; min-width:0; }
  .page-hero-ctas,
  .fz-hero-actions,
  .page-cta-actions,
  .fz-cta-strip-actions,
  .cta-actions { flex-direction:column; align-items:stretch; }
  .page-hero-ctas a,
  .fz-hero-actions a,
  .page-cta-actions a,
  .fz-cta-strip-actions a,
  .cta-actions a { width:100%; }
  .ps-grid { grid-template-columns:1fr; }
  .hero-body { padding-top:1.2rem; padding-bottom:.65rem; }
  .hero-trust { gap:.25rem .8rem; margin-top:.7rem; }
  .ticker-t { gap:1.4rem; }
  .titem { font-size:.62rem; }
  .whatsapp-float-wrap { left:auto; right:.85rem; bottom:.85rem; flex-direction:row; align-items:center; }
  .whatsapp-float { width:52px; height:52px; }
  .whatsapp-float svg { width:100%; height:100%; }
  .whatsapp-float-hint { max-width:min(210px,calc(100vw - 1.7rem)); font-size:.76rem; padding:.65rem .8rem; }
}
@media (max-width:900px) {
  .hero-body {
    max-width: 430px;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }
  #hero-watermark { width:clamp(180px,50vw,350px); bottom:0; right:-4%; opacity:.12; }
  .hero-tag {
    font-size: .74rem;
    margin-bottom: .9rem;
  }
  .hero-h1 {
    font-size: 3.55rem;
    line-height: 1.1;
    letter-spacing: .006em;
  }
  .hero-h1 .muted { font-size: .7em; letter-spacing: .018em; }
  .hero-sub {
    font-size: 1.2rem;
    line-height: 1.5;
    margin-top: 1.3rem;
    max-width: 380px;
  }
  .hero-ctas {
    margin-top: 1.05rem;
  }
  .hero-trust-micro {
    gap: .4rem .6rem;
    font-size: .68rem;
    margin-top: .6rem;
  }
}
@media (min-width:901px) and (max-height:820px) {
  #hero { padding-top: calc(var(--nav-h) + 1.35rem); padding-bottom: 8.5rem; }
  .hero-h1 { font-size: 6.5rem; line-height: 1.02; }
  .hero-sub { margin-top: .65rem; line-height: 1.62; }
  .hero-ctas { margin-top: .95rem; }
  #hero-watermark { width: 360px; bottom: 8%; }
  .fc-2 { top: 59%; }
  .fc-3 { bottom: 28%; }
}
@media (min-width:901px) and (max-height:700px) {
  #hero { padding-top: calc(var(--nav-h) + 1rem); padding-bottom: 6.75rem; }
  .hero-tag { margin-bottom: .65rem; }
  .hero-h1 { font-size: 5.9rem; line-height: .98; }
  .hero-sub { margin-top: .5rem; line-height: 1.5; max-width: 700px; }
  .hero-ctas { margin-top: .8rem; }
  .hero-trust-micro { font-size: .72rem; gap: .4rem .8rem; }
  .hero-wa-btn { padding: .88rem 1.55rem; }
  #hero-watermark { width: 300px; bottom: 6%; opacity: .05; }
  .fc-1 { top: 10%; left: 8%; scale: .86; }
  .fc-2 { top: 62%; right: 7%; scale: .8; }
  .fc-3 { bottom: 24%; left: 12%; scale: .82; }
  .fc-4 { top: 24%; right: 16%; scale: .84; }
}
@media (min-width:901px) and (max-width:1280px) {
  .hero-h1 { font-size: 5.6rem; line-height: 1.02; }
  .hero-sub { max-width: 700px; }
}
@media (min-width:901px) and (max-width:1120px) {
  .hero-h1 { font-size: 5rem; line-height: 1; }
  .hero-sub { max-width: 660px; }
}
@media (min-width:1600px) {
  .hero-body { max-width: 980px; }
  .hero-h1 { font-size: 5.45rem; line-height: 1.04; }
  .hero-sub { max-width: 760px; }
}
@media (max-width:520px) {
  #hero-watermark { width:clamp(140px,60vw,240px); bottom:4px; right:-2%; opacity:.06; }
}

/* Card 1 desktop mockup image */
.fz-img-desktop.fz-iphone.front {
  filter: none !important;
}
.fz-img-desktop.fz-iphone.front img {
  width: 100%;
  display: block;
  filter: none !important;
}

/* MOBILE: quasi zero padding laterale */
@media (max-width:600px) {
  #hero {
    background: #c9edd4;
    background-image: none;
    background-size: auto;
  }
  .container,
  .container-tight { padding: 0 .5rem; }

  .nav-wrap { padding: 0 .75rem; max-width: 100%; width: 100%; box-sizing: border-box; }
  .nav-mobile { padding: .75rem .75rem 1.25rem; }

  #hero-mockup > .container {
    padding-left: .65rem;
    padding-right: .65rem;
  }

  #problema,
  #overview,
  #funzionalita,
  #haccp-kf,
  #etichette,
  #piattaforma,
  #come-funziona,
  #risultati,
  #testimonianze,
  #prezzi,
  #faq,
  #contattaci,
  #cta-finale { padding-left: .5rem; padding-right: .5rem; }

  #contattaci {
    padding-left: .2rem;
    padding-right: .2rem;
  }
  .contattaci-card {
    padding: 2rem .95rem;
    border-radius: 18px;
  }

  .form-box { padding: 1.35rem 1.1rem; }
  .cta-g { gap: 2rem; }

  #problema {
    background: #EEF2F7;
  }

  #problema::after {
    display: none;
  }

  #funzionalita::before,
  #funzionalita::after {
    display: none;
  }

  #come-funziona::before,
  #come-funziona::after,
  #testimonianze::after {
    display: none;
  }
  #overview::before,
  #faq::before,
  #prezzi::before,
  #risultati::before,
  #piattaforma::before {
    display: none;
  }

  #problema .eyebrow {
    color: var(--green);
  }

  #problema .eyebrow::before {
    background: var(--green);
  }

  #problema .stitle {
    color: var(--ink);
  }

  #problema .stitle .hi {
    color: var(--green);
  }

  .ps-grid {
    display: none;
  }

  .ps-mobile-compare {
    display: block;
    margin-top: 1.2rem;
  }

  .psm-card {
    background: var(--white);
    border: 1px solid rgba(28,43,58,.08);
    border-radius: 26px;
    box-shadow: 0 16px 36px rgba(20,50,40,.08);
    overflow: hidden;
  }

  .psm-head {
    padding: 1.35rem 1.15rem 1rem;
    border-bottom: 1px solid rgba(28,43,58,.08);
    background: linear-gradient(180deg, rgba(247,249,248,.9) 0%, rgba(255,255,255,1) 100%);
  }

  .psm-kicker {
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: .11em;
    text-transform: uppercase;
    color: var(--green);
  }

  .psm-title {
    margin-top: .45rem;
    font-size: 1.18rem;
    line-height: 1.28;
    font-weight: 800;
    color: var(--ink);
  }

  .psm-item {
    border-top: 1px solid rgba(28,43,58,.08);
  }

  .psm-item:first-of-type {
    border-top: 0;
  }

  .psm-summary {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .9rem;
    padding: 1.05rem 1.15rem;
    cursor: pointer;
  }

  .psm-summary::-webkit-details-marker {
    display: none;
  }

  .psm-topic {
    font-size: .74rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink2);
    margin: 0;
  }

  .psm-toggle {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid rgba(28,43,58,.12);
    background: #f7f9f8;
    position: relative;
    flex-shrink: 0;
  }

  .psm-toggle::before,
  .psm-toggle::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 1.5px;
    background: var(--ink2);
    border-radius: 999px;
    transform: translate(-50%, -50%);
  }

  .psm-toggle::after {
    transform: translate(-50%, -50%) rotate(90deg);
    transition: opacity .2s ease;
  }

  .psm-item[open] .psm-toggle::after {
    opacity: 0;
  }

  .psm-body {
    padding: 0 1.15rem 1.15rem;
  }

  .psm-side {
    padding: .95rem;
    border-radius: 18px;
  }

  .psm-side + .psm-side {
    margin-top: .7rem;
  }

  .psm-side.bad {
    background: #fff5f3;
    border: 1px solid rgba(216,90,75,.18);
  }

  .psm-side.good {
    background: #eef9f0;
    border: 1px solid rgba(26,158,82,.18);
  }

  .psm-label {
    width: max-content;
    padding: .28rem .56rem;
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: .65rem;
  }

  .psm-side.bad .psm-label {
    background: rgba(216,90,75,.1);
    color: #b03a2e;
  }

  .psm-side.good .psm-label {
    background: rgba(26,158,82,.1);
    color: var(--green-dark);
  }

  .psm-side strong {
    display: block;
    font-size: 1.02rem;
    line-height: 1.25;
    margin-bottom: .3rem;
  }

  .psm-side.bad strong {
    color: #7b241c;
  }

  .psm-side.good strong {
    color: var(--green-deep);
  }

  .psm-side p {
    margin: 0;
    font-size: .9rem;
    line-height: 1.58;
  }

  .psm-side.bad p {
    color: #a4655d;
  }

  .psm-side.good p {
    color: #3f8465;
  }

  .kf-wrap { padding: 1.5rem .75rem; }
  .hero-body { padding-left: .75rem; padding-right: .75rem; }
  .hero-stats .hstat { padding-left: .5rem; padding-right: .5rem; }
  footer { padding-left: .5rem; padding-right: .5rem; }
  .ft { padding-left: 0; padding-right: 0; }
  .ft-bot { padding-left: 0; padding-right: 0; }

  /* Piattaforma: compattezza mobile */
  .plat-main-grid { gap: 0.8rem; margin-top: 2rem; }
  .plat-main-card { padding: 1.25rem 1rem; gap: 0.75rem; border-radius: 12px; }
  .pmc-ico { width: 44px; height: 44px; font-size: 1.5rem; border-radius: 10px; }
  .pmc-ico svg { width: 20px; height: 20px; }
  .pmc-content h3 { font-size: 0.95rem; margin-bottom: 0.2rem; }
  .pmc-content p { font-size: 0.8rem; line-height: 1.4; color: rgba(255,255,255,.5); }
  .plat-chips { gap: 0.5rem; margin-top: 2rem; }
  .p-chip { padding: 0.4rem 0.8rem; font-size: 0.7rem; }

  /* Piano unico compattezza mobile */
  .sp-box { padding: 2.5rem 1.25rem; margin-top: 2.5rem; }
  .sp-list { gap: 1rem; }
  .sp-list li { font-size: .88rem; gap: .75rem; padding: 1rem; }
}

/* PANORAMA SWIPE MOBILE ZOOM INDICATOR ULTRA-MINIMAL */
.mobile-zoom-indicator { display:none; position:absolute; top:45%; left:50%; transform:translate(-50%, -50%); background:rgba(255,255,255,.1); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px); border:1px solid rgba(255,255,255,.2); border-radius:50%; width:36px; height:36px; color:rgba(28,43,58,.6); font-size:1.4rem; font-weight:400; z-index:99; box-shadow:none; align-items:center; justify-content:center; pointer-events:none; transition:background .3s; }
.is-expanded ~ .mobile-zoom-indicator { background:rgba(255,255,255,.25); font-size:1.6rem; padding-bottom:2px; }


@media (max-width:600px) {
  .hero-sub { font-size:1.02rem; line-height:1.65; }
}

@media (max-width:900px) {
  #funzionalita .fc,
  #funzionalita .fc-hero {
    background: rgba(255,255,255,.72) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: 0 10px 24px rgba(15,23,42,.06) !important;
    border: 1px solid rgba(15,23,42,.12) !important;
  }

  #funzionalita .fc::before,
  #funzionalita .fc::after,
  #funzionalita .fc-hero::before,
  #funzionalita .fc-hero::after {
    display: none !important;
  }

  #funzionalita .chip {
    background: rgba(255,255,255,.78) !important;
    box-shadow: none !important;
    border: 1px solid rgba(15,23,42,.12) !important;
    color: #0f172a !important;
  }

  #funzionalita .fc-title,
  #funzionalita .fc-desc,
  #funzionalita .fc-n {
    color: #0f172a !important;
  }

  #funzionalita .fc-ico {
    background: #10b981 !important;
    color: #ffffff !important;
    box-shadow: none !important;
  }

  #funzionalita .fc-dashboard-embed,
  #funzionalita .fc-stock-embed,
  #funzionalita .fc-prod-embed,
  #funzionalita .fc-order-embed,
  #funzionalita .fc-report-embed,
  #funzionalita .fc-haccp-embed,
  #funzionalita .fc-label-embed,
  #funzionalita .fc-dashboard-embed::before,
  #funzionalita .fc-stock-embed::before,
  #funzionalita .fc-prod-embed::before,
  #funzionalita .fc-order-embed::before,
  #funzionalita .fc-report-embed::before,
  #funzionalita .fc-haccp-embed::before,
  #funzionalita .fc-label-embed::before {
    display: none !important;
  }
}

