/* BeviQui — landing page (design system marketing). Teal #096B85 · Poppins + Inter. */
:root{
  --teal:#096B85; --teal-dark:#064F63; --teal-light:#1E8AA6;
  --ice:#E8F4F7; --soft:#F2F9FB; --accent:#F2994A;
  --ink:#0E2A33; --muted:#4A6670; --line:#CFE3E9; --success:#2BB673;
  --maxw:1140px; --read:720px; --radius:20px;
  --shadow:0 8px 30px rgba(14,42,51,.08); --shadow-btn:0 6px 20px rgba(9,107,133,.25);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.brand-name,.count,.btn,.eyebrow{font-family:Poppins,Inter,sans-serif}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:var(--read)}
.center{text-align:center}
h1{font-size:clamp(2.5rem,7vw,4rem);font-weight:700;line-height:1.05;letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,4.2vw,2.3rem);font-weight:600;line-height:1.15;letter-spacing:-.01em;margin-bottom:14px}
h3{font-size:1.22rem;font-weight:600;margin:8px 0 4px}
p{font-size:1.08rem}
a{color:var(--teal);text-decoration:none}
strong{color:inherit;font-weight:600}
.muted{color:var(--muted)} .small{font-size:.9rem} .xsmall{font-size:.8rem}
.grad{background:linear-gradient(120deg,var(--teal-light),#7fd0e0);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);background:var(--ice);padding:6px 14px;border-radius:999px;margin-bottom:18px}
.sub{color:var(--muted);font-size:1.1rem;margin-bottom:8px}
.big{font-size:clamp(1.15rem,2.4vw,1.4rem);color:var(--muted);line-height:1.55}
.big strong{color:var(--ink)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:1.05rem;font-weight:600;padding:15px 28px;border-radius:14px;border:0;cursor:pointer;transition:transform .12s ease,background .2s ease,box-shadow .2s ease;min-height:48px}
.btn-sm{padding:10px 18px;font-size:.95rem;min-height:0}
.btn-lg{padding:18px 36px;font-size:1.15rem}
.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow-btn)}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--teal);border:1.6px solid var(--teal)}
.btn-ghost:hover{background:var(--ice);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--teal)}
.btn-light:hover{background:#eef7f9;transform:translateY(-2px)}
.btn:active{transform:translateY(0)}

/* NAV */
.nav{position:sticky;top:0;z-index:30;transition:background .25s ease,box-shadow .25s ease}
.nav.solid{background:rgba(255,255,255,.92);backdrop-filter:blur(10px);box-shadow:0 1px 0 rgba(14,42,51,.06)}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:9px}
.brand-drop{display:flex}
.brand-name{font-weight:700;font-size:1.35rem;color:var(--teal)}
.brand-name span{color:var(--teal-dark)}
.brand-name.small{font-size:1.15rem}

