/* ============================================================
   PARKING FIRENZE SUD — CSS Principale
   Stile: Blu scuro #0d2158 + Oro #fbbf24
   Font: Plus Jakarta Sans
   ============================================================ */

:root {
  --blu:     #0d2158;
  --blu2:    #1a3a8a;
  --oro:     #fbbf24;
  --oro-dk:  #d97706;
  --bianco:  #ffffff;
  --grigio:  #f4f6fb;
  --testo:   #1e1e2e;
  --testo2:  #6b7280;
  --bordo:   #e5e7eb;
  --radius:  12px;
  --radius-sm: 8px;
  --shadow:  0 4px 24px rgba(13,33,88,0.10);
  --trans:   0.25s ease;
  --nav-h:   64px;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--testo);background:var(--bianco);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}

/* ============================================================
   BANNER
   ============================================================ */
#pfs-banner{
  position:fixed;top:calc(var(--nav-h) + 38px);left:0;right:0;z-index:998;
  padding:7px 20px;text-align:center;
  font-size:13px;font-weight:500;
  display:flex;align-items:center;justify-content:center;gap:16px;
}

/* ============================================================
   NAVBAR
   ============================================================ */
#pfs-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--blu);
  height:var(--nav-h);
  transition:top var(--trans), box-shadow var(--trans);
}
#pfs-nav.con-banner{top:0}
#pfs-nav.scrolled{box-shadow:0 4px 20px rgba(0,0,0,0.25)}

.nav-inner{
  max-width:1280px;margin:0 auto;
  height:100%;padding:0 24px;
  display:flex;align-items:center;gap:20px;
}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo-box{
  width:36px;height:36px;background:var(--oro);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.nav-logo-box i{font-size:20px;color:var(--blu)}
.nav-logo-name{font-size:14px;font-weight:600;color:var(--bianco)}
.nav-logo-sub{font-size:9px;color:rgba(255,255,255,0.5);line-height:1}

.nav-links{
  display:flex;gap:4px;align-items:center;flex:1;justify-content:center;
}
.nav-links li a{
  font-size:13px;color:rgba(255,255,255,0.75);
  padding:6px 10px;border-radius:6px;
  transition:color var(--trans),background var(--trans);
}
.nav-links li a:hover,.nav-links li a.active{background:#f0f4ff;border-color:#c7d4ff;
  color:var(--bianco);background:rgba(255,255,255,0.08);
}
.nav-links li a.active{color:var(--oro)}

.nav-lang{display:flex;gap:4px}
.lang-btn{
  font-size:18px;opacity:0.5;transition:opacity var(--trans);
  padding:2px;border-radius:4px;
}
.lang-btn:hover,.lang-btn.active{opacity:1}

.btn-prenota{
  background:var(--oro);color:var(--blu);
  font-size:13px;font-weight:600;
  padding:8px 18px;border-radius:8px;
  transition:background var(--trans),transform var(--trans);
  white-space:nowrap;flex-shrink:0;
}
.btn-prenota:hover{background:var(--oro-dk);transform:translateY(-1px)}

.nav-burger{display:none;background:none;border:none;color:var(--bianco);font-size:24px;padding:4px}

/* ============================================================
   HERO
   ============================================================ */
.pfs-hero{
  background:var(--blu);
  padding-top:calc(var(--nav-h) + 5px);
  padding-bottom:56px;
  display:grid;
  grid-template-columns:1fr 420px;
  gap:40px;align-items:start;
  max-width:1280px;margin:0 auto;padding-left:24px;padding-right:24px;
}
.hero-left h1{text-align:center;
  font-size:38px;font-weight:600;color:var(--bianco);
  line-height:1.2;margin-bottom:14px;
}
.hero-left h1 span{color:var(--oro)}
.hero-left p{font-size:15px;color:rgba(255,255,255,0.75);line-height:1.7;margin-bottom:24px;text-align:center}

.hero-tags{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.hero-tag{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,0.85)}
.hero-tag i{color:var(--oro);font-size:18px;flex-shrink:0}

.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.hero-stat{
  background:rgba(255,255,255,0.08);
  border:0.5px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-sm);padding:14px;text-align:center;
}
.hero-stat-n{font-size:24px;font-weight:600;color:var(--oro)}
.hero-stat-l{font-size:11px;color:rgba(255,255,255,0.6);margin-top:2px}

