:root{
  --primary:#2F5D3A;        /* verde bosco */
  --primary-dark:#234A2D;
  --accent:#C97B3D;          /* terracotta */
  --accent-soft:#F6E7D7;
  --bg:#FAF8F4;              /* avorio caldo */
  --card:#FFFFFF;
  --ink:#26261F;
  --ink-soft:#6B6A60;
  --line:#E8E4DB;
  --ok:#1E7F4F;
  --radius:16px;
  --maxw:1080px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h1,h2,h3{line-height:1.2;font-weight:800;letter-spacing:-.01em}
h2{font-size:clamp(26px,4vw,38px);margin-bottom:14px}
.kicker{display:inline-block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:10px}
.sub{color:var(--ink-soft);font-size:clamp(16px,2vw,19px);max-width:640px}
section{padding:72px 0}
.center{text-align:center}
.center .sub{margin:0 auto}

/* topbar */
.topbar{position:sticky;top:0;z-index:50;background:rgba(250,248,244,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-size:20px;font-weight:800;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:8px}
.logo .dot{width:12px;height:12px;border-radius:50%;background:var(--accent);display:inline-block}
.nav-links{display:flex;gap:22px;align-items:center}
.nav-links a{color:var(--ink);text-decoration:none;font-size:15px;font-weight:600}
.nav-links a:hover{color:var(--primary)}
@media(max-width:760px){.nav-links a:not(.btn){display:none}}

/* language switcher */
.lang-sel{appearance:none;-webkit-appearance:none;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 30px 8px 14px;font-size:14px;font-weight:700;color:var(--primary);cursor:pointer;font-family:inherit;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%232F5D3A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.lang-sel:hover{border-color:var(--primary)}

/* buttons */
.btn{display:inline-block;padding:14px 26px;border-radius:999px;font-weight:700;font-size:16px;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease;cursor:pointer;border:none}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 18px rgba(47,93,58,.28)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-wa{background:#25D366;color:#fff;box-shadow:0 6px 18px rgba(37,211,102,.3)}
.btn-demo{background:var(--accent);color:#fff;box-shadow:0 8px 24px rgba(201,123,61,.5)}
.btn-ghost{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-sm{padding:10px 20px;font-size:14px}

/* hero */
.hero{padding:84px 0 64px;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;gap:40px}}
.hero h1{font-size:clamp(32px,5.2vw,52px);margin-bottom:18px}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero .sub{margin-bottom:28px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-note{font-size:14px;color:var(--ink-soft);margin-top:14px}
.badge-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.badge{font-size:13px;font-weight:600;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:7px 14px;color:var(--ink-soft)}

/* phone mockup */
.phone{width:300px;margin:0 auto;background:#1b1b18;border-radius:42px;padding:12px;box-shadow:0 30px 60px rgba(38,38,31,.25), 0 4px 14px rgba(38,38,31,.12)}
.phone-screen{background:var(--bg);border-radius:32px;overflow:hidden;height:560px;display:flex;flex-direction:column}
.ph-head{background:var(--primary);color:#fff;padding:18px 16px 14px;font-weight:700;font-size:15px}
.ph-head small{display:block;font-weight:400;opacity:.8;font-size:11px;margin-top:2px}
.ph-grid{padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px;overflow:hidden}
.ph-group{grid-column:1/-1;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin:4px 2px 0}
.ph-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 10px;text-align:center;font-size:12px;font-weight:600;color:var(--ink)}
.ph-card span{display:block;font-size:22px;margin-bottom:4px}

/* problem strip */
.strip{background:var(--primary);color:#fff;padding:56px 0}
.strip h2{color:#fff}
.strip .sub{color:rgba(255,255,255,.82)}
.pains{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px}
@media(max-width:860px){.pains{grid-template-columns:repeat(2,1fr)}}
.pain{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:20px 18px;font-size:15px}
.pain b{display:block;font-size:17px;margin-bottom:6px}

/* modules */
.mods{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
@media(max-width:860px){.mods{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.mods{grid-template-columns:1fr}}
.mod{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;transition:transform .15s ease,box-shadow .15s ease}
.mod:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(38,38,31,.08)}
.mod .ico{font-size:30px;display:block;margin-bottom:10px}
.mod b{font-size:17px;display:block;margin-bottom:6px}
.mod p{font-size:14.5px;color:var(--ink-soft)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
@media(max-width:760px){.steps{grid-template-columns:1fr}}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;position:relative}
.step .n{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:14px}
.step b{font-size:17px;display:block;margin-bottom:6px}
.step p{font-size:14.5px;color:var(--ink-soft)}

/* compare table */
.tbl-wrap{overflow-x:auto;margin-top:38px;border-radius:var(--radius);border:1px solid var(--line);background:var(--card)}
table{width:100%;border-collapse:collapse;font-size:14.5px;min-width:640px}
th,td{padding:13px 16px;text-align:center;border-bottom:1px solid var(--line)}
th:first-child,td:first-child{text-align:left;font-weight:600;position:sticky;left:0;background:var(--card);z-index:1;min-width:170px}
thead th:first-child{background:var(--bg)}
thead th{background:var(--bg);font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
thead th.me{background:var(--primary);color:#fff;border-radius:0}
td.me{background:#F1F6F1;font-weight:700}
.yes{color:var(--ok);font-weight:800}
.no{color:#C9472B;font-weight:700;opacity:.75}
.half{color:var(--accent);font-weight:700}
.tbl-note{font-size:13px;color:var(--ink-soft);margin-top:12px}

/* cost stack comparison */
.cost-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:20px;margin-top:38px;text-align:left;align-items:stretch}
@media(max-width:760px){.cost-grid{grid-template-columns:1fr}}
.cost-col{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column}
.cost-col.sep{border-color:#E4CFC0}
.cost-col h3{font-size:18px;margin-bottom:4px}
.cost-col .lead{font-size:13.5px;color:var(--ink-soft);margin-bottom:16px}
.cost-line{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
.cost-line span:first-child{color:var(--ink)}
.cost-line span:last-child{font-weight:700;color:var(--ink-soft);white-space:nowrap}
.cost-sum{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-top:auto;padding-top:18px;font-size:15px}
.cost-sum b{font-size:26px;color:#C9472B}
.cost-col.fattore{background:var(--primary);color:#fff;border:none;justify-content:center;text-align:center}
.cost-col.fattore h3{color:#fff;font-size:20px}
.cost-col.fattore .big{font-size:52px;font-weight:800;margin:6px 0 2px}
.cost-col.fattore .big small{font-size:18px;font-weight:600;opacity:.85}
.cost-col.fattore p{font-size:14.5px;color:rgba(255,255,255,.85);margin-top:10px}
.cost-col.fattore .save{display:inline-block;margin-top:16px;background:rgba(255,255,255,.16);border-radius:999px;padding:7px 16px;font-size:14px;font-weight:700}

/* story */
.story{background:var(--accent-soft)}
.story .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:860px){.story .wrap{grid-template-columns:1fr}}
.story blockquote{font-size:clamp(17px,2.2vw,21px);font-weight:600;line-height:1.5;border-left:4px solid var(--accent);padding-left:20px;margin:22px 0}
.story .sig{font-size:15px;color:var(--ink-soft)}
.story-facts{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fact{background:#fff;border-radius:var(--radius);padding:22px 18px;text-align:center;border:1px solid rgba(201,123,61,.25)}
.fact b{display:block;font-size:26px;color:var(--primary)}
.fact span{font-size:13.5px;color:var(--ink-soft)}

/* pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px;align-items:stretch}
@media(max-width:860px){.plans{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}}
.plan{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column}
.plan.featured{border:2px solid var(--primary);box-shadow:0 18px 40px rgba(47,93,58,.14);position:relative}
.plan.featured .flag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;font-size:12px;font-weight:700;padding:5px 16px;border-radius:999px;white-space:nowrap}
.plan h3{font-size:19px;margin-bottom:4px}
.plan .pricetag{font-size:38px;font-weight:800;color:var(--primary);margin:10px 0 2px}
.plan .pricetag small{font-size:15px;font-weight:600;color:var(--ink-soft)}
.plan .yr{font-size:13.5px;color:var(--ink-soft);margin-bottom:18px}
.plan ul{list-style:none;margin-bottom:24px;flex:1}
.plan li{padding:7px 0;font-size:14.5px;border-bottom:1px dashed var(--line)}
.plan li::before{content:"✓ ";color:var(--ok);font-weight:800}
.plan .btn{text-align:center}
.launch{margin-top:26px;background:#FFF6EA;border:1.5px dashed var(--accent);border-radius:var(--radius);padding:18px 22px;font-size:15px}
.launch b{color:var(--accent)}

/* faq */
details{background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden}
summary{padding:18px 22px;font-weight:700;font-size:16px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:22px;color:var(--accent);font-weight:400}
details[open] summary::after{content:"–"}
details .a{padding:0 22px 18px;color:var(--ink-soft);font-size:15px}

/* final cta */
.final{background:var(--primary);color:#fff;text-align:center;padding:84px 0}
.final h2{color:#fff;font-size:clamp(28px,4.5vw,42px)}
.final .sub{color:rgba(255,255,255,.85);margin:14px auto 32px}
.contact-alt{margin-top:18px;font-size:15px;color:rgba(255,255,255,.75)}
.contact-alt a{color:#fff}

footer{padding:34px 0;font-size:13.5px;color:var(--ink-soft)}
footer .wrap{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
footer a{color:var(--ink-soft)}

/* ===== brand mark (germoglio) ===== */
.logo-mark{width:30px;height:30px;display:block;flex:0 0 auto;filter:drop-shadow(0 2px 5px rgba(38,38,31,.22))}
.foot-mark{width:24px;height:24px;vertical-align:middle;margin-right:9px}
.cta-mark{width:62px;height:62px;display:block;margin:0 auto 20px;filter:drop-shadow(0 8px 16px rgba(0,0,0,.22))}

/* ===== topbar demo button: short label on mobile, never wraps ===== */
.btn-short{display:none}
.nav-links .btn{white-space:nowrap}
@media(max-width:760px){
  .nav-links{gap:12px}
  .lang-sel{padding:7px 28px 7px 12px;font-size:13px}
  .btn-sm{padding:9px 16px;font-size:13px}
  .btn-full{display:none}
  .btn-short{display:inline}
}
@media(max-width:460px){
  .logo{font-size:18px}
  .logo-mark{width:26px;height:26px}
  .nav-links{gap:9px}
  .lang-sel{padding:6px 24px 6px 10px;font-size:12.5px}
  .btn-sm{padding:8px 13px;font-size:12.5px}
}

/* ===== compare table on mobile: scroll affordance (Lea Verou shadows) + tighter ===== */
@media(max-width:680px){
  .tbl-wrap{
    background:
      linear-gradient(to right, var(--card) 32%, rgba(255,255,255,0)) left center,
      linear-gradient(to left, var(--card) 32%, rgba(255,255,255,0)) right center,
      radial-gradient(farthest-side at 0 50%, rgba(38,38,31,.16), rgba(38,38,31,0)) left center,
      radial-gradient(farthest-side at 100% 50%, rgba(38,38,31,.16), rgba(38,38,31,0)) right center;
    background-repeat:no-repeat;
    background-size:46px 100%,46px 100%,16px 100%,16px 100%;
    background-attachment:local,local,scroll,scroll;
    -webkit-overflow-scrolling:touch;
  }
}
@media(max-width:560px){
  table{min-width:500px;font-size:12.5px;table-layout:fixed}
  th,td{padding:11px 8px;word-wrap:break-word}
  th:first-child,td:first-child{width:140px;min-width:140px}
  thead th{font-size:11px;letter-spacing:.02em}
}
