/* ============================================================
   SmaServiceCar — "Blueprint / precisione" design system
   ============================================================ */
:root{
  /* brand */
  --blu:#1C75BC; --azzurro:#36B5E5; --navy:#0B3C6E; --navy-deep:#072743;
  --amber:#FFB020; --amber-d:#F59300;
  /* plan accents */
  --ord:#15C0C9; --str:#5B6CF0; --com:#2E8BE0;
  /* neutrals */
  --ink:#0E1C2B; --body:#3A4A5C; --paper:#FBFCFE; --mist:#EEF3F9; --line:#dde6f0;
  --radius:18px; --maxw:1180px;
  --shadow-s:0 4px 14px rgba(11,60,110,.08);
  --shadow:0 18px 50px -18px rgba(11,60,110,.35);
  --shadow-amber:0 14px 34px -10px rgba(245,147,0,.55);
  --f-display:'Archivo',sans-serif;
  --f-body:'Hanken Grotesk',sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,monospace;
  --grid:rgba(28,117,188,.07);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--f-body);color:var(--body);background:var(--paper);line-height:1.65;
  font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--blu);text-decoration:none}
h1,h2,h3{font-family:var(--f-display);line-height:1.04;color:var(--ink);margin:0 0 .4em;letter-spacing:-.02em}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
b,strong{color:inherit;font-weight:700}

/* grain overlay */
.grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* eyebrow / labels */
.eyebrow{display:inline-block;font-family:var(--f-mono);font-size:.74rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blu);margin-bottom:16px}
.eyebrow.center{display:block;text-align:center}
.eyebrow.light{color:var(--azzurro)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;cursor:pointer;border:0;
  font-family:var(--f-display);font-weight:700;font-size:1rem;letter-spacing:-.01em;
  padding:15px 30px;border-radius:50px;color:#fff;background:linear-gradient(120deg,var(--azzurro),var(--blu));
  box-shadow:var(--shadow-s);transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s,filter .2s}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 30px -10px rgba(28,117,188,.6);color:#fff}
.btn-sm{padding:10px 20px;font-size:.92rem}
.btn-block{display:flex;width:100%}
.btn-amber{background:linear-gradient(120deg,#FFC247,var(--amber));color:#3a2600;box-shadow:var(--shadow-amber)}
.btn-amber:hover{color:#3a2600;box-shadow:0 18px 36px -10px rgba(245,147,0,.7)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink);box-shadow:none}
.btn-ghost:hover{border-color:var(--blu);color:var(--blu);background:rgba(28,117,188,.05)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.09s}.reveal.d2{transition-delay:.18s}.reveal.d3{transition-delay:.27s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================ HEADER ============================ */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,252,254,.82);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:76px}
.brand img{height:50px;width:auto}
.nav-list{display:flex;gap:4px;list-style:none;margin:0;padding:0;align-items:center}
.nav-list a{font-family:var(--f-display);font-weight:600;color:var(--navy);padding:9px 14px;border-radius:10px;font-size:.96rem}
.nav-list a:hover{background:var(--mist)}
.nav-list a.btn{color:#fff}
.nav-list a.btn:hover{color:#fff}
.nav-lock{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--line);color:var(--navy)!important}
.nav-lock svg{flex:none}
.nav-lock:hover{border-color:var(--blu);background:rgba(28,117,188,.06)!important;color:var(--blu)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:3px;background:var(--navy);border-radius:2px;transition:.3s}

/* ============================ HERO ============================ */
.hero{position:relative;overflow:hidden;padding:84px 0 96px;background:var(--paper)}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1100px 520px at 78% -8%,rgba(54,181,229,.22),transparent 60%),
    radial-gradient(800px 500px at 8% 110%,rgba(28,117,188,.12),transparent 55%),
    linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:auto,auto,38px 38px,38px 38px}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.6rem);font-weight:900;color:var(--ink)}
.hero h1 em{font-style:normal;color:var(--blu);position:relative}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.14em;
  background:linear-gradient(90deg,var(--amber),transparent);border-radius:4px}