/* Form prenotazione hero */
.hero-form{
  background:var(--bianco);border-radius:16px;
  padding:24px;
  box-shadow:0 16px 48px rgba(0,0,0,0.2);
}
.hero-form-title{
  font-size:14px;font-weight:600;color:var(--blu);
  margin-bottom:4px;display:flex;align-items:center;gap:8px;
}
.hero-form-title i{color:var(--oro);font-size:18px}
.hero-form-sub{font-size:12px;color:var(--testo2);margin-bottom:16px}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.form-field{
  background:#ffffff;border:1px solid var(--bordo);
  border-radius:var(--radius-sm);padding:10px 12px;
  transition:border-color var(--trans);
}
.form-field:focus-within{border-color:var(--blu2)}
.form-field label{font-size:10px;color:var(--testo2);display:block;margin-bottom:3px;font-weight:500}
.form-field select,
.form-field input{
  width:100%;background:#ffffff;border:none;outline:none;
  font-size:13px;color:var(--testo);font-family:inherit;
}
.form-field select{cursor:pointer}

.veicoli-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:6px;
  margin-bottom:10px;
}
.vei-btn{
  border:1px solid var(--bordo);border-radius:8px;
  padding:8px 4px;text-align:center;cursor:pointer;
  background:var(--grigio);transition:all var(--trans);
}
.vei-btn i{font-size:18px;color:var(--blu);display:block;margin-bottom:3px}
.vei-btn span{font-size:9px;color:var(--testo2)}
.vei-btn.sel,.vei-btn:hover{background:var(--blu);border-color:var(--blu)}
.vei-btn.sel i,.vei-btn:hover i{color:var(--oro)}
.vei-btn.sel span,.vei-btn:hover span{color:rgba(255,255,255,0.8)}

#tariffa-select-wrap{margin-bottom:10px}

.btn-verifica{
  background:var(--blu);color:var(--bianco);border:none;
  border-radius:var(--radius-sm);padding:13px;
  width:100%;font-size:14px;font-weight:600;
  transition:background var(--trans),transform var(--trans);
}
.btn-verifica:hover{background:var(--blu2);transform:translateY(-1px)}

.form-pay-icons{
  display:flex;justify-content:center;gap:12px;margin-top:10px;
}
.form-pay-icons i{font-size:22px;color:var(--testo2)}

/* ============================================================
   HERO WRAPPER (sfondo blu pieno)
   ============================================================ */
.hero-wrap{background:var(--blu);padding-top:76px}
.hero-banner-bar{color:#0d2158;font-weight:600;
  background:var(--oro);padding:6px 24px;
  display:flex;justify-content:center;gap:16px;flex-wrap:nowrap;overflow-x:auto;
  position:fixed;top:var(--nav-h);left:0;right:0;z-index:999;
}
.hero-banner-bar span{
  font-size:13px;font-weight:700;color:#0d2158;
  display:flex;align-items:center;gap:5px;
}
.hero-banner-bar i{font-size:14px}

/* ============================================================
   SEZIONI
   ============================================================ */
.pfs-section{padding:64px 24px;max-width:1280px;margin:0 auto}
.pfs-section-full{padding:64px 0}
.pfs-section-full .pfs-section{padding-top:0;padding-bottom:0}

.section-header{margin-bottom:40px}
.section-title{
  font-size:28px;font-weight:600;color:var(--testo);
  padding-left:16px;border-left:4px solid var(--oro);
  line-height:1.3;
}
.section-sub{font-size:15px;color:var(--testo2);margin-top:8px;padding-left:20px}

