.ucp-launcher{position:fixed;right:18px;bottom:18px;z-index:999998;display:none;align-items:center;gap:8px;min-height:48px;padding:11px 18px;border:0;border-radius:999px;background:#F09200;color:#fff;box-shadow:0 12px 34px rgba(0,0,0,.34);font-family:"Montserrat","DM Sans",Arial,sans-serif;font-size:14px;font-weight:800;cursor:pointer;letter-spacing:.2px}.ucp-launcher.is-visible{display:inline-flex}.ucp-launcher:hover{filter:brightness(.95)}.ucp-launcher-icon{width:25px;height:25px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.22);font-size:16px;line-height:1}.ucp-overlay{position:fixed;inset:0;z-index:999999;display:none;align-items:center;justify-content:center;padding:18px;background:rgba(0,0,0,.74);box-sizing:border-box;overflow-y:auto}.ucp-overlay.is-visible{display:flex}.ucp-modal{position:relative;width:min(940px,96vw);max-height:min(90vh,820px);background:#0E1014;box-shadow:0 24px 80px rgba(0,0,0,.48);border-radius:18px;overflow:hidden;font-family:"DM Sans","Inter",Arial,sans-serif;color:#fff;border:1px solid rgba(255,255,255,.08)}.ucp-close{position:absolute;right:12px;top:12px;z-index:3;width:36px;height:36px;border:1px solid rgba(255,255,255,.16);border-radius:50%;background:rgba(14,16,20,.7);color:#fff;font-size:27px;line-height:1;cursor:pointer}.ucp-close:hover{background:rgba(240,146,0,.95)}.ucp-content{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,380px);min-height:420px;max-height:min(90vh,820px);align-items:stretch}.ucp-form-panel{padding:34px 34px 30px;overflow-y:auto;background:radial-gradient(circle at 15% 0%,rgba(240,146,0,.18),transparent 34%),linear-gradient(180deg,#171A21 0%,#0E1014 100%)}.ucp-offer-badge{display:inline-flex;align-items:center;width:fit-content;margin-bottom:13px;padding:7px 12px;border-radius:999px;background:#F09200;color:#fff;font-family:"Montserrat","DM Sans",Arial,sans-serif;font-size:12px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;box-shadow:0 8px 18px rgba(240,146,0,.28)}.ucp-form-panel h2{margin:0 0 8px;padding:0;font-family:"Montserrat","DM Sans",Arial,sans-serif;font-size:clamp(27px,3vw,40px);line-height:.98;background:transparent;color:#fff;font-weight:900;text-transform:uppercase;letter-spacing:.2px;text-shadow:none;border:0}.ucp-subtitle{margin:0 0 10px;font-family:"Montserrat","DM Sans",Arial,sans-serif;font-size:22px;line-height:1.12;color:#F5BC3C;font-weight:900}.ucp-intro{margin:0 0 20px;color:#C9CED6;font-size:14px;line-height:1.45}.ucp-radio-row{display:flex;gap:18px;margin:0 0 12px;font-size:13px;color:#E5E8EC}.ucp-radio-row input,.ucp-check input{accent-color:#F09200}.ucp-field{display:block;margin-bottom:12px}.ucp-field span{display:block;font-size:12px;color:#C9CED6;margin-bottom:5px;font-weight:700}.ucp-field input,.ucp-field textarea{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:12px 13px;font-size:15px;box-sizing:border-box;background:#fff!important;color:#101820!important;-webkit-text-fill-color:#101820!important;caret-color:#101820!important;min-height:44px}.ucp-field input::placeholder,.ucp-field textarea::placeholder{color:#7b838c!important;opacity:1}.ucp-field input:focus,.ucp-field textarea:focus{outline:none;border-color:#F09200;box-shadow:0 0 0 3px rgba(240,146,0,.20)}.ucp-submit{width:100%;border:0;border-radius:14px;background:linear-gradient(135deg,#F5BC3C 0%,#F09200 100%);color:#fff;padding:15px 18px;font-family:"Montserrat","DM Sans",Arial,sans-serif;font-size:15px;font-weight:900;cursor:pointer;letter-spacing:.35px;box-shadow:0 12px 24px rgba(240,146,0,.30)}.ucp-submit:hover{filter:brightness(.98);transform:translateY(-1px)}.ucp-submit:disabled{opacity:.6;cursor:wait;transform:none}.ucp-reassurance{margin:11px 0 0;color:#C9CED6;font-size:12px;line-height:1.35;text-align:center}.ucp-image-panel{position:relative;background:#1F242E;min-height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;border-left:1px solid rgba(255,255,255,.08)}.ucp-image-panel:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,16,20,.10) 0%,rgba(14,16,20,.28) 100%);pointer-events:none}.ucp-image-panel img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}.ucp-image-overlay{position:absolute;left:18px;right:18px;bottom:18px;z-index:2;padding:14px 16px;border-radius:14px;background:rgba(14,16,20,.76);color:#fff;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(4px);font-family:"Montserrat","DM Sans",Arial,sans-serif;font-size:18px;font-weight:900;line-height:1.12;text-transform:uppercase}.ucp-image-overlay span{display:block;color:#F5BC3C}.ucp-placeholder{width:100%;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center;background:#1F242E;color:#fff;font-family:"Montserrat","DM Sans",Arial,sans-serif;font-weight:900;font-size:30px;line-height:1.05;padding:20px;box-sizing:border-box}.ucp-feedback{margin-top:10px;font-size:13px;line-height:1.4}.ucp-feedback.is-success{color:#7DD97E}.ucp-feedback.is-error{color:#FF8A80}.ucp-hp{position:absolute!important;left:-9999px!important;opacity:0!important;height:1px!important;width:1px!important}@media (max-width:860px){.ucp-overlay{padding:8px;align-items:center}.ucp-modal{width:calc(100vw - 16px);max-height:94vh;border-radius:14px}.ucp-content{display:flex;flex-direction:column;min-height:0;max-height:none}.ucp-image-panel{order:-1;min-height:130px;max-height:150px;border-left:0;border-bottom:1px solid rgba(255,255,255,.08)}.ucp-image-panel img{height:150px;object-fit:cover;object-position:center center!important}.ucp-image-overlay{left:12px;right:auto;bottom:12px;max-width:72%;padding:9px 11px;border-radius:11px;font-size:12px}.ucp-form-panel{padding:18px 16px 16px;overflow:visible}.ucp-offer-badge{margin-bottom:9px;padding:6px 10px;font-size:10px}.ucp-form-panel h2{font-size:24px;line-height:1;margin-bottom:6px}.ucp-subtitle{font-size:17px;margin-bottom:8px}.ucp-intro{font-size:13px;margin-bottom:12px}.ucp-radio-row{margin-bottom:9px;gap:14px}.ucp-field{margin-bottom:8px}.ucp-field span{font-size:11px;margin-bottom:3px}.ucp-field input,.ucp-field textarea{padding:9px 10px;font-size:16px;min-height:40px;border-radius:10px}.ucp-field textarea{min-height:54px}.ucp-submit{margin-top:4px;border-radius:12px;padding:13px 14px;font-size:13px}.ucp-reassurance{font-size:11px}.ucp-close{top:7px;right:7px;width:32px;height:32px;font-size:26px}.ucp-launcher{right:12px;bottom:12px;min-height:44px;padding:9px 14px}}@media (max-width:420px){.ucp-image-panel{max-height:118px;min-height:108px}.ucp-image-panel img{height:118px}.ucp-form-panel h2{font-size:21px}.ucp-subtitle{font-size:15px}.ucp-field textarea{display:none}.ucp-field:has(textarea){display:none}}
/* V2.1 : popup toujours entièrement visible, avec scroll interne si petit écran */
.ucp-overlay {
    align-items: center !important;
    padding: 12px !important;
}

.ucp-modal {
    max-height: calc(100vh - 24px) !important;
}

.ucp-content {
    min-height: 0 !important;
    max-height: calc(100vh - 24px) !important;
}

.ucp-form-panel {
    max-height: calc(100vh - 24px) !important;
    overflow-y: auto !important;
    padding-top: 24px !important;
    padding-bottom: 20px !important;
}

.ucp-form-panel h2 {
    font-size: clamp(24px, 2.6vw, 34px) !important;
    line-height: 1.02 !important;
}

.ucp-subtitle {
    font-size: 19px !important;
    margin-bottom: 8px !important;
}

.ucp-intro {
    margin-bottom: 12px !important;
}

.ucp-field {
    margin-bottom: 8px !important;
}

.ucp-field input,
.ucp-field textarea {
    min-height: 38px !important;
    padding: 9px 11px !important;
}

.ucp-field textarea {
    min-height: 48px !important;
}

.ucp-submit {
    padding: 12px 16px !important;
}

.ucp-image-panel {
    max-height: calc(100vh - 24px) !important;
}

@media (min-width: 861px) and (max-height: 780px) {
    .ucp-modal {
        width: min(860px, 96vw) !important;
    }

    .ucp-content {
        grid-template-columns: minmax(0, 1fr) minmax(280px, 330px) !important;
    }

    .ucp-form-panel {
        padding: 22px 26px 18px !important;
    }

    .ucp-offer-badge {
        margin-bottom: 8px !important;
        padding: 5px 10px !important;
        font-size: 10px !important;
    }

    .ucp-form-panel h2 {
        font-size: 26px !important;
    }

    .ucp-subtitle {
        font-size: 17px !important;
    }

    .ucp-intro {
        font-size: 12px !important;
    }

    .ucp-radio-row {
        margin-bottom: 7px !important;
        font-size: 12px !important;
    }

    .ucp-field span {
        font-size: 11px !important;
        margin-bottom: 2px !important;
    }

    .ucp-reassurance {
        margin-top: 7px !important;
    }
}

@media (max-width: 860px) {
    .ucp-modal {
        max-height: calc(100vh - 16px) !important;
    }

    .ucp-form-panel {
        max-height: calc(100vh - 150px) !important;
        overflow-y: auto !important;
    }
}


/* V2.2 : ajout journée d’essai offerte et optimisation mobile */
.ucp-benefits-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: -4px 0 14px;
}