.lead{font-size:1.2rem;color:var(--body);max-width:33em;margin:0 0 30px}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap}
.stat b{display:block;font-family:var(--f-display);font-weight:800;font-size:1.5rem;color:var(--navy)}
.stat span{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blu)}

/* hero panel */
.hero-panel{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:30px}
.hero-panel::before{content:"";position:absolute;inset:14px -14px -14px 14px;z-index:-1;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--azzurro),var(--blu));opacity:.16}
.panel-title{display:flex;align-items:center;gap:9px;font-family:var(--f-display);font-weight:700;color:var(--navy);margin:0 0 16px}
.panel-title .dot{width:10px;height:10px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 5px rgba(255,176,32,.2)}
/* license plate */
.plate{display:flex;align-items:stretch;border:2.5px solid var(--ink);border-radius:11px;overflow:hidden;
  background:#fff;box-shadow:0 6px 16px rgba(11,60,110,.14)}
.plate-eu{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a3aa8;color:#fff;
  width:42px;font-family:var(--f-mono);font-weight:700;font-size:.95rem;padding:8px 0;gap:3px}
.plate-stars{color:#ffd200;font-size:.7rem;line-height:1}
#targa{flex:1;border:0;outline:0;min-width:0;width:100%;
  font-family:var(--f-mono);font-weight:700;font-size:1.9rem;letter-spacing:.14em;text-align:center;
  text-transform:uppercase;color:var(--ink);padding:10px 8px}
#targa::placeholder{color:#c2cede}
.panel-fields{display:grid;gap:10px;margin:16px 0}
input,textarea{font-family:var(--f-body);font-size:1rem;border:1.5px solid var(--line);border-radius:11px;
  padding:13px 14px;width:100%;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s}
input::placeholder,textarea::placeholder{color:#9aabbd}
input:focus,textarea:focus{outline:none;border-color:var(--azzurro);box-shadow:0 0 0 4px rgba(54,181,229,.18)}
.panel-note{font-size:.86rem;color:var(--body);margin:14px 0 0;text-align:center}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ============================ SECTIONS ============================ */
.section{position:relative;padding:96px 0}
.section-title{font-size:clamp(1.9rem,3.6vw,2.9rem);font-weight:800;text-align:center;max-width:16ch;margin-left:auto;margin-right:auto}
.section-title.left{text-align:left;margin-left:0;margin-right:0;max-width:18ch}
.section-title.light,.eyebrow.center.light{color:#fff}
.section-sub{text-align:center;color:var(--body);max-width:620px;margin:0 auto 50px;font-size:1.08rem}
.section-sub.light{color:#bdd4ea}
.section-soft{background:var(--mist)}
.light-muted{color:#bdd4ea}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px 30px 30px;overflow:hidden}
.step::after{content:"";position:absolute;top:0;left:0;width:46px;height:4px;background:var(--amber)}
.step-n{font-family:var(--f-display);font-weight:900;font-size:2.6rem;color:transparent;
  -webkit-text-stroke:1.5px var(--azzurro);display:block;margin-bottom:8px;letter-spacing:-.04em}
.step h3{font-size:1.3rem}

/* ============================ PLANS (dark) ============================ */
.section-dark{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);overflow:hidden}
.section-dark::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
             linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(circle at 50% 30%,#000,transparent 80%)}
.plans{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.plan{position:relative;overflow:hidden;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:34px 28px;display:flex;flex-direction:column;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.plan::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--accent)}
.plan-idx{position:absolute;top:18px;right:22px;font-family:var(--f-mono);font-weight:700;color:var(--accent);opacity:.7;font-size:.85rem}
.plan h3{color:#fff;font-size:1.7rem}
.plan-desc{color:#acc6e0;min-height:52px;font-size:.98rem}
.plan ul{list-style:none;padding:0;margin:16px 0 24px;flex:1}
.plan li{position:relative;padding:10px 0 10px 28px;color:#d6e4f2;border-bottom:1px solid rgba(255,255,255,.09);font-size:.96rem}
.plan li::before{content:"";position:absolute;left:0;top:16px;width:13px;height:13px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 25%,transparent)}
.plan.featured{background:rgba(91,108,240,.14);border-color:var(--str);box-shadow:0 0 60px -20px var(--str)}
.plan-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--amber);color:#3a2600;
  font-family:var(--f-display);font-weight:700;font-size:.72rem;letter-spacing:.04em;padding:6px 16px;border-radius:0 0 12px 12px}
.plan-elig{text-align:center;margin-top:34px;font-family:var(--f-mono);font-size:.84rem;letter-spacing:.04em}

/* ============================ SERVICES ============================ */
.services{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.service{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 12px;
  text-align:center;transition:transform .25s,box-shadow .25s,border-color .25s}
.service::before,.service::after{content:"";position:absolute;width:10px;height:10px;border-color:var(--azzurro);opacity:0;transition:opacity .25s}
.service::before{top:8px;left:8px;border-top:2px solid;border-left:2px solid}
.service::after{bottom:8px;right:8px;border-bottom:2px solid;border-right:2px solid}
.service:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.service:hover::before,.service:hover::after{opacity:1}
.service img{width:58px;height:58px;object-fit:contain;margin:0 auto 12px}
.service span{font-family:var(--f-display);font-weight:600;font-size:.9rem;color:var(--navy)}
.service-more{grid-column:span 1;display:flex;align-items:center;justify-content:center;
  background:var(--navy);border:0}
.service-more span{color:#cfe0f1;font-family:var(--f-body);font-weight:500;font-size:.86rem;line-height:1.4}
.services-cta{text-align:center;margin-top:38px}

/* ============================ BENEFITS ============================ */
.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.benefit{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px}
.benefit-i{display:inline-grid;place-items:center;width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(54,181,229,.16),rgba(28,117,188,.16));color:var(--blu);
  font-size:1.5rem;font-weight:700;margin-bottom:14px}
.benefit h3{font-size:1.2rem}
.pay{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:44px;
  font-family:var(--f-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--body)}
.pay img{height:32px;width:auto}

/* ============================ PARTNER ============================ */
.section-partner{position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--blu),var(--navy-deep));color:#fff}
.partner-bg{position:absolute;inset:0;opacity:.6;
  background:radial-gradient(700px 400px at 90% 10%,rgba(255,176,32,.18),transparent 60%),
  linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:auto,40px 40px,40px 40px}
.partner-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.partner-list{list-style:none;padding:0;margin:22px 0 0}
.partner-list li{position:relative;padding:10px 0 10px 32px;color:#e3eefb}
.partner-list li::before{content:"→";position:absolute;left:0;color:var(--amber);font-weight:800}

/* card form */
.card-form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;display:grid;gap:12px}
.card-form h3{color:var(--ink);font-size:1.4rem;margin-bottom:6px}
.consent{display:flex;gap:9px;align-items:flex-start;font-size:.8rem;color:var(--body);line-height:1.45;text-align:left;cursor:pointer;margin:2px 0}
.consent input{width:auto;flex:none;margin-top:3px;accent-color:var(--blu)}
.consent a{font-weight:600}

/* ============================ ABOUT ============================ */
.about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
.about-mark{aspect-ratio:1;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(150deg,var(--navy),var(--blu));color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden}
.about-mark::before{content:"";position:absolute;inset:0;opacity:.5;
  background:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:30px 30px}
.about-mark span{position:relative;font-family:var(--f-display);font-weight:900;font-size:clamp(3rem,9vw,6rem);letter-spacing:-.04em}
.about-mark small{position:relative;font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;color:#bcd6f0;text-transform:uppercase}

/* ============================ CONTACT ============================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-info{list-style:none;padding:0;margin:18px 0 0;color:var(--body)}
.contact-info li{padding:5px 0}

/* ============================ FOOTER ============================ */
.site-footer{background:var(--navy-deep);color:#a9c0d6;padding:60px 0 30px}
.footer-inner{display:grid;grid-template-columns:1.3fr 1fr 1.5fr;gap:34px;align-items:start}
.footer-brand img{filter:brightness(0) invert(1);height:54px;width:auto;margin-bottom:10px;opacity:.96}
.footer-brand p{font-family:var(--f-mono);font-size:.82rem;color:#7f9bb5}
.footer-nav{display:flex;flex-direction:column;gap:9px}
.footer-nav a{color:#a9c0d6;font-family:var(--f-display);font-weight:500}
.footer-nav a:hover{color:var(--amber)}
.footer-legal{font-size:.85rem;color:#7f9bb5}
.footer-legal p{margin:.3em 0}

/* ============================ LEGAL PAGE ============================ */
.legal{padding:60px 0}
.legal h1{font-size:clamp(2rem,4vw,2.8rem)}
.legal h2{font-size:1.35rem;margin-top:1.7em;color:var(--blu)}
.legal ul{padding-left:1.2em}
.back-home{display:inline-block;margin-bottom:20px;font-family:var(--f-mono);font-size:.85rem;font-weight:700}

/* ============================ AUTH / AREA RISERVATA ============================ */
.auth{position:relative;min-height:100vh;display:grid;place-items:center;padding:40px 20px;overflow:hidden;
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%)}
.auth-bg{position:absolute;inset:0;opacity:.6;pointer-events:none;
  background:radial-gradient(700px 380px at 80% 0%,rgba(54,181,229,.22),transparent 60%),
  radial-gradient(500px 360px at 0% 100%,rgba(255,176,32,.14),transparent 60%),
  linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:auto,auto,42px 42px,42px 42px}
.auth-card{position:relative;z-index:1;width:100%;max-width:430px;background:#fff;border-radius:22px;
  box-shadow:var(--shadow);padding:40px 38px;text-align:center}
.auth-logo{display:inline-block;margin-bottom:18px}
.auth-logo img{height:62px;width:auto;margin:0 auto}
.auth-card h1{font-size:1.7rem;font-weight:800;margin:.1em 0 .2em}
.auth-sub{color:var(--body);margin:0 0 26px}
.auth-form{display:grid;gap:16px;text-align:left}
.auth-form label{font-family:var(--f-display);font-weight:600;font-size:.9rem;color:var(--navy);display:grid;gap:7px}
.auth-form input[type=email],.auth-form input[type=password]{font-weight:400}
.auth-row{display:flex;align-items:center;justify-content:space-between;font-size:.88rem;margin-top:-4px}
.auth-check{display:flex;align-items:center;gap:7px;font-weight:500;color:var(--body)}
.auth-check input{width:auto}
.auth-forgot{font-weight:600}
.auth-form .btn{margin-top:6px}
.auth-foot{margin:22px 0 6px;font-size:.92rem;color:var(--body)}
.auth .back-home{color:var(--blu)}
.auth-spinner{width:42px;height:42px;margin:8px auto 26px;border-radius:50%;
  border:4px solid var(--mist);border-top-color:var(--blu);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.auth-spinner{animation:none}}

/* ============================ RESPONSIVE ============================ */
@media(max-width:920px){
  .hero-grid,.partner-grid,.contact-grid,.about-grid{grid-template-columns:1fr}
  .about-mark{aspect-ratio:auto;padding:40px}
  .steps,.plans,.benefits{grid-template-columns:1fr}
  .services{grid-template-columns:repeat(3,1fr)}
  .service-more{grid-column:1/-1}
  .footer-inner{grid-template-columns:1fr;gap:24px}
  .nav-toggle{display:flex}
  .nav-list{position:absolute;top:76px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--paper);
    border-bottom:1px solid var(--line);padding:12px 18px;gap:4px;box-shadow:var(--shadow);display:none}
  .nav-list.open{display:flex}
  .nav-list a{padding:13px}
}
@media(max-width:560px){
  body{font-size:16px}
  .section{padding:68px 0}
  .services{grid-template-columns:repeat(2,1fr)}
  .hero-stats{gap:20px}
}