/* ============================================================
   CARD PERCHÉ SCEGLIERCI
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{
  background:var(--bianco);border:2px solid var(--oro) !important;
  border-radius:var(--radius);padding:20px;
  position:relative;overflow:hidden;
}
.why-card::before{display:none}
.why-num{
  font-size:48px;font-weight:700;color:var(--grigio);
  position:absolute;top:8px;right:12px;line-height:1;
}
.why-icon{
  width:44px;height:44px;border-radius:10px;
  background:#fef9e8;display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;
}
.why-icon i{font-size:22px;color:var(--blu)}
.why-card h4{font-size:14px;font-weight:600;color:var(--testo);margin-bottom:6px}
.why-card p{font-size:13px;color:var(--testo2);line-height:1.5}

/* ============================================================
   CARD VEICOLI (con foto)
   ============================================================ */
.veicoli-section{background:var(--bianco)}
.veicoli-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

.veicolo-card{
  background:var(--bianco);border:3px solid var(--oro);
  border-radius:var(--radius);
  position:relative;
}
.veicolo-card::before{display:none}
.veicolo-foto{
  height:160px;overflow:hidden;background:var(--grigio);
  position:relative;display:flex;align-items:center;justify-content:center;
}
.veicolo-foto img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.4s ease;
}
.veicolo-card[data-id="6"] .veicolo-foto{
  background:#fff;
}
.veicolo-card[data-id="6"] .veicolo-foto img{
  object-fit:contain;padding:6px;width:95%;height:95%;
}
.veicolo-card:hover .veicolo-foto img{transform:scale(1.05)}
.veicolo-foto .placeholder-icon{font-size:64px;color:rgba(13,33,88,0.15)}
.veicolo-label{
  position:absolute;bottom:10px;left:10px;
  background:rgba(13,33,88,0.85);color:var(--oro);
  font-size:10px;font-weight:600;padding:3px 10px;border-radius:20px;z-index:2;
}

.veicolo-body{padding:16px}
.veicolo-body h4{font-size:15px;font-weight:600;color:var(--testo);margin-bottom:6px}
.veicolo-body p{font-size:12px;color:var(--testo2);margin-bottom:14px}

/* Fasce tariffarie dentro card veicolo */
.fasce-list{display:flex;flex-direction:column;gap:8px}
.fascia-item{
  border:1px solid var(--bordo);border-radius:8px;
  padding:10px 12px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  transition:all var(--trans);
}
.fascia-item:hover{border-color:var(--blu);background:var(--grigio)}
.fascia-item.sel{border-color:var(--blu);background:#e8f0fe}
.fascia-nome{font-size:13px;font-weight:500;color:var(--testo)}
.fascia-prezzo{font-size:15px;font-weight:700;color:var(--blu)}
.fascia-desc{font-size:11px;color:var(--testo2);margin-top:2px}

.veicolo-cta{
  display:block;width:100%;
  background:var(--blu);color:var(--bianco);border:none;
  border-radius:8px;padding:11px;
  font-size:13px;font-weight:600;text-align:center;
  margin-top:14px;transition:background var(--trans);
}
.veicolo-cta:hover{background:var(--blu2)}

/* ============================================================
   TARIFFE GENERALI
   ============================================================ */
.tariffe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tariffa-card{
  background:var(--bianco);border:2px solid var(--oro) !important;
  border-radius:var(--radius);overflow:hidden;
}
.tariffa-card.pop{border:2px solid var(--blu)}
.tariffa-head{padding:20px;background:var(--grigio);text-align:center;border-bottom:1px solid var(--bordo);position:relative}
.tariffa-head.oro{background:var(--oro)}
.tariffa-head.oro h4{color:var(--blu)}
.tariffa-head h4{font-size:12px;color:var(--testo2);margin-bottom:6px;font-weight:500}
.tariffa-head .price{font-size:36px;font-weight:700;color:var(--blu)}
.tariffa-head .unit{font-size:12px;color:var(--testo2)}
.tariffa-head.oro .unit{color:var(--blu)}
.pop-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--blu);color:var(--bianco);
  font-size:10px;font-weight:600;
  padding:3px 14px;border-radius:20px;white-space:nowrap;
}
.tariffa-body{padding:16px}
.tariffa-feat{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--testo2);
  padding:6px 0;border-bottom:1px solid var(--bordo);
}
.tariffa-feat:last-child{border-bottom:none}
.tariffa-feat i{color:var(--blu);font-size:14px;flex-shrink:0}