.ucp-benefit-chip {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 999px;
    border: 1px solid rgba(245,188,60,0.35);
    background: rgba(245,188,60,0.10);
    color: #F5BC3C;
    font-family: "Montserrat", "DM Sans", Arial, sans-serif;
    font-size: 11px;
    font-weight: 900;
    line-height: 1.1;
    text-transform: uppercase;
    letter-spacing: .25px;
}

.ucp-benefit-trial {
    border-color: rgba(245,188,60,0.35);
    background: rgba(245,188,60,0.10);
    color: #F5BC3C;
}

.ucp-benefit-plus {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #F5BC3C;
    font-family: "Montserrat", "DM Sans", Arial, sans-serif;
    font-size: 20px;
    font-weight: 900;
    line-height: 1;
    margin: 0 2px;
}

.ucp-image-overlay small {
    display: block;
    margin-top: 5px;
    color: #ffffff;
    font-size: 12px;
    line-height: 1.2;
    font-weight: 800;
    text-transform: none;
}

@media (max-width: 860px) {
    .ucp-image-overlay {
        display: none !important;
    }

    .ucp-image-panel {
        min-height: 86px !important;
        max-height: 96px !important;
    }

    .ucp-image-panel img {
        height: 96px !important;
        object-position: center center !important;
    }

    .ucp-form-panel {
        padding: 14px 14px 14px !important;
        max-height: calc(100vh - 112px) !important;
    }

    .ucp-offer-badge {
        margin-bottom: 7px !important;
        font-size: 9px !important;
        padding: 5px 9px !important;
    }

    .ucp-form-panel h2 {
        font-size: 20px !important;
        line-height: 1.04 !important;
        margin-bottom: 5px !important;
        hyphens: none !important;
        word-break: normal !important;
    }

    .ucp-subtitle {
        font-size: 14px !important;
        margin-bottom: 6px !important;
    }

    .ucp-intro {
        font-size: 12px !important;
        margin-bottom: 8px !important;
        line-height: 1.35 !important;
    }

    .ucp-benefits-row {
        gap: 6px;
        margin: 0 0 9px;
    }

    .ucp-benefit-chip {
        font-size: 9px;
        padding: 6px 8px;
    }

    .ucp-benefit-plus {
        font-size: 16px;
        margin: 0 0px;
    }

    .ucp-radio-row {
        font-size: 12px !important;
    }

    .ucp-field {
        margin-bottom: 6px !important;
    }

    .ucp-field input,
    .ucp-field textarea {
        min-height: 34px !important;
        padding: 7px 9px !important;
    }

    .ucp-submit {
        padding: 11px 12px !important;
    }

    .ucp-reassurance {
        font-size: 10px !important;
        margin-top: 6px !important;
    }
}

