:root{
  --b:#d62828; --bd:#b51f1f; --b2:#ff6b4a;
  --ink:#171a21; --muted:#6b7280; --line:#e9ebef; --bg:#ffffff; --soft:#f6f7f9;
  --green:#1a9d52; --amber:#b8860b;
  --shadow:0 18px 50px rgba(20,20,45,.10); --shadow-sm:0 4px 16px rgba(20,20,45,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,"Segoe UI",sans-serif;margin:0;background:var(--bg);color:var(--ink);line-height:1.45}
a{color:inherit}
.wrap{max-width:1080px;margin:0 auto;padding:0 18px}

/* NAV */
.nav{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px}
.brand .mark{width:30px;height:30px;border-radius:9px;background:var(--b);display:flex;align-items:center;justify-content:center;font-size:17px}
.nav a.link{color:var(--muted);text-decoration:none;font-weight:600;font-size:14px}
.nav a.link:hover{color:var(--ink)}

/* HERO */
.hero{position:relative;overflow:hidden;background:
  linear-gradient(100deg, #ffffff 34%, rgba(255,255,255,.72) 52%, rgba(255,255,255,.30) 72%, rgba(255,255,255,.55) 100%),
  url(/hero.png) right center / cover no-repeat,
  linear-gradient(180deg,#fff7f5, #ffffff 70%)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:56px 18px 64px}
.pill-live{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);
  color:var(--b);font-weight:700;font-size:13px;padding:7px 13px;border-radius:999px}
.pill-live .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(26,157,82,.18)}
.hero h1{font-size:46px;line-height:1.06;letter-spacing:-.02em;margin:18px 0 14px}
.hero h1 .u{text-decoration:underline;text-decoration-color:var(--b);text-underline-offset:5px}
.hero .lead{font-size:18px;color:#3a4150;max-width:30ch;margin:0 0 18px}
.ticks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.ticks li{display:flex;gap:10px;align-items:center;color:#2a2f3a;font-weight:600;font-size:15px}
.ticks li::before{content:"✓";width:22px;height:22px;border-radius:50%;background:#e3f6ec;color:var(--green);display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}

/* FORM CARD */
.card-form{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:22px}
.card-form h3{margin:0 0 4px;font-size:18px}
.card-form .hint{color:var(--muted);font-size:13px;margin:0 0 14px}
.types{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:12px 0}
.types button{padding:12px 4px;border:2px solid var(--line);background:#fff;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.types button:hover{border-color:#f0c4c4}
.types button.on{border-color:var(--b);background:#fff0f0;color:var(--b)}
label{display:block;margin:12px 0 5px;font-size:13px;font-weight:700;color:#39404d}
input{width:100%;padding:13px;border:1px solid #d6d9df;border-radius:12px;font-size:16px;background:#fff}
input:focus{outline:2px solid #f6c3c3;border-color:var(--b)}
.cta{margin-top:16px;width:100%;padding:16px;border:0;border-radius:13px;color:#fff;font-size:17px;font-weight:800;cursor:pointer;
  background:linear-gradient(135deg,var(--b),var(--b2));box-shadow:0 10px 24px rgba(214,40,40,.30)}
.cta:hover{filter:brightness(1.03)} .cta:disabled{opacity:.55;box-shadow:none}
.trust{display:flex;gap:12px;justify-content:center;color:var(--muted);font-size:12px;margin-top:14px;flex-wrap:wrap}

/* RESULT (offerte) */
#out{margin-top:16px}
.estimate{background:#fff8e8;border:1px solid #f3e2b8;border-radius:12px;padding:13px;margin-bottom:12px;font-size:14px}
.estimate b{font-size:18px}
.searching{display:flex;align-items:center;gap:10px;color:var(--muted)}
.spin{width:16px;height:16px;border:3px solid #eee;border-top-color:var(--b);border-radius:50%;animation:s 1s linear infinite}
@keyframes s{to{transform:rotate(360deg)}}
.offer{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;margin:10px 0;box-shadow:var(--shadow-sm)}
.offer .top{display:flex;justify-content:space-between;align-items:baseline}
.offer .name{font-weight:800;font-size:16px}
.offer .eta{color:var(--green);font-weight:800}
.offer .price{margin:6px 0;font-size:15px}.offer .price b{font-size:18px}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}
.badge{font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px;background:#eef0f3;color:#44495a}
.badge.rec{background:#e3f6ec;color:var(--green)}
.choose{width:100%;margin-top:8px;padding:12px;border:0;border-radius:10px;background:var(--b);color:#fff;font-weight:800;cursor:pointer}
.contact{background:#e3f6ec;border:1px solid #bfe6cf;border-radius:14px;padding:18px;text-align:center}
.contact .call{display:inline-block;margin-top:10px;background:var(--green);color:#fff;padding:13px 20px;border-radius:12px;text-decoration:none;font-weight:800}
.note{color:var(--muted);font-size:12px;text-align:center;margin-top:12px}

/* SECTIONS */
.section{padding:56px 0}
.section.soft{background:var(--soft)}
.section h2{text-align:center;font-size:30px;letter-spacing:-.02em;margin:0 0 6px}
.section .subtitle{text-align:center;color:var(--muted);margin:0 auto 34px;max-width:46ch}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm)}
.step .n{width:38px;height:38px;border-radius:11px;background:#fff0f0;color:var(--b);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:12px}
.step h3{margin:0 0 6px;font-size:17px}.step p{margin:0;color:var(--muted);font-size:14px}
.props{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.prop{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;text-align:center;box-shadow:var(--shadow-sm)}
.prop .i{font-size:30px}.prop h3{margin:10px 0 6px;font-size:17px}.prop p{margin:0;color:var(--muted);font-size:14px}
.stats{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.stat{text-align:center}.stat .v{font-size:34px;font-weight:800;color:var(--b)}.stat .l{color:var(--muted);font-size:14px}

/* BAND fabbri */
.band{background:linear-gradient(135deg,#171a21,#2a2230);color:#fff;border-radius:22px;padding:34px;display:flex;
  align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.band h3{margin:0 0 6px;font-size:24px}.band p{margin:0;color:#c9cdd6;max-width:50ch}
.band .btn{background:#fff;color:var(--ink);border:0;border-radius:12px;padding:14px 22px;font-weight:800;text-decoration:none;white-space:nowrap}

/* FOOTER */
footer{background:#0f1115;color:#aeb4bf;padding:44px 0 30px;margin-top:8px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
footer h4{color:#fff;font-size:14px;margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}
footer a{color:#aeb4bf;text-decoration:none;display:block;margin:6px 0;font-size:14px}
footer a:hover{color:#fff}
footer .legal{border-top:1px solid #23262e;margin-top:26px;padding-top:16px;font-size:12px;color:#737a86}

/* SEO content */
.seo-hero{background:linear-gradient(180deg,#fff7f5,#fff);border-bottom:1px solid var(--line)}
.seo-hero .wrap{display:grid;grid-template-columns:1fr .9fr;gap:36px;align-items:start;padding:44px 18px}
.seo h2{font-size:22px;margin:26px 0 8px}
.seo p{color:#33384a}
.seo .faq{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;margin:8px 0;box-shadow:var(--shadow-sm)}
.seo .faq b{display:block;margin-bottom:4px}
.citylinks{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.citylinks a{font-size:13px;color:var(--b);text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:6px 12px;background:#fff}
.citylinks a:hover{background:#fff0f0}

/* responsive */
@media(max-width:820px){
  .hero .wrap{grid-template-columns:1fr;gap:26px;padding:34px 18px 44px}
  .hero h1{font-size:34px}.hero .lead{max-width:none}
  .steps,.props{grid-template-columns:1fr}
  .seo-hero .wrap{grid-template-columns:1fr;gap:22px}
  footer .cols{grid-template-columns:1fr 1fr}
  .section{padding:40px 0}
}