/* HERO */
.hero{position:relative;background:linear-gradient(160deg,var(--ice),#fff 72%);padding:54px 0 92px}
.hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
.hero-text .lead{font-size:1.22rem;color:var(--muted);margin:18px 0 26px;max-width:560px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.microcopy{font-size:.92rem;color:var(--muted);margin-top:16px}
.microcopy.light{color:rgba(255,255,255,.85)}
.wave{position:absolute;left:0;right:0;bottom:-1px;line-height:0}
.wave svg{width:100%;height:60px;display:block}

/* HERO phone mockup */
.hero-art{display:flex;justify-content:center}
.phone{width:248px;height:506px;border-radius:38px;background:#0e2a33;padding:12px;box-shadow:0 30px 60px rgba(9,107,133,.28);position:relative}
.phone:before{content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);width:80px;height:7px;border-radius:99px;background:#1b3a44;z-index:2}
.phone-screen{width:100%;height:100%;border-radius:28px;overflow:hidden;position:relative;background:#dff0f3}
.map-bg{position:absolute;inset:0;background:radial-gradient(120% 80% at 70% 20%,#eaf6f8,#cfe7ec)}
.street{position:absolute;background:#bcd9df;border-radius:6px;opacity:.9}
.street.s1{top:24%;left:-10%;width:120%;height:10px;transform:rotate(-8deg)}
.street.s2{top:58%;left:-10%;width:120%;height:14px;transform:rotate(6deg)}
.street.s3{top:-10%;left:34%;width:12px;height:120%;transform:rotate(10deg)}
.street.s4{top:-10%;left:68%;width:9px;height:120%;transform:rotate(-6deg)}
.pin{position:absolute;width:22px;height:22px;background:var(--teal);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 4px 8px rgba(9,107,133,.35);animation:drop .6s cubic-bezier(.2,1.2,.3,1) backwards}
.pin:after{content:"";position:absolute;top:6px;left:6px;width:10px;height:10px;background:#fff;border-radius:50%}
.pin1{top:30%;left:26%;animation-delay:.2s}
.pin2{top:46%;left:60%;animation-delay:.45s}
.pin3{top:66%;left:34%;animation-delay:.7s}
.pin4{top:22%;left:70%;animation-delay:.95s}
.me{position:absolute;top:52%;left:46%;width:16px;height:16px;background:#2b7fff;border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 0 rgba(43,127,255,.5);animation:pulse 2s infinite}
.map-chip{position:absolute;left:14px;bottom:16px;background:#fff;color:var(--ink);font-size:.78rem;font-weight:600;padding:8px 12px;border-radius:12px;box-shadow:0 6px 16px rgba(14,42,51,.16)}
/* Mappa REALE dell'app dentro il mockup + contatore fontanelle subito sotto */
.hero-art{flex-direction:column;align-items:center}
.phone-screen .map-shot{width:100%;height:100%;object-fit:cover;display:block}
.hero-count{text-align:center;margin-top:22px}
.hero-count .hc-num{display:block;font-size:clamp(2.5rem,6.5vw,3.6rem);font-weight:800;color:var(--teal);line-height:1;letter-spacing:-1px}
.hero-count .hc-label{display:block;font-size:.95rem;color:var(--muted);font-weight:600;margin-top:6px}
@keyframes drop{from{opacity:0;transform:rotate(-45deg) translateY(-40px)}to{opacity:1;transform:rotate(-45deg) translateY(0)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(43,127,255,.5)}70%{box-shadow:0 0 0 16px rgba(43,127,255,0)}100%{box-shadow:0 0 0 0 rgba(43,127,255,0)}}

/* SECTIONS */
.section{padding:78px 0}
.section-soft{background:var(--soft)}
.section-teal{background:linear-gradient(135deg,var(--teal),var(--teal-light));color:#fff}
.section-teal h2,.section-teal p{color:#fff}
.section-cta{background:var(--ink);color:#fff}
.section-cta h2,.section-cta p{color:#fff}
.section .sub{margin-bottom:8px}
.lead-light{font-size:1.18rem;color:rgba(255,255,255,.92);max-width:520px;margin:14px 0 18px}

/* STEPS */
.steps{display:grid;grid-template-columns:1fr;gap:20px;margin-top:34px}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px 26px}
.step{position:relative}
.step-n{position:absolute;top:22px;right:26px;font-family:Poppins;font-weight:700;font-size:1.5rem;color:var(--ice)}
.ico-circle{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:16px;background:var(--ice);color:var(--teal);margin-bottom:8px}
.ico-circle.sm{width:48px;height:48px;border-radius:14px;flex:0 0 auto}
.ico{width:28px;height:28px}
.ico-circle.sm .ico{width:24px;height:24px}
.card p{color:var(--muted);font-size:1rem}

/* BENEFITS */
.benefits{display:grid;grid-template-columns:1fr;gap:22px;margin-top:34px}
.benefit{display:flex;gap:16px;align-items:flex-start;text-align:left}
.benefit h3{margin-top:2px}
.benefit p{color:var(--muted);font-size:1rem}

/* PROVA / QR */
.prova-grid{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.badge{display:inline-flex;align-items:center;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);color:#fff;padding:11px 16px;border-radius:12px;font-weight:600;font-size:.95rem}
.badge-soon{opacity:.7}
.qr-wrap{display:flex;justify-content:center}
.qr-card{background:#fff;border-radius:22px;padding:18px;box-shadow:0 16px 40px rgba(6,55,67,.3);text-align:center;animation:glow 2.6s ease-in-out infinite}
.qr-card img{display:block;width:200px;height:200px;border-radius:8px}
.qr-label{display:block;margin-top:10px;color:var(--teal);font-weight:600;font-size:.95rem}
@keyframes glow{0%,100%{box-shadow:0 16px 40px rgba(6,55,67,.3)}50%{box-shadow:0 16px 50px rgba(127,208,224,.55)}}

/* COUNTER + TIMELINE */
.counter{margin:30px 0 8px}
.count{display:block;font-family:Poppins;font-weight:700;font-size:clamp(3rem,9vw,5rem);color:var(--teal);line-height:1}
.count-label{color:var(--muted);font-size:1.05rem}
.timeline{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;margin-top:18px}
.timeline .dot{font-size:.82rem;font-weight:600;color:var(--muted);background:var(--soft);border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.timeline .dot.on{color:#fff;background:var(--teal);border-color:var(--teal)}
.timeline .line{width:18px;height:2px;background:var(--line)}

/* SUPPORT */
.support{display:grid;grid-template-columns:1fr;gap:16px;margin-top:26px;text-align:left}
.support-card{display:block;border:0;background:#fff;cursor:pointer;text-align:left;transition:transform .15s ease,box-shadow .2s ease}
.support-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(14,42,51,.12)}
.support-card h3{color:var(--ink)} .support-card p{color:var(--muted);font-size:.98rem}

/* SIGNUP */
.signup{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:480px;margin:22px auto 0}
.signup input{flex:1 1 240px;padding:15px 18px;border-radius:14px;border:1.5px solid var(--line);font-size:1rem;font-family:inherit}
.signup input:focus{outline:none;border-color:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.35)}

/* FAQ */
.faq{margin-top:26px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:2px 20px;margin-bottom:12px}
.faq summary{cursor:pointer;list-style:none;font-family:Poppins;font-weight:600;padding:16px 0;position:relative;padding-right:34px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";position:absolute;right:4px;top:13px;font-size:1.5rem;color:var(--teal);transition:transform .2s ease}
.faq details[open] summary:after{transform:rotate(45deg)}
.faq details p{color:var(--muted);padding:0 0 16px}

/* FOOTER */
.section-cta .btn-primary{background:var(--teal-light)} .section-cta .btn-primary:hover{background:var(--teal)}
.footer{padding:34px 0 26px;border-top:1px solid var(--line);background:var(--soft)}
.footer-row{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
.footer-links{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.credits{margin-top:14px}

/* REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* LEGAL PAGES */
.legal{padding:92px 0 60px}
.legal h1{font-size:clamp(2rem,5vw,2.6rem);margin-bottom:6px}
.legal .upd{color:var(--muted);font-size:.92rem;margin-bottom:24px}
.legal h2{font-size:1.35rem;margin:30px 0 8px}
.legal h3{font-size:1.08rem;margin:20px 0 4px}
.legal p,.legal li{font-size:1rem;line-height:1.7;color:var(--ink)}
.legal p{margin-bottom:12px}
.legal ul{margin:6px 0 14px 20px} .legal li{margin-bottom:6px}
.legal a{word-break:break-word}
.legal .back{display:inline-block;margin-bottom:8px;font-weight:600}
.legal .note{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:14px 18px;margin:14px 0}

/* DESKTOP */
@media(min-width:760px){
  .section{padding:104px 0}
  .hero{padding:70px 0 110px}
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .steps{grid-template-columns:repeat(3,1fr)}
  .benefits{grid-template-columns:1fr 1fr;gap:28px 40px}
  .prova-grid{grid-template-columns:1.1fr .9fr}
  .support{grid-template-columns:repeat(3,1fr)}
  .reveal{transition-delay:.05s}
  .steps .reveal:nth-child(2){transition-delay:.12s}.steps .reveal:nth-child(3){transition-delay:.2s}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