@media (max-width: 420px) {
    .ucp-image-panel {
        min-height: 74px !important;
        max-height: 82px !important;
    }

    .ucp-image-panel img {
        height: 82px !important;
    }

    .ucp-form-panel h2 {
        font-size: 19px !important;
    }
}


/* V2.4 : bloc unique plus clair pour les avantages */
.ucp-benefits-box {
    margin: 2px 0 14px;
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px solid rgba(245,188,60,0.24);
    background: linear-gradient(180deg, rgba(245,188,60,0.10) 0%, rgba(245,188,60,0.04) 100%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.ucp-benefits-title {
    margin-bottom: 8px;
    color: #ffffff;
    font-family: "Montserrat", "DM Sans", Arial, sans-serif;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .5px;
}

.ucp-benefits-box .ucp-benefits-row {
    margin: 0;
    align-items: center;
}

@media (max-width: 860px) {
    .ucp-benefits-box {
        margin: 0 0 10px;
        padding: 10px 10px;
        border-radius: 14px;
    }

    .ucp-benefits-title {
        margin-bottom: 6px;
        font-size: 10px;
    }

    .ucp-benefits-box .ucp-benefits-row {
        gap: 5px;
    }
}


/* V2.5 : sur smartphone on masque complètement l’image pour privilégier la conversion */
@media (max-width: 860px) {
    .ucp-content {
        grid-template-columns: 1fr !important;
    }

    .ucp-image-panel {
        display: none !important;
    }

    .ucp-form-panel {
        max-height: calc(100vh - 24px) !important;
        padding: 16px 14px 16px !important;
    }

    .ucp-modal {
        width: min(96vw, 520px) !important;
    }
}

@media (max-width: 420px) {
    .ucp-form-panel {
        padding: 14px 12px 14px !important;
    }
}


/* V2.6 : desktop et laptop en dimensions adaptatives en pourcentage */
.ucp-overlay {
    padding: 2vh 2vw !important;
    overflow: hidden !important;
}

.ucp-modal {
    width: min(92vw, 1120px) !important;
    height: min(88vh, 760px) !important;
    max-height: min(88vh, 760px) !important;
}

.ucp-content {
    grid-template-columns: minmax(0, 58%) minmax(0, 42%) !important;
    height: 100% !important;
    min-height: 0 !important;
    max-height: 100% !important;
}

.ucp-form-panel,
.ucp-image-panel {
    min-height: 0 !important;
    height: 100% !important;
}

.ucp-form-panel {
    padding: clamp(18px, 2.2vw, 34px) clamp(18px, 2.4vw, 34px) clamp(18px, 2vw, 28px) !important;
    overflow-y: auto !important;
}

.ucp-form-panel h2 {
    font-size: clamp(24px, 2.8vw, 40px) !important;
}

.ucp-subtitle {
    font-size: clamp(18px, 1.6vw, 22px) !important;
}

.ucp-intro {
    margin-bottom: 14px !important;
}

.ucp-image-panel img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
}

.ucp-image-overlay {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    padding: 12px 14px !important;
    font-size: clamp(15px, 1.35vw, 18px) !important;
}

.ucp-image-overlay small {
    font-size: clamp(11px, 1vw, 13px) !important;
}

@media (max-width: 1100px) {
    .ucp-modal {
        width: 94vw !important;
        height: 86vh !important;
        max-height: 86vh !important;
    }

    .ucp-content {
        grid-template-columns: minmax(0, 56%) minmax(0, 44%) !important;
    }
}

@media (max-height: 820px) and (min-width: 861px) {
    .ucp-modal {
        height: 84vh !important;
        max-height: 84vh !important;
    }

    .ucp-offer-badge {
        margin-bottom: 8px !important;
        padding: 5px 10px !important;
        font-size: 10px !important;
    }

    .ucp-form-panel h2 {
        font-size: clamp(22px, 2.4vw, 32px) !important;
        margin-bottom: 6px !important;
    }

    .ucp-subtitle {
        font-size: 17px !important;
        margin-bottom: 6px !important;
    }

    .ucp-intro {
        font-size: 12px !important;
        line-height: 1.35 !important;
        margin-bottom: 10px !important;
    }

    .ucp-benefits-box {
        margin-bottom: 10px !important;
        padding: 10px 12px !important;
    }

    .ucp-benefits-title {
        font-size: 11px !important;
        margin-bottom: 6px !important;
    }

    .ucp-benefit-chip {
        font-size: 10px !important;
        padding: 6px 9px !important;
    }

    .ucp-benefit-plus {
        font-size: 18px !important;
    }

    .ucp-radio-row {
        margin-bottom: 8px !important;
        font-size: 12px !important;
        gap: 14px !important;
    }

    .ucp-field {
        margin-bottom: 8px !important;
    }

    .ucp-field span {
        font-size: 11px !important;
        margin-bottom: 3px !important;
    }

    .ucp-field input,
    .ucp-field textarea {
        min-height: 38px !important;
        padding: 8px 10px !important;
    }

    .ucp-submit {
        padding: 12px 16px !important;
    }

    .ucp-reassurance {
        margin-top: 7px !important;
        font-size: 11px !important;
    }

    .ucp-image-overlay {
        padding: 10px 12px !important;
    }
}

/* conserver le masquage complet de l’image sur smartphone */
@media (max-width: 860px) {
    .ucp-content {
        display: block !important;
    }

    .ucp-image-panel {
        display: none !important;
    }

    .ucp-modal {
        width: min(96vw, 520px) !important;
        height: auto !important;
        max-height: calc(100vh - 16px) !important;
    }

    .ucp-form-panel {
        max-height: calc(100vh - 32px) !important;
        height: auto !important;
    }
}