/* ============================================================
   SEZIONE DOVE SIAMO
   ============================================================ */
.dove-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}
.mappa-wrap{border-radius:var(--radius);overflow:hidden;height:320px}
.mappa-wrap iframe{width:100%;height:100%;border:none;display:block}
.info-card{
  background:var(--bianco);border:1px solid var(--bordo);
  border-radius:var(--radius);padding:20px;
}
.info-card h4{font-size:16px;font-weight:600;color:var(--testo);margin-bottom:16px}
.info-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 0;border-bottom:1px solid var(--bordo);
}
.info-row:last-child{border-bottom:none}
.info-row i{font-size:18px;color:var(--blu);flex-shrink:0;margin-top:1px}
.info-row span,.info-row a{font-size:13px;color:var(--testo2);line-height:1.5}
.info-row a:hover{color:var(--blu)}

/* ============================================================
   FAQ
   ============================================================ */
.faq-section .section-title{color:#ffffff !important}
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{
  background:var(--bianco);border:1px solid var(--bordo);
  border-radius:var(--radius-sm);overflow:hidden;
}
.faq-q{
  width:100%;background:none;border:none;
  padding:16px 20px;display:flex;align-items:center;justify-content:space-between;
  font-size:14px;font-weight:500;color:var(--testo);text-align:left;
  cursor:pointer;transition:background var(--trans);
}
.faq-q:hover{background:var(--grigio)}
.faq-q.open{background:var(--grigio);color:var(--blu)}
.faq-q i{font-size:18px;color:var(--testo2);transition:transform var(--trans);flex-shrink:0}
.faq-q.open i{transform:rotate(45deg);color:var(--blu)}
.faq-a{
  display:none;padding:0 20px 16px;
  font-size:13px;color:var(--testo2);line-height:1.7;
}
.faq-a.open{display:block}

/* ============================================================
   RECENSIONI WIDGET
   ============================================================ */
.recensioni-cta{
  background:var(--blu);border-radius:var(--radius);
  padding:28px 32px;text-align:center;margin-top:20px;
}
.recensioni-cta p{color:rgba(255,255,255,0.8);font-size:14px;margin-bottom:16px}
.recensioni-cta a{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--oro);color:var(--blu);
  font-size:14px;font-weight:600;
  padding:10px 24px;border-radius:8px;
  transition:background var(--trans);
}
.recensioni-cta a:hover{background:var(--oro-dk)}

/* ============================================================
   SERVIZI
   ============================================================ */
.servizi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.servizio-card{
  background:var(--bianco);border:1px solid var(--bordo);
  border-radius:var(--radius);padding:20px;
  position:relative;overflow:hidden;
}
.servizio-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--oro)}
.servizio-icon{
  width:48px;height:48px;border-radius:10px;
  background:#fef9e8;display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.servizio-icon i{font-size:24px;color:var(--blu)}
.servizio-card h4{font-size:15px;font-weight:600;color:var(--testo);margin-bottom:6px}
.servizio-card p{font-size:13px;color:var(--testo2);line-height:1.5}

/* ============================================================
   FOOTER
   ============================================================ */
.pfs-footer{background:var(--blu)}
.footer-inner{
  max-width:1280px;margin:0 auto;
  padding:48px 24px 32px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;
}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-logo-box{
  width:36px;height:36px;background:var(--oro);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
}
.footer-logo-box i{font-size:20px;color:var(--blu)}
.footer-logo span{font-size:15px;font-weight:600;color:var(--bianco)}
.footer-desc{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.7;margin-bottom:16px}

.btn-recensioni{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--oro);color:var(--blu);
  font-size:12px;font-weight:600;
  padding:7px 14px;border-radius:6px;margin-bottom:16px;
  transition:background var(--trans);
}
.btn-recensioni:hover{background:var(--oro-dk)}
.btn-recensioni i{color:var(--blu)}

.footer-social{display:flex;gap:10px;margin-top:4px}
.footer-social a{
  width:34px;height:34px;border-radius:8px;
  background:rgba(255,255,255,0.08);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.7);font-size:18px;
  transition:background var(--trans),color var(--trans);
}
.footer-social a:hover{background:var(--oro);color:var(--blu)}

