/* AutoAssur Leads — Frontend Form CSS v2.2 */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;600;700&family=Fraunces:wght@700;800&display=swap');
*,.aal-form-wrap *{box-sizing:border-box;}

/* ── TRIGGER ── */
.aal-trigger-wrap{display:inline-flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:420px;margin:0 auto;text-align:center;}
.aal-trigger-btn{display:inline-flex!important;align-items:center!important;gap:10px!important;background:linear-gradient(135deg,#1a2e25,#2d6a4f)!important;color:#fff!important;padding:18px 36px!important;border-radius:14px!important;font-family:'DM Sans',sans-serif!important;font-weight:700!important;font-size:1.05rem!important;border:none!important;cursor:pointer!important;-webkit-appearance:none!important;transition:transform .2s,box-shadow .2s!important;box-shadow:0 8px 28px rgba(26,46,37,.35)!important;width:100%!important;justify-content:center!important;}
.aal-trigger-btn:hover{transform:translateY(-2px)!important;box-shadow:0 14px 40px rgba(26,46,37,.45)!important;color:#fff!important;background:linear-gradient(135deg,#2d6a4f,#52b788)!important;}
.aal-trigger-arrow{margin-left:auto!important;opacity:.7!important;transition:transform .2s!important;}
.aal-trigger-btn:hover .aal-trigger-arrow{transform:translateX(4px)!important;}
.aal-trigger-trust{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;}
.aal-trigger-trust span{font-size:.73rem;color:#6b8275;font-weight:600;font-family:'DM Sans',system-ui,sans-serif;}
.aal-trigger-trust span::before{content:'✓ ';}

/* ── OVERLAY ── */
.aal-overlay{position:fixed;inset:0;background:rgba(8,16,11,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:99998;display:none;transition:opacity .3s;}

/* ── MODAL ── */
.aal-form-wrap.aal-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:99999;width:min(600px,96vw);max-height:93vh;overflow-y:auto;display:none;flex-direction:column;}
/* ── INLINE ── */
.aal-form-wrap.aal-inline{width:100%;max-width:640px;margin:0 auto;display:flex;flex-direction:column;}

/* ── SHARED FORM ── */
.aal-form-wrap{border-radius:20px;background:#fff;box-shadow:0 32px 80px rgba(0,0,0,.25);font-family:'DM Sans',system-ui,sans-serif;}
.aal-form-wrap::-webkit-scrollbar{width:3px;}
.aal-form-wrap::-webkit-scrollbar-thumb{background:#dde8e3;border-radius:3px;}

/* ── HEAD ── */
.aal-form-head{background:linear-gradient(135deg,#1a2e25 0%,#2d6a4f 100%);padding:28px 30px 24px;border-radius:20px 20px 0 0;position:relative;}
.aal-close-btn{position:absolute!important;top:14px!important;right:14px!important;width:34px!important;height:34px!important;border-radius:50%!important;background:rgba(255,255,255,.14)!important;border:none!important;cursor:pointer!important;color:#fff!important;font-size:1rem!important;display:flex!important;align-items:center!important;justify-content:center!important;-webkit-appearance:none!important;transition:background .15s!important;line-height:1!important;}
.aal-close-btn:hover{background:rgba(255,255,255,.26)!important;}
.aal-form-head h2{font-family:'Fraunces',Georgia,serif;font-size:1.3rem;font-weight:800;color:#fff;margin:0 0 4px;}
.aal-form-head p{color:rgba(255,255,255,.6);font-size:.82rem;margin:0;}
.aal-trust{display:flex;gap:18px;margin-top:15px;flex-wrap:wrap;}
.aal-ti{display:flex;align-items:center;gap:5px;color:rgba(255,255,255,.75);font-size:.72rem;font-weight:600;}
.aal-ti::before{content:'';width:5px;height:5px;background:#52b788;border-radius:50%;flex-shrink:0;}

/* ── PROGRESS ── */
.aal-prog{padding:20px 30px 0;background:#fff;}
.aal-steps{display:flex;align-items:flex-start;margin-bottom:10px;}
.aal-step-ind{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;}
.aal-step-ind:not(:last-child)::after{content:'';position:absolute;top:11px;left:calc(50% + 14px);right:calc(-50% + 14px);height:2px;background:#f0f4f2;transition:background .3s;}
.aal-step-ind.done:not(:last-child)::after{background:#52b788;}
.aal-step-circle{width:24px;height:24px;border-radius:50%;background:#f0f4f2;border:2px solid #dde8e3;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:800;color:#6b8275;z-index:1;transition:.25s;}
.aal-step-ind.active .aal-step-circle{background:#2d6a4f;border-color:#2d6a4f;color:#fff;}
.aal-step-ind.done .aal-step-circle{background:#52b788;border-color:#52b788;color:#fff;}
.aal-step-lbl{font-size:.6rem;font-weight:700;color:#c9d8d1;text-transform:uppercase;letter-spacing:.05em;text-align:center;transition:color .25s;}
.aal-step-ind.active .aal-step-lbl,.aal-step-ind.done .aal-step-lbl{color:#2d6a4f;}
.aal-bar-wrap{height:3px;background:#f0f4f2;border-radius:3px;margin-bottom:2px;}
.aal-bar{height:100%;background:linear-gradient(90deg,#2d6a4f,#52b788);border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1);}

/* ── BODY ── */
.aal-form-body{padding:24px 30px 28px;}
.aal-step-panel{display:none;}
.aal-step-panel.active{display:block;}
.aal-step-title{font-family:'Fraunces',Georgia,serif;font-size:1.15rem;font-weight:700;color:#1a2e25;margin-bottom:18px;}

/* ── GRID ── */
.aal-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.aal-field{display:flex;flex-direction:column;gap:5px;}
.aal-field-full{grid-column:1/-1;}
.aal-label{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#1a2e25;}
.aal-hint{font-size:.7rem;color:#6b8275;margin-top:2px;line-height:1.4;}
.aal-err{font-size:.68rem;color:#e53e3e;display:none;margin-top:1px;}

/* ── INPUTS — visible states ── */
.aal-input{width:100%;padding:12px 14px;background:#f8f7f4;border:1.5px solid #dde8e3;border-radius:10px;font-family:'DM Sans',system-ui,sans-serif;font-size:.9rem;color:#1a2e25;transition:border-color .2s,background .2s,box-shadow .2s;-webkit-appearance:none;appearance:none;}
.aal-input::placeholder{color:#9aaba4;}
.aal-input:hover{background:#f2f0eb;border-color:#b7cfc6;}
.aal-input:focus{outline:none;border-color:#2d6a4f;background:#fff;box-shadow:0 0 0 3px rgba(45,106,79,.1);}
.aal-input-err{border-color:#e53e3e!important;background:#fff5f5!important;}

/* ── SELECT — fully visible ── */
select.aal-input{-webkit-appearance:auto!important;appearance:auto!important;background:#f8f7f4;color:#1a2e25;cursor:pointer;}
select.aal-input:hover{background:#f2f0eb;}
select.aal-input option{color:#1a2e25;background:#fff;}

/* ── PHONE WITH INDICATIF ── */
.aal-phone-wrap{display:flex;gap:7px;align-items:flex-start;}
.aal-phone-num{flex:1;min-width:0;}

/* Custom indicatif dropdown */
.aal-ind-wrap{position:relative;flex-shrink:0;}
.aal-ind-btn{display:flex;align-items:center;gap:4px;padding:11px 8px;background:#f8f7f4;border:1.5px solid #dde8e3;border-radius:10px;cursor:pointer;font-family:'DM Sans',system-ui,sans-serif;font-size:.82rem;color:#1a2e25;white-space:nowrap;transition:border-color .15s,background .15s;-webkit-appearance:none;min-width:80px;}
.aal-ind-btn:hover,.aal-ind-btn.open{border-color:#2d6a4f;background:#fff;}
.aal-ind-flag{font-size:1rem;line-height:1;}
.aal-ind-code{font-weight:700;font-size:.8rem;}
.aal-ind-arrow{font-size:.55rem;color:#6b8275;margin-left:1px;transition:transform .2s;}
.aal-ind-btn.open .aal-ind-arrow{transform:rotate(180deg);}

/* Dropdown panel */
.aal-ind-dropdown{position:absolute;top:calc(100% + 5px);left:0;z-index:9999;background:#fff;border:1.5px solid #dde8e3;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);width:260px;overflow:hidden;}
.aal-ind-search-wrap{padding:10px 10px 8px;border-bottom:1px solid #f0f4f2;position:sticky;top:0;background:#fff;z-index:1;}
.aal-ind-search{width:100%;padding:8px 11px;border:1.5px solid #dde8e3;border-radius:8px;font-family:'DM Sans',system-ui,sans-serif;font-size:.82rem;color:#1a2e25;outline:none;}
.aal-ind-search:focus{border-color:#2d6a4f;}
.aal-ind-list{max-height:220px;overflow-y:auto;padding:4px 0;}
.aal-ind-list::-webkit-scrollbar{width:3px;}
.aal-ind-list::-webkit-scrollbar-thumb{background:#dde8e3;border-radius:3px;}
.aal-ind-item{padding:9px 14px;font-size:.82rem;color:#1a2e25;cursor:pointer;transition:background .1s;display:flex;align-items:center;gap:8px;}
.aal-ind-item:hover{background:#f0f9f4;}
.aal-ind-sel{background:#e8f5ee;color:#2d6a4f;font-weight:700;}

/* ── ADDRESS ── */
.aal-addr-input{background:#f8f7f4!important;}
.aal-addr-hint{font-size:.7rem;color:#2d6a4f;margin-top:4px;font-weight:600;}
.aal-addr-hint a{color:#2d6a4f;text-decoration:underline;}

/* ── CHIPS ── */
.aal-chips{display:flex;gap:8px;flex-wrap:wrap;}
.aal-chip{flex:1;min-width:72px;padding:10px 6px;border:1.5px solid #dde8e3;border-radius:10px;background:#f8f7f4;font-family:'DM Sans',system-ui,sans-serif;font-size:.8rem;font-weight:600;color:#4a5e55;cursor:pointer;transition:.15s;text-align:center;-webkit-appearance:none!important;appearance:none!important;}
.aal-chip:hover{border-color:#2d6a4f;background:#ecf7f1;color:#2d6a4f;}
.aal-chip-sel{border-color:#2d6a4f!important;background:#e8f5ee!important;color:#2d6a4f!important;}

/* ── SLIDER ── */
.aal-bonus-display{background:linear-gradient(135deg,#f0f9f4,#e8f5ee);border:1.5px solid #b7ddc8;border-radius:12px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;transition:border-color .3s,background .3s;}
.aal-bonus-val{font-family:'Fraunces',Georgia,serif;font-size:1.6rem;font-weight:800;color:#2d6a4f;line-height:1;transition:color .25s;}
.aal-bonus-desc{font-size:.75rem;color:#4a5e55;font-weight:600;text-align:right;line-height:1.4;}
.aal-slider-wrap{position:relative;padding:4px 0;}
.aal-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:6px;outline:none;cursor:pointer;background:#dde8e3;}
.aal-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:#2d6a4f;border:3px solid #fff;box-shadow:0 2px 10px rgba(45,106,79,.4);cursor:pointer;transition:transform .15s;}
.aal-slider::-webkit-slider-thumb:active{transform:scale(1.15);}
.aal-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#2d6a4f;border:3px solid #fff;cursor:pointer;}
.aal-slider-zero{display:none;}
.aal-slider-base{position:absolute;top:50%;transform:translateY(-50%);width:3px;height:18px;background:#3b82f6;opacity:.5;border-radius:2px;pointer-events:none;}
.aal-slider-labels{display:flex;justify-content:space-between;font-size:.6rem;color:#6b8275;margin-top:6px;}
.aal-slider-labels span:nth-child(2){color:#3b82f6;font-weight:700;}

/* ── INSURERS ── */
.aal-insurers{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.aal-insurer{padding:10px 12px;border:1.5px solid #dde8e3;border-radius:10px;background:#f8f7f4;font-family:'DM Sans',system-ui,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:9px;color:#1a2e25;transition:.15s;-webkit-appearance:none!important;appearance:none!important;text-align:left;}
.aal-insurer:hover{background:#ecf7f1;border-color:#b7cfc6;}
.aal-ins-sel{border-color:#2d6a4f!important;background:#e8f5ee!important;}
.aal-ins-logo{width:54px;height:30px;background:#fff;border-radius:6px;border:1px solid #eef2f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:4px;}
.aal-ins-logo img{max-width:46px;max-height:22px;object-fit:contain;display:block;}

/* ── NAV ── */
.aal-form-footer{display:flex;gap:10px;margin-top:22px;}
.aal-back-btn{padding:13px 20px!important;border-radius:10px!important;border:1.5px solid #dde8e3!important;background:#fff!important;font-family:'DM Sans',system-ui,sans-serif!important;font-size:.88rem!important;font-weight:700!important;color:#6b8275!important;cursor:pointer!important;-webkit-appearance:none!important;transition:.2s!important;}
.aal-back-btn:hover{border-color:#2d6a4f!important;color:#2d6a4f!important;background:#f0f9f4!important;}
.aal-next-btn,.aal-submit-btn{flex:1!important;padding:14px!important;border-radius:10px!important;border:none!important;background:linear-gradient(135deg,#2d6a4f,#52b788)!important;font-family:'DM Sans',system-ui,sans-serif!important;font-size:.92rem!important;font-weight:700!important;color:#fff!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;-webkit-appearance:none!important;transition:transform .2s,box-shadow .2s!important;}
.aal-next-btn:hover,.aal-submit-btn:hover{transform:translateY(-1px)!important;box-shadow:0 6px 20px rgba(45,106,79,.35)!important;}
.aal-next-btn:disabled,.aal-submit-btn:disabled{opacity:.5!important;cursor:not-allowed!important;transform:none!important;}

/* ── SUCCESS ── */
.aal-success{display:none;padding:52px 30px;text-align:center;}
.aal-success-icon{width:76px;height:76px;background:linear-gradient(135deg,#2d6a4f,#52b788);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.2rem;margin:0 auto 22px;}
.aal-success h3{font-family:'Fraunces',Georgia,serif;font-size:1.45rem;font-weight:800;color:#1a2e25;margin-bottom:10px;}
.aal-success p{color:#6b8275;font-size:.9rem;line-height:1.75;max-width:360px;margin:0 auto 26px;}
.aal-success-close{padding:13px 36px!important;border-radius:10px!important;background:#2d6a4f!important;color:#fff!important;border:none!important;font-family:'DM Sans',system-ui,sans-serif!important;font-size:.92rem!important;font-weight:700!important;cursor:pointer!important;-webkit-appearance:none!important;transition:background .2s!important;}
.aal-success-close:hover{background:#1a2e25!important;}

@keyframes aal-spin{to{transform:rotate(360deg);}}

@media(max-width:500px){
  .aal-grid{grid-template-columns:1fr!important;}
  .aal-field-full{grid-column:1!important;}
  .aal-form-head,.aal-form-body,.aal-prog{padding-left:18px!important;padding-right:18px!important;}
  .aal-insurers{grid-template-columns:1fr!important;}
}
@keyframes aal-spin{to{transform:rotate(360deg);}}

/* ── Unité CV / kWh ── */
.aal-input-with-unit {
    display: flex; gap: 8px; align-items: stretch;
}
.aal-input-with-unit .aal-input {
    flex: 1; min-width: 0;
}
.aal-unit-select {
    flex-shrink: 0; width: 68px;
    padding: 0 6px;
    border: 2px solid #dde8e3; border-radius: 14px;
    background: #f0f7f4; color: #2d6a4f;
    font-size: .82rem; font-weight: 700;
    cursor: pointer; outline: none;
    appearance: none; -webkit-appearance: none;
    text-align: center;
    transition: border-color .2s;
}
.aal-unit-select:focus { border-color: #2d6a4f; }
