/* ══════════════════════════════════════════════════════════
   SMA Energia — Form & Modal Styles
   Form multi-step, validazione, emergenza, modali, stati
   ══════════════════════════════════════════════════════════ */

/* ── MODALI ── */
.tmodal{position:fixed;inset:0;z-index:9990;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.42);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);opacity:0;pointer-events:none;transition:opacity .22s}
.tmodal.open{opacity:1;pointer-events:all}
.tbox{background:#fff;border-radius:18px;padding:38px 34px;max-width:390px;width:88%;box-shadow:0 24px 72px rgba(0,0,0,.18);transform:translateY(14px) scale(.97);transition:transform .28s cubic-bezier(.22,1,.36,1);position:relative;text-align:center}
.tmodal.open .tbox{transform:translateY(0) scale(1)}
.tbox-form{max-width:640px;width:94%;padding:0;border-radius:24px;text-align:left;overflow:hidden;max-height:92vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.22)}
.tbox-ic{font-size:40px;margin-bottom:12px}
.tbox h3{font-family:'Fraunces',serif;font-size:21px;font-weight:700;color:var(--ink);margin-bottom:8px}
.tbox p{font-size:13.5px;color:var(--mid);line-height:1.75;margin-bottom:20px}
.tbox-cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:14px;font-weight:700;cursor:pointer;border:none;text-decoration:none;transition:all .2s;margin-bottom:8px}
.tbox-cta:last-child{margin-bottom:0}
.tbox-cta.green{background:var(--g);color:#fff}.tbox-cta.green:hover{background:var(--gd)}
.tbox-cta.red{background:#dc2626;color:#fff}.tbox-cta.red:hover{background:#b91c1c}
.tbox-cta.wa{background:#22c55e;color:#fff}.tbox-cta.wa:hover{background:#16a34a}
.tbox-cta.outline{background:#fff;color:var(--mu);border:1.5px solid rgba(26,32,20,.13)}.tbox-cta.outline:hover{background:var(--bg)}
.tmclose-abs{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:#f3f4f6;border:none;cursor:pointer;font-size:13px;color:var(--mu);display:flex;align-items:center;justify-content:center;transition:background .18s;z-index:5}
.tmclose-abs:hover{background:#e5e7eb}
.tmclose-inline{background:rgba(26,32,20,.08);border:none;cursor:pointer;font-size:12px;color:var(--mu);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .18s;flex-shrink:0}
.tmclose-inline:hover{background:rgba(26,32,20,.18)}

/* Google reviews modal (homepage) */
.tbox-google{max-width:460px;text-align:left;padding:34px 32px}
.g-header{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.g-logo{font-size:36px}
.g-header-txt h3{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--ink);margin:0 0 2px}
.g-score-row{display:flex;align-items:center;gap:8px}
.g-big{font-size:28px;font-weight:800;color:var(--ink);font-family:'Sora',sans-serif;line-height:1}
.g-stars{color:#f5b800;font-size:16px;letter-spacing:1px}
.g-count{font-size:12px;color:var(--mu)}
.g-reviews{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;max-height:260px;overflow-y:auto}
.g-rev{background:var(--bg);border-radius:12px;padding:14px;border:1px solid rgba(58,136,48,.08)}
.g-rev-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.g-rev-name{font-size:12.5px;font-weight:700;color:var(--ink)}
.g-rev-stars{color:#f5b800;font-size:12px}
.g-rev-date{font-size:10.5px;color:var(--mu);margin-bottom:5px}
.g-rev-text{font-size:12.5px;color:var(--mid);line-height:1.6}
.g-actions{display:flex;gap:9px}
.g-btn{flex:1;padding:12px;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:13px;font-weight:700;cursor:pointer;border:none;text-align:center;text-decoration:none;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.g-btn.primary{background:var(--g);color:#fff}.g-btn.primary:hover{background:var(--gd)}
.g-btn.sec{background:rgba(58,136,48,.09);color:var(--g)}.g-btn.sec:hover{background:rgba(58,136,48,.16)}

/* ── PROGRESS BAR ── */
.fprog{border-radius:22px 22px 0 0;background:rgba(58,136,48,.05);padding:18px 32px 14px;border-bottom:1px solid rgba(58,136,48,.08)}
.fprog-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.plbl{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g);flex:1}
.ptime{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--g);background:rgba(58,136,48,.08);padding:4px 10px;border-radius:20px;white-space:nowrap;transition:all .3s}
.pbar-track{height:5px;background:rgba(58,136,48,.12);border-radius:3px;overflow:hidden}
.pbar-fill{height:100%;background:linear-gradient(to right,var(--g),#52c41a);border-radius:3px;transition:width .55s cubic-bezier(.22,1,.36,1);position:relative}
.pbar-fill::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(to right,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.8s infinite}
@keyframes shimmer{0%{left:-60%}100%{left:120%}}

/* ── FORM LAYOUT ── */
.fhead{padding:22px 32px 6px}
.stt{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--ink);margin-bottom:4px}
.ssb{font-size:13px;color:var(--mu);line-height:1.5}
.fbody{padding:16px 32px 26px}
.sf{display:none}.sf.active{display:block}

/* ── STEP BUTTONS ── */
.sgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}
.sbtn{border:1.5px solid rgba(58,136,48,.18);background:rgba(58,136,48,.07);border-radius:12px;padding:15px 16px;cursor:pointer;display:flex;align-items:center;gap:11px;text-align:left;transition:all .22s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden;font-family:'Sora',sans-serif}
.sbtn::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--g);opacity:0;transition:opacity .22s}
.sbtn:hover{border-color:var(--g);background:rgba(58,136,48,.12);transform:translateY(-1px);box-shadow:0 4px 14px rgba(58,136,48,.14)}
.sbtn:hover::before{opacity:1}
.sbtn.sel{border-color:var(--g);background:rgba(58,136,48,.12);box-shadow:0 0 0 3px rgba(58,136,48,.15)}
.sbtn.sel::before{opacity:1}
.sbtn-icon{font-size:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.85);box-shadow:0 1px 4px rgba(26,32,20,.10)}
.sbtn-txt{display:flex;flex-direction:column;gap:1px;min-width:0}
.slb{font-size:13.5px;font-weight:700;color:var(--ink);line-height:1.2}
.ssub{font-size:11px;font-weight:500;color:#6a8565;line-height:1.3}
.sgrid-sm{grid-template-columns:1fr 1fr 1fr;gap:7px;margin-bottom:0}
.sbtn-sm{padding:9px 10px;border-radius:10px}
.sbtn-sm .slb{font-size:11.5px}
.sbtn-sm{position:relative;overflow:visible}
.sbtn-sm::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--ink);color:#fff;font-size:10.5px;font-weight:500;padding:6px 10px;border-radius:7px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:50;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.sbtn-sm:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.sbtn-emerg{border-color:rgba(220,38,38,.25);background:rgba(220,38,38,.06)}
.sbtn-emerg::before{background:#dc2626}
.sbtn-emerg:hover{border-color:#dc2626;background:rgba(220,38,38,.12)}
.sbtn-emerg:hover::before{opacity:1}
.sbtn-emerg.sel{border-color:#dc2626;background:rgba(220,38,38,.12);box-shadow:0 0 0 3px rgba(220,38,38,.15)}
.sbtn-emerg.sel::before{opacity:1}

/* ── FORM FIELDS ── */
.fg{margin-bottom:14px}
.fg label{display:block;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--mid);margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 16px;border:1.5px solid rgba(58,136,48,.2);border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:15px;color:var(--ink);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(58,136,48,.1)}
.fg textarea{resize:vertical;min-height:70px}
.fgr{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.tel-wrap{display:flex;align-items:center;border:1.5px solid rgba(58,136,48,.2);border-radius:var(--r10);overflow:hidden;background:#fff;transition:border-color .2s,box-shadow .2s}
.tel-wrap:focus-within{border-color:var(--g);box-shadow:0 0 0 3px rgba(58,136,48,.1)}
.tel-flag{padding:0 12px;font-size:13px;font-weight:600;color:var(--mid);white-space:nowrap;border-right:1px solid rgba(58,136,48,.12);background:rgba(58,136,48,.03);display:flex;align-items:center;gap:4px;height:100%;flex-shrink:0}
.tel-wrap input{border:none;outline:none;padding:11px 14px;font-family:'Sora',sans-serif;font-size:14px;color:var(--ink);flex:1;min-width:0;background:transparent}

/* Privacy */
.fg-privacy{margin-top:6px;margin-bottom:10px}
.fg-privacy label.privacy-label{display:flex;align-items:center;gap:10px;font-size:11.5px;font-weight:500;color:var(--mid);line-height:1.4;cursor:pointer;text-transform:none;letter-spacing:0;margin:0}
.privacy-txt{flex:1}
.privacy-label input[type="checkbox"]{accent-color:var(--g);flex-shrink:0;width:18px;height:18px;cursor:pointer}
.privacy-label a{color:var(--g);text-decoration:underline;font-weight:500;margin:0;padding:0;display:inline}

/* Validation */
.fg.has-error input,.fg.has-error select,.fg.has-error textarea,.fg.has-error .tel-wrap{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.1)}
.fg-error-msg{font-size:10.5px;font-weight:600;color:#dc2626;margin-top:4px;display:none}
.fg.has-error .fg-error-msg{display:block}
.fg-privacy.has-error .privacy-txt{color:#dc2626}
.fg-privacy.has-error input[type="checkbox"]{outline:2px solid #dc2626;outline-offset:2px;border-radius:3px}

/* ── NAVIGATION ── */
.fnav{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:13px;border-top:1px solid rgba(58,136,48,.08)}
.fbk{font-size:12.5px;font-weight:500;color:var(--mu);cursor:pointer;background:none;border:none;font-family:'Sora',sans-serif;display:flex;align-items:center;gap:4px;transition:color .2s}
.fbk:hover{color:var(--ink)}
.fnx{background:var(--g);color:#fff;border:none;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:14px;font-weight:700;padding:13px 26px;cursor:pointer;display:flex;align-items:center;gap:5px;box-shadow:0 3px 10px rgba(58,136,48,.25);transition:all .2s}
.fnx:hover{background:var(--gd);transform:translateY(-1px)}
.fsub{width:100%;background:var(--y);color:var(--ink);border:none;border-radius:12px;font-family:'Sora',sans-serif;font-size:16px;font-weight:800;padding:17px;cursor:pointer;margin-top:14px;box-shadow:0 4px 16px rgba(245,184,0,.3);transition:all .2s}
.fsub:hover{background:var(--yl);transform:translateY(-1px)}

/* ── EMERGENZA ── */
.emerg-head{text-align:center;margin-bottom:14px}
.emerg-badge{display:inline-block;background:rgba(220,38,38,.1);color:#dc2626;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:20px;margin-bottom:8px}
.emerg-sub{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink)}
.emerg-urgenza{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.sbtn-urg{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;border:1.5px solid rgba(26,32,20,.1);background:#fff;cursor:pointer;font-family:'Sora',sans-serif;transition:all .22s;overflow:visible}
.sbtn-urg:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.08)}
.sbtn-urg.sel{border-color:var(--ink);background:rgba(26,32,20,.03);box-shadow:0 0 0 3px rgba(26,32,20,.08)}
.urg-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.urg-red{background:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.2)}
.urg-orange{background:#f59e0b;box-shadow:0 0 0 3px rgba(245,158,11,.2)}
.urg-yellow{background:#eab308;box-shadow:0 0 0 3px rgba(234,179,8,.2)}
.emerg-call{margin-bottom:12px}
.fsub-call{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:#dc2626;color:#fff;border:none;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:15px;font-weight:800;padding:15px;cursor:pointer;margin-top:8px;margin-bottom:4px;box-shadow:0 4px 16px rgba(220,38,38,.3);transition:all .2s;text-decoration:none}
.fsub-call:hover{background:#b91c1c;transform:translateY(-1px)}
.fsub-wa{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:#22c55e;color:#fff;border:none;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:15px;font-weight:800;padding:15px;cursor:pointer;margin-top:8px;box-shadow:0 4px 16px rgba(34,197,94,.3);transition:all .2s;text-decoration:none}
.fsub-wa:hover{background:#16a34a;transform:translateY(-1px)}
.emerg-divider{text-align:center;margin:16px 0 12px;position:relative}
.emerg-divider::before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:rgba(26,32,20,.1)}
.emerg-divider span{position:relative;background:#fff;padding:0 14px;font-size:11px;font-weight:600;color:var(--mu);text-transform:uppercase;letter-spacing:.05em}
.fsub-callback{width:100%;background:rgba(26,32,20,.06);color:var(--mid);border:1.5px solid rgba(26,32,20,.12);border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:13px;font-weight:700;padding:13px;cursor:pointer;margin-top:10px;transition:all .2s;text-align:center}
.fsub-callback:hover{background:rgba(26,32,20,.1);color:var(--ink)}
.fsub-emerg-submit{width:100%;background:var(--y);color:var(--ink);border:none;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:15px;font-weight:800;padding:15px;cursor:pointer;margin-top:8px;box-shadow:0 4px 16px rgba(245,184,0,.3);transition:all .2s}
.fsub-emerg-submit:hover{background:var(--yl);transform:translateY(-1px)}

/* ── STATI: SUCCESS / LOADING / ERROR ── */
.fsuccess{display:none;text-align:center;padding:52px 28px 36px;position:relative;animation:successIn .5s ease}
.fsuccess .tmclose-abs{position:absolute;top:12px;right:12px}
@keyframes successIn{0%{opacity:0;transform:translateY(16px)}100%{opacity:1;transform:translateY(0)}}
.fsuccess .fsc-ic{margin-bottom:14px;width:64px;height:64px;background:var(--g);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(58,136,48,.3)}
.fsuccess h3{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--g);margin-bottom:8px}
.fsuccess p{font-size:14px;color:var(--mu);line-height:1.6}
.fsuccess-recap{text-align:left;background:var(--bg);border-radius:12px;padding:16px 20px;margin:16px 0;border:1px solid rgba(58,136,48,.1)}
.fsuccess-recap-row{display:flex;justify-content:space-between;padding:5px 0;font-size:12px;border-bottom:1px solid rgba(58,136,48,.06)}
.fsuccess-recap-row:last-child{border-bottom:none}
.fsuccess-recap-label{font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:.05em;font-size:10px}
.fsuccess-recap-value{font-weight:600;color:var(--ink);text-align:right;max-width:60%}
.floading{display:none;text-align:center;padding:64px 28px;animation:successIn .4s ease}
.floading-spinner{width:48px;height:48px;border:3.5px solid rgba(58,136,48,.15);border-top-color:var(--g);border-radius:50%;animation:fSpin .7s linear infinite;margin:0 auto 20px}
@keyframes fSpin{to{transform:rotate(360deg)}}
.floading-text{font-family:'Sora',sans-serif;font-size:15px;font-weight:600;color:var(--ink);margin-bottom:4px}
.floading-sub{font-family:'Sora',sans-serif;font-size:12px;color:var(--mu)}

/* ── FORM BUTTONS (recap) ── */
.fmodal-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 24px;border-radius:var(--r10);font-family:'Sora',sans-serif;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.fmodal-btn.green{background:var(--g);color:#fff}.fmodal-btn.green:hover{background:var(--gd)}
.fmodal-btn.outline{background:#fff;color:var(--mid);border:1.5px solid rgba(26,32,20,.15)}.fmodal-btn.outline:hover{background:var(--bg);color:var(--ink)}

/* ── RESPONSIVE FORM ── */
@media(max-width:600px){
  .tbox-form .sgrid{grid-template-columns:1fr;gap:8px}
  .tbox-form .sgrid-sm{grid-template-columns:1fr 1fr;gap:6px}
  .tbox-form .sbtn{padding:11px 12px}
  .tbox-form .sbtn-sm{padding:8px 8px}
  .tbox-form .fgr{grid-template-columns:1fr}
  .tbox-form .fbody{padding:12px 20px 18px}
  .tbox-form .fhead{padding:14px 20px 4px}
  .tbox-form .fsub{font-size:14px;padding:14px}
  .tbox-form .emerg-head{margin-bottom:10px}
  .tbox-form .emerg-sub{font-size:16px}
  .tbox-form .emerg-urgenza{gap:6px;margin-bottom:12px}
  .tbox-form .sbtn-urg{padding:12px 14px}
  .tbox-form .fsub-call,.tbox-form .fsub-wa{font-size:14px;padding:14px}
  .tbox-form .fsub-callback{font-size:12px;padding:12px}
  .tbox-form .emerg-divider{margin:12px 0 10px}
}