.footer-col h5{
  color:var(--oro);font-size:12px;font-weight:600;
  margin-bottom:14px;letter-spacing:0.5px;text-transform:uppercase;
}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,0.55);transition:color var(--trans)}
.footer-col ul li a:hover{color:var(--oro)}

.footer-info li{
  display:flex;align-items:flex-start;gap:8px;
  font-size:13px;color:rgba(255,255,255,0.55);
}
.footer-info li i{color:var(--oro);font-size:15px;flex-shrink:0;margin-top:2px}
.footer-info li a{color:rgba(255,255,255,0.55)}
.footer-info li a:hover{color:var(--oro)}
.footer-info{gap:10px!important}

.footer-azienda{margin-top:16px}
.footer-azienda p{font-size:11px;color:rgba(255,255,255,0.3);line-height:1.8}

.footer-pay{display:flex;gap:10px;margin-top:14px}
.footer-pay i{font-size:20px;color:rgba(255,255,255,0.35)}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.08);
  max-width:1280px;margin:0 auto;
  padding:16px 24px;
  display:flex;justify-content:space-between;align-items:center;
}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.3)}

/* ============================================================
   WHATSAPP BUTTON
   ============================================================ */
.wa-button{
  position:fixed;bottom:28px;right:28px;z-index:999;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:transform var(--trans),box-shadow var(--trans);
}
.wa-button i{font-size:30px;color:var(--bianco)}
.wa-button:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,0.55)}

.wa-tooltip{
  position:absolute;right:68px;
  background:var(--testo);color:var(--bianco);
  font-size:12px;font-weight:500;
  padding:6px 12px;border-radius:6px;white-space:nowrap;
  opacity:0;transform:translateX(6px);
  transition:opacity var(--trans),transform var(--trans);
  pointer-events:none;
}
.wa-tooltip::after{
  content:'';position:absolute;right:-5px;top:50%;transform:translateY(-50%);
  border:5px solid transparent;border-left-color:var(--testo);
}
.wa-button:hover .wa-tooltip{opacity:1;transform:translateX(0)}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
#cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:998;
  background:var(--blu);border-top:1px solid rgba(255,255,255,0.1);
  padding:16px 24px;
}
.cookie-inner{
  max-width:1280px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.cookie-inner p{font-size:13px;color:rgba(255,255,255,0.8)}
.cookie-inner p a{color:var(--oro);text-decoration:underline}
.cookie-buttons{display:flex;gap:10px;flex-shrink:0}
.btn-cookie-ok{
  background:var(--oro);color:var(--blu);border:none;
  font-size:13px;font-weight:600;padding:8px 18px;border-radius:6px;
}
.btn-cookie-no{
  background:rgba(255,255,255,0.1);color:var(--bianco);border:none;
  font-size:13px;padding:8px 18px;border-radius:6px;
}

/* ============================================================
   ANIMAZIONI SCROLL
   ============================================================ */
.anim{
  opacity:0;transform:translateY(32px);
  transition:opacity 0.6s ease, transform 0.6s ease;
}
.anim.visible{opacity:1;transform:translateY(0)}
.anim-delay-1{transition-delay:0.1s}
.anim-delay-2{transition-delay:0.2s}
.anim-delay-3{transition-delay:0.3s}
.anim-delay-4{transition-delay:0.4s}

/* ============================================================
   PAGINA GRAZIE (conversione Google Ads)
   ============================================================ */
.grazie-wrap{
  min-height:70vh;display:flex;align-items:center;justify-content:center;
  padding:80px 24px;background:var(--grigio);
}
.grazie-card{
  background:var(--bianco);border-radius:var(--radius);
  padding:48px 40px;text-align:center;max-width:560px;
  box-shadow:var(--shadow);
}
.grazie-icon{
  width:72px;height:72px;border-radius:50%;
  background:#d1fae5;margin:0 auto 20px;
  display:flex;align-items:center;justify-content:center;
}
.grazie-icon i{font-size:36px;color:#059669}
.grazie-card h1{font-size:26px;font-weight:700;color:var(--testo);margin-bottom:10px}
.grazie-card p{font-size:15px;color:var(--testo2);margin-bottom:20px}
.grazie-numero{
  background:var(--grigio);border-radius:8px;padding:14px 20px;
  display:inline-flex;align-items:center;gap:12px;margin-bottom:24px;
}
.grazie-numero span{font-size:13px;color:var(--testo2)}
.grazie-numero strong{font-size:22px;font-weight:700;color:var(--blu)}

/* ============================================================
   FORM PRENOTAZIONE PAGINA DEDICATA
   ============================================================ */
.prenotazione-wrap{
  padding-top:calc(var(--nav-h) + 60px);
  padding-bottom:60px;
  max-width:800px;margin:0 auto;padding-left:24px;padding-right:24px;
}
.form-card{border:2px solid var(--oro);
  background:var(--bianco);border-radius:var(--radius);
  padding:32px;border:1px solid var(--bordo);
  box-shadow:var(--shadow);
}
.form-card h2{font-size:22px;font-weight:700;color:var(--testo);margin-bottom:6px}
.form-card p{font-size:14px;color:var(--testo2);margin-bottom:24px}
.form-section-label{
  font-size:12px;font-weight:600;color:var(--testo2);
  text-transform:uppercase;letter-spacing:0.5px;
  margin:20px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--bordo);
}
.form-full{margin-bottom:10px}
.form-full .form-field{width:100%}
.prefisso-tel{display:grid;grid-template-columns:110px 1fr;gap:8px;margin-bottom:10px}
.form-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.form-check input{margin-top:3px;accent-color:var(--blu);width:16px;height:16px;flex-shrink:0}
.form-check label{font-size:13px;color:var(--testo2)}
.form-check label a{color:var(--blu);text-decoration:underline}

.btn-submit{
  background:var(--blu);color:var(--bianco);border:none;
  border-radius:var(--radius-sm);padding:14px;
  width:100%;font-size:15px;font-weight:700;
  transition:background var(--trans),transform var(--trans);
  margin-top:8px;
}
.btn-submit:hover{background:var(--blu2);transform:translateY(-1px)}
.btn-submit:disabled{opacity:0.6;cursor:not-allowed;transform:none}

/* Riepilogo prezzo */
.prezzo-riepilogo{
  background:var(--grigio);border-radius:var(--radius-sm);
  padding:14px 16px;margin-bottom:16px;
}
.prezzo-riepilogo .prezzo-row{
  display:flex;justify-content:space-between;
  font-size:13px;color:var(--testo2);padding:3px 0;
}
.prezzo-riepilogo .prezzo-totale{
  display:flex;justify-content:space-between;
  font-size:17px;font-weight:700;color:var(--blu);
  margin-top:10px;padding-top:10px;border-top:1px solid var(--bordo);
}

/* ============================================================
   COME ARRIVARE
   ============================================================ */
.arrivare-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.arrivare-card{
  background:var(--bianco);border:1px solid var(--bordo);
  border-radius:var(--radius);padding:24px;
}
.arrivare-card h3{font-size:16px;font-weight:600;color:var(--testo);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.arrivare-card h3 i{color:var(--oro);font-size:20px}
.arrivare-step{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--bordo)}
.arrivare-step:last-child{border-bottom:none}
.step-num{
  width:28px;height:28px;border-radius:50%;
  background:var(--blu);color:var(--bianco);
  font-size:12px;font-weight:700;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.step-text{font-size:13px;color:var(--testo2);line-height:1.5}

/* ============================================================
   UTILITY
   ============================================================ */
.bg-grigio{background:var(--grigio)}
.bg-blu{background:var(--blu)}
.text-center{text-align:center}
.mt-16{margin-top:16px}
.mt-32{margin-top:32px}
.mb-8{margin-bottom:8px}
.alert-error{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px}
.alert-ok{background:#d1fae5;color:#065f46;padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .pfs-hero{grid-template-columns:1fr;padding-bottom:40px;padding-top:calc(var(--nav-h) + 8px)}
  .hero-left h1{text-align:center;font-size:30px}
  .hero-form{max-width:560px;margin:0 auto;width:100%}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .veicoli-grid{grid-template-columns:repeat(2,1fr)}
  .servizi-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
  .tariffe-grid{grid-template-columns:1fr}
}

@media (max-width: 768px) {
  :root{--nav-h:56px}
  .hero-left h1{text-align:center;font-size:26px;line-height:1.35;margin-top:-45px}
  .nav-links{
    display:none;flex-direction:column;
    position:absolute;top:var(--nav-h);left:0;right:0;
    background:#ffffff;border-top:3px solid var(--oro);border-bottom:1px solid #e5e7eb;padding:10px 12px;gap:6px;box-shadow:0 8px 16px rgba(0,0,0,0.12);
  }
  .nav-links.open{display:flex}
  .nav-links li a{padding:10px 14px;display:flex;align-items:center;gap:10px;color:#0d2158;background:#f8f9fa;border:1px solid #e5e7eb;border-radius:20px;font-size:14px;font-weight:500;margin:2px 0;}
  .nav-burger{display:block}
  .nav-lang{display:flex;gap:4px;flex-wrap:wrap}
  .why-grid{grid-template-columns:1fr}
  .veicoli-grid{grid-template-columns:1fr}
  .tariffe-grid{grid-template-columns:1fr}
  .servizi-grid{grid-template-columns:1fr}
  .dove-grid{grid-template-columns:1fr}
  .arrivare-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .form-row{grid-template-columns:1fr}
  .veicoli-grid.hero{grid-template-columns:repeat(3,1fr)}
  .pfs-section{padding:40px 16px}
}

/* Dropdown lingua */
.nav-lang-dropdown{position:relative}
.lang-current{background:transparent;border:1px solid rgba(255,255,255,0.3);color:#fff;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.lang-current:hover{background:rgba(255,255,255,0.1)}
.lang-menu{display:none;position:absolute;right:0;top:calc(100% + 6px);background:#fff;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.15);min-width:120px;z-index:999;overflow:hidden}
.nav-lang-dropdown.open .lang-menu{display:block}
.lang-menu a{display:block;padding:10px 16px;font-size:13px;font-weight:600;color:#0d2158;text-decoration:none}
.lang-menu a:hover{background:#f0f9ff}
.lang-menu a.active{background:#fbbf24;color:#0d2158}
@media(max-width:768px){.nav-lang-dropdown{display:block}}

.pfs-section.dark .section-title,.faq-wrap .section-title{color:#fff !important}

/* === FIX CARD BORDO GIALLO === */
.why-card { border: 2px solid #fbbf24 !important; }
.why-card::before { display: none !important; }
.tariffa-card { border: 2px solid #fbbf24 !important; }

/* === FAQ TITOLO BIANCO === */
.faq-section .section-title,
.faq-wrap .section-title,
section.pfs-section.faq-section h2,
.section-title.faq-title { color: #ffffff !important; }

/* FORCE BORDER YELLOW ALL SIDES */
.tariffa-card, .why-card {
  border-right: 2px solid #fbbf24 !important;
  border-bottom: 2px solid #fbbf24 !important;
  border-left: 2px solid #fbbf24 !important;
  outline: 2px solid #fbbf24 !important;
}
.why-card::before { display: none !important; }

/* BORDO GIALLO VEICOLO-CARD */
.veicolo-card {
  border-left: 1px solid var(--oro);
  border-right: 1px solid var(--oro);
  border-bottom: 1px solid var(--oro);
  border-top-width: 8px !important;
}
.fascia-item { pointer-events: none; cursor: default; }
.veicolo-cta { pointer-events: auto; cursor: pointer; }
@media(max-width:600px){
  .hero-banner-bar{font-size:12px;gap:10px;padding:5px 10px;}
  .hero-banner-bar span{white-space:nowrap}
}

/* Prefisso + telefono */
.prefisso-tel-row{display:flex;gap:8px}
.prefisso-tel-row .prefisso-wrap{flex:0 0 130px}
.prefisso-tel-row .tel-wrap{flex:1}
@media(max-width:480px){
  .prefisso-tel-row .prefisso-wrap{flex:0 0 110px}
}

/* Previeni zoom iOS su input */
@media(max-width:768px){
  input, select, textarea {
    font-size: 16px !important;
  }
}


.fascia-item:nth-child(1){background:#e6f1fb;border-radius:8px;}
.fascia-item:nth-child(1) .fascia-nome{color:#0c447c;}
.fascia-item:nth-child(1) .fascia-prezzo{color:#0c447c;}
.fascia-item:nth-child(2){background:#e1f5ee;border-radius:8px;}
.fascia-item:nth-child(2) .fascia-nome{color:#085041;}
.fascia-item:nth-child(2) .fascia-prezzo{color:#085041;}
.fascia-item:nth-child(3){background:#faeeda;border-radius:8px;}
.fascia-item:nth-child(3) .fascia-nome{color:#633806;}
.fascia-item:nth-child(3) .fascia-prezzo{color:#633806;}
.fascia-item:nth-child(4){background:#eeedfe;border-radius:8px;}
.fascia-item:nth-child(4) .fascia-nome{color:#3c3489;}
.fascia-item:nth-child(4) .fascia-prezzo{color:#3c3489;}
.fascia-item:nth-child(5){background:#faece7;border-radius:8px;}
.fascia-item:nth-child(5) .fascia-nome{color:#712b13;}
.fascia-item:nth-child(5) .fascia-prezzo{color:#712b13;}
.fascia-item:nth-child(6){background:#fbeaf0;border-radius:8px;}
.fascia-item:nth-child(6) .fascia-nome{color:#72243e;}
.fascia-item:nth-child(6) .fascia-prezzo{color:#72243e;}

.form-card input[type=date],
.form-card input[type=time],
.form-card input[type=text],
.form-card input[type=email],
.form-card input[type=tel],
.form-card select {
  background:#f4f6ff;
  border:1.5px solid #e0e7ff;
  border-radius:10px;
  padding:10px 12px;
  font-size:15px;
  color:#0d2158;
  width:100%;
}
.form-card input:focus,
.form-card select:focus {
  border-color:#0d2158;
  outline:none;
  background:#fff;
}
.prezzo-riepilogo {
  background:#f0f4ff;
  border-radius:10px;
  padding:14px 16px;
  margin:12px 0;
  border:1px solid #e0e7ff;
}
.prezzo-totale {
  border-top:1px solid #c7d4ff;
  padding-top:8px;
  margin-top:6px;
  font-size:17px;
  font-weight:700;
  color:#0d2158;
}
.prezzo-totale .p-totale { color:#059669; }

.form-card input[type=date],
.form-card input[type=time],
.form-card input[type=text],
.form-card input[type=email],
.form-card input[type=tel],
.form-card select {
  background:#f4f6ff;
  border:1.5px solid #e0e7ff;
  border-radius:10px;
  padding:10px 12px;
  font-size:15px;
  color:#0d2158;
  width:100%;
}
.form-card input:focus,
.form-card select:focus {
  border-color:#0d2158;
  outline:none;
  background:#fff;
}
.prezzo-riepilogo {
  background:#f0f4ff;
  border-radius:10px;
  padding:14px 16px;
  margin:12px 0;
  border:1px solid #e0e7ff;
}
.prezzo-totale {
  border-top:1px solid #c7d4ff;
  padding-top:8px;
  margin-top:6px;
  font-size:17px;
  font-weight:700;
  color:#0d2158;
}
.prezzo-totale .p-totale { color:#059669; }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}
.form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.form-field label {
  font-size: 12px;
  color: #6b7280;
  font-weight: 500;
}
.form-full {
  margin-bottom: 10px;
}

@media (max-width: 600px) {
  .form-row { grid-template-columns: 1fr; }
  .prefisso-tel { grid-template-columns: 1fr; }
}

.form-card input[type=date] {
  max-width: 210px;
}

.form-card input[type=email],
.form-card input[type=text],
.form-card input[type=tel] {
  max-width: 100%;
  width: 100%;
}

.form-card input[type=email] {
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 14px;
}
