/* =============================================
   FORMULAIRE NUISIBLES PRO v6 — Design clair PestAvenue
   ============================================= */

#tcf-wrapper,
#tcf-wrapper *,
#tcf-wrapper *::before,
#tcf-wrapper *::after {
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: inherit !important;
}

#tcf-wrapper {
    width: 100% !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    box-shadow: 0 8px 40px rgba(26,75,140,0.13), 0 2px 8px rgba(0,0,0,0.06) !important;
}

#tcf-wrapper .tcf-grid {
    display: grid !important;
    grid-template-columns: 1.25fr 1fr !important;
    align-items: stretch !important;
}

/* ==============================================
   COLONNE GAUCHE — blanc cassé propre
   ============================================== */
#tcf-wrapper .tcf-col-left {
    background: #ffffff !important;
    padding: 32px 36px 36px !important;
    position: relative !important;
    overflow: hidden !important;
    border-right: 1px solid #e8edf8 !important;
}

/* Bandeau rappel */
#tcf-wrapper .tcf-recall-banner {
    background: linear-gradient(135deg, #eef4ff 0%, #f0faff 100%) !important;
    border: 1px solid #c7d9ff !important;
    color: #1a4b8c !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-align: center !important;
    padding: 11px 16px !important;
    border-radius: 10px !important;
    margin-bottom: 24px !important;
}

/* Header form */
#tcf-wrapper .tcf-form-header { margin-bottom: 22px !important; }

#tcf-wrapper .tcf-form-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: #eef4ff !important;
    border: 1px solid #c7d9ff !important;
    color: #1a4b8c !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    padding: 5px 14px !important;
    border-radius: 50px !important;
    margin-bottom: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
}

#tcf-wrapper .tcf-form-title {
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #0f2d5e !important;
    line-height: 1.2 !important;
    margin-bottom: 6px !important;
}

#tcf-wrapper .tcf-form-sub {
    font-size: 14px !important;
    color: #5a6a8a !important;
    font-weight: 400 !important;
}

/* Honeypot */
#tcf-wrapper .tcf-hp {
    position: absolute !important;
    left: -9999px !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Grille 2 cols */
#tcf-wrapper .tcf-row-2 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
}
#tcf-wrapper .tcf-mb     { margin-bottom: 12px !important; }
#tcf-wrapper .tcf-field-block  { margin-bottom: 12px !important; }
#tcf-wrapper .tcf-select-block { display: block !important; }

/* Labels petits */
#tcf-wrapper .tcf-label-sm {
    display: block !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #3a5080 !important;
    margin-bottom: 8px !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
}

/* ============================================
   BOUTONS PROFIL PARTICULIER / PRO
   ============================================ */
#tcf-wrapper .tcf-radio-pill { display:flex !important; cursor:pointer !important; }
#tcf-wrapper .tcf-radio-pill input[type="radio"] { display:none !important; }

#tcf-wrapper .tcf-radio-pill span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    width: 100% !important;
    padding: 12px 10px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #6b7fa8 !important;
    background: #f5f8ff !important;
    border: 2px solid #dce6f7 !important;
    border-radius: 10px !important;
    transition: all .22s ease !important;
    cursor: pointer !important;
}

#tcf-wrapper .tcf-radio-pill input[type="radio"]:checked + span {
    color: #fff !important;
    background: linear-gradient(135deg, #1a4b8c 0%, #2563c4 100%) !important;
    border-color: #1a4b8c !important;
    box-shadow: 0 4px 16px rgba(26,75,140,0.28) !important;
}

#tcf-wrapper .tcf-radio-pill:hover span {
    border-color: #1a4b8c !important;
    color: #1a4b8c !important;
    background: #eef4ff !important;
}

/* ============================================
   RADIOS OUI / PAS SÛR / NON
   ============================================ */
#tcf-wrapper .tcf-radio-row { display:flex !important; flex-wrap:wrap !important; gap:8px !important; }
#tcf-wrapper .tcf-radio-check { display:flex !important; cursor:pointer !important; }
#tcf-wrapper .tcf-radio-check input[type="radio"] { display:none !important; }

#tcf-wrapper .tcf-radio-check span {
    display: inline-flex !important;
    align-items: center !important;
    padding: 9px 18px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #6b7fa8 !important;
    background: #f5f8ff !important;
    border: 2px solid #dce6f7 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all .18s ease !important;
}

#tcf-wrapper .tcf-radio-check input[type="radio"]:checked + span {
    color: #fff !important;
    background: linear-gradient(135deg, #1a73e8 0%, #2563c4 100%) !important;
    border-color: #1a73e8 !important;
    box-shadow: 0 3px 12px rgba(26,115,232,0.3) !important;
}

#tcf-wrapper .tcf-radio-check:hover span {
    border-color: #1a73e8 !important;
    color: #1a73e8 !important;
}

/* ============================================
   INPUTS — smooth & clean
   ============================================ */
#tcf-wrapper .tcf-field-wrap { position: relative !important; }

#tcf-wrapper .tcf-ico {
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 15px !important;
    pointer-events: none !important;
    z-index: 2 !important;
    opacity: 0.5 !important;
    transition: opacity .2s !important;
}

#tcf-wrapper .tcf-field-wrap:focus-within .tcf-ico {
    opacity: 0.85 !important;
}

#tcf-wrapper .tcf-input {
    display: block !important;
    width: 100% !important;
    padding: 13px 14px 13px 42px !important;
    font-size: 14px !important;
    color: #1a2a4a !important;
    background: #f8faff !important;
    border: 2px solid #dce6f7 !important;
    border-radius: 10px !important;
    outline: none !important;
    transition: border-color .22s ease, box-shadow .22s ease, background .22s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    line-height: 1.4 !important;
}

#tcf-wrapper .tcf-input::placeholder {
    color: #a0aec0 !important;
    font-size: 13.5px !important;
}

#tcf-wrapper .tcf-input:focus {
    border-color: #1a73e8 !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(26,115,232,0.12) !important;
}

#tcf-wrapper .tcf-input:valid:not(:placeholder-shown) {
    border-color: #34a853 !important;
    background: #fff !important;
}

/* Selects sans icone gauche */
#tcf-wrapper .tcf-select-noi { padding-left: 14px !important; }
#tcf-wrapper .tcf-select { cursor:pointer !important; color:#1a2a4a !important; padding-right:36px !important; }
#tcf-wrapper .tcf-select option { background:#fff !important; color:#1a2a4a !important; }
#tcf-wrapper .tcf-caret {
    position:absolute !important; right:13px !important; top:50% !important;
    transform:translateY(-50%) !important; font-size:10px !important;
    color:#6b7fa8 !important; pointer-events:none !important; z-index:2 !important;
}

/* Fichier */
#tcf-wrapper .tcf-file-zone {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    width: 100% !important;
    padding: 13px !important;
    font-size: 13.5px !important;
    color: #6b7fa8 !important;
    background: #f5f8ff !important;
    border: 2px dashed #c7d9ff !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: all .2s ease !important;
}
#tcf-wrapper .tcf-file-zone:hover {
    border-color: #1a73e8 !important;
    color: #1a73e8 !important;
    background: #eef4ff !important;
}
#tcf-wrapper .tcf-file-zone em { font-style:normal !important; opacity:0.6 !important; font-size:12px !important; }

/* CGU */
#tcf-wrapper .tcf-cgu-label {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    cursor: pointer !important;
    padding: 11px 14px !important;
    background: #f0faff !important;
    border: 1px solid #c7e8ff !important;
    border-radius: 8px !important;
    transition: background .18s !important;
}
#tcf-wrapper .tcf-cgu-label:hover { background: #e3f4ff !important; }
#tcf-wrapper .tcf-cgu-label input[type="checkbox"] {
    width: 17px !important; height: 17px !important; min-width: 17px !important;
    margin-top: 2px !important; accent-color: #1a73e8 !important;
    cursor: pointer !important; padding: 0 !important;
}
#tcf-wrapper .tcf-cgu-label span {
    font-size: 13px !important; color: #3a5080 !important; line-height: 1.5 !important;
}
#tcf-wrapper .tcf-cgu-label a { color: #1a73e8 !important; text-decoration: underline !important; font-weight: 600 !important; }

/* Erreur */
#tcf-wrapper #tcf-error {
    display: none !important;
    font-size: 13.5px !important;
    color: #c0392b !important;
    background: #fff5f5 !important;
    border: 1.5px solid #ffb3b3 !important;
    border-radius: 8px !important;
    padding: 11px 14px !important;
    margin-bottom: 12px !important;
    line-height: 1.5 !important;
}

/* Bouton submit */
#tcf-wrapper .tcf-btn-submit {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 16px 24px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    color: #fff !important;
    background: linear-gradient(135deg, #1d8348 0%, #27ae60 100%) !important;
    border: none !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all .22s ease !important;
    box-shadow: 0 4px 18px rgba(29,131,72,0.35) !important;
    margin-bottom: 10px !important;
    line-height: 1 !important;
}
#tcf-wrapper .tcf-btn-submit:hover {
    background: linear-gradient(135deg, #27ae60 0%, #2ecc71 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 7px 24px rgba(29,131,72,0.45) !important;
}
#tcf-wrapper .tcf-btn-submit:active { transform: translateY(0) !important; }
#tcf-wrapper .tcf-btn-submit:disabled { opacity:.6 !important; cursor:not-allowed !important; transform:none !important; }

#tcf-wrapper .tcf-btn-spin {
    display: none !important;
    width: 16px !important; height: 16px !important;
    border: 2px solid rgba(255,255,255,.35) !important;
    border-top-color: #fff !important;
    border-radius: 50% !important;
    animation: tcf-spin .65s linear infinite !important;
    flex-shrink: 0 !important;
}
#tcf-wrapper .tcf-btn-submit.tcf-loading .tcf-btn-label { display:none !important; }
#tcf-wrapper .tcf-btn-submit.tcf-loading .tcf-btn-spin  { display:inline-block !important; }
@keyframes tcf-spin { to { transform:rotate(360deg); } }

#tcf-wrapper .tcf-legal {
    font-size: 12px !important;
    color: #a0aec0 !important;
    text-align: center !important;
    line-height: 1.5 !important;
}

/* Succès */
#tcf-wrapper #tcf-success {
    display: none !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 60px 30px !important;
    min-height: 400px !important;
}
#tcf-wrapper #tcf-success.tcf-visible {
    display: flex !important;
    animation: tcf-fadein .4s ease !important;
}
#tcf-wrapper .tcf-success-check {
    width: 70px !important; height: 70px !important;
    background: linear-gradient(135deg, #1d8348, #27ae60) !important;
    color: #fff !important; font-size: 32px !important;
    border-radius: 50% !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    margin-bottom: 20px !important;
    box-shadow: 0 8px 24px rgba(29,131,72,0.4) !important;
}
#tcf-wrapper #tcf-success h3 {
    font-size: 26px !important; font-weight: 800 !important;
    color: #0f2d5e !important; margin-bottom: 12px !important;
}
#tcf-wrapper #tcf-success-msg {
    font-size: 15px !important; color: #4a5a7a !important; line-height: 1.7 !important;
}

@keyframes tcf-fadein {
    from { opacity:0; transform:translateY(12px); }
    to   { opacity:1; transform:translateY(0); }
}

/* ==============================================
   COLONNE DROITE — bleu clair élégant
   ============================================== */
#tcf-wrapper .tcf-col-right {
    background: linear-gradient(160deg, #eef4ff 0%, #f0faff 100%) !important;
    padding: 32px 28px !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 100% !important;
}

#tcf-wrapper .tcf-right-header {
    margin-bottom: 22px !important;
    padding-bottom: 18px !important;
    border-bottom: 2px solid #dce6f7 !important;
}

#tcf-wrapper .tcf-right-badge {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: #0f2d5e !important;
    margin-bottom: 6px !important;
    display: block !important;
}

#tcf-wrapper .tcf-right-horaires {
    font-size: 14px !important;
    color: #4a5a7a !important;
    line-height: 1.6 !important;
    font-weight: 500 !important;
}

/* Bouton CTA unique */
#tcf-wrapper .tcf-cta-wrap {
    margin-bottom: 20px !important;
}

#tcf-wrapper .tcf-cta-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 16px 20px !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    color: #0f2d5e !important;
    background: linear-gradient(135deg, #00c8ff 0%, #1a73e8 100%) !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    transition: all .22s ease !important;
    box-shadow: 0 5px 22px rgba(26,115,232,0.35) !important;
}
#tcf-wrapper .tcf-cta-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 9px 30px rgba(26,115,232,0.45) !important;
    color: #fff !important;
}

/* Shortcode wrapper (popup buttons etc.) */
#tcf-wrapper .tcf-shortcode-btn a,
#tcf-wrapper .tcf-shortcode-btn button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    padding: 16px 20px !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    transition: all .22s ease !important;
}

#tcf-wrapper .tcf-divider {
    height: 1px !important;
    background: #dce6f7 !important;
    margin: 6px 0 18px !important;
}

/* Features */
#tcf-wrapper .tcf-features {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    gap: 0 !important;
}

#tcf-wrapper .tcf-feature {
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
    padding: 13px 0 !important;
    border-bottom: 1px solid #e4ecf8 !important;
}
#tcf-wrapper .tcf-feature:last-child { border-bottom: none !important; }

#tcf-wrapper .tcf-feat-ico {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important; height: 44px !important;
    background: #fff !important;
    border: 1.5px solid #dce6f7 !important;
    border-radius: 10px !important;
    font-size: 20px !important;
    flex-shrink: 0 !important;
    box-shadow: 0 2px 8px rgba(26,75,140,0.07) !important;
}

#tcf-wrapper .tcf-feature strong {
    display: block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #0f2d5e !important;
    line-height: 1.3 !important;
    margin-bottom: 3px !important;
}
#tcf-wrapper .tcf-feature p {
    font-size: 13px !important;
    color: #6b7fa8 !important;
    line-height: 1.4 !important;
}

/* ==============================================
   RESPONSIVE
   ============================================== */
@media (max-width:860px) {
    #tcf-wrapper .tcf-grid { grid-template-columns: 1fr !important; }
    #tcf-wrapper .tcf-col-right {
        border-top: 1px solid #dce6f7 !important;
    }
    #tcf-wrapper .tcf-features {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
    }
    #tcf-wrapper .tcf-feature { border-bottom: none !important; }
}
@media (max-width:520px) {
    #tcf-wrapper .tcf-col-left  { padding: 22px 18px !important; }
    #tcf-wrapper .tcf-col-right { padding: 22px 18px !important; }
    #tcf-wrapper .tcf-row-2     { grid-template-columns: 1fr !important; }
    #tcf-wrapper .tcf-form-title { font-size: 23px !important; }
    #tcf-wrapper .tcf-features   { grid-template-columns: 1fr !important; }
}


/* =============================================
   Compatibilite shortcode popup v6.1
   Les memes styles sont appliques via .tcf-wrapper
   pour eviter les conflits d'IDs entre bas de page et popup.
   ============================================= */
/* =============================================
   FORMULAIRE NUISIBLES PRO v6 — Design clair PestAvenue
   ============================================= */

.tcf-wrapper,
.tcf-wrapper *,
.tcf-wrapper *::before,
.tcf-wrapper *::after {
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: inherit !important;
}

.tcf-wrapper {
    width: 100% !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    box-shadow: 0 8px 40px rgba(26,75,140,0.13), 0 2px 8px rgba(0,0,0,0.06) !important;
}

.tcf-wrapper .tcf-grid {
    display: grid !important;
    grid-template-columns: 1.25fr 1fr !important;
    align-items: stretch !important;
}

/* ==============================================
   COLONNE GAUCHE — blanc cassé propre
   ============================================== */
.tcf-wrapper .tcf-col-left {
    background: #ffffff !important;
    padding: 32px 36px 36px !important;
    position: relative !important;
    overflow: hidden !important;
    border-right: 1px solid #e8edf8 !important;
}

/* Bandeau rappel */
.tcf-wrapper .tcf-recall-banner {
    background: linear-gradient(135deg, #eef4ff 0%, #f0faff 100%) !important;
    border: 1px solid #c7d9ff !important;
    color: #1a4b8c !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-align: center !important;
    padding: 11px 16px !important;
    border-radius: 10px !important;
    margin-bottom: 24px !important;
}

/* Header form */
.tcf-wrapper .tcf-form-header { margin-bottom: 22px !important; }

.tcf-wrapper .tcf-form-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: #eef4ff !important;
    border: 1px solid #c7d9ff !important;
    color: #1a4b8c !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    padding: 5px 14px !important;
    border-radius: 50px !important;
    margin-bottom: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
}

.tcf-wrapper .tcf-form-title {
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #0f2d5e !important;
    line-height: 1.2 !important;
    margin-bottom: 6px !important;
}

.tcf-wrapper .tcf-form-sub {
    font-size: 14px !important;
    color: #5a6a8a !important;
    font-weight: 400 !important;
}

/* Honeypot */
.tcf-wrapper .tcf-hp {
    position: absolute !important;
    left: -9999px !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Grille 2 cols */
.tcf-wrapper .tcf-row-2 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
}
.tcf-wrapper .tcf-mb     { margin-bottom: 12px !important; }
.tcf-wrapper .tcf-field-block  { margin-bottom: 12px !important; }
.tcf-wrapper .tcf-select-block { display: block !important; }

/* Labels petits */
.tcf-wrapper .tcf-label-sm {
    display: block !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #3a5080 !important;
    margin-bottom: 8px !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
}

/* ============================================
   BOUTONS PROFIL PARTICULIER / PRO
   ============================================ */
.tcf-wrapper .tcf-radio-pill { display:flex !important; cursor:pointer !important; }
.tcf-wrapper .tcf-radio-pill input[type="radio"] { display:none !important; }

.tcf-wrapper .tcf-radio-pill span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    width: 100% !important;
    padding: 12px 10px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #6b7fa8 !important;
    background: #f5f8ff !important;
    border: 2px solid #dce6f7 !important;
    border-radius: 10px !important;
    transition: all .22s ease !important;
    cursor: pointer !important;
}

.tcf-wrapper .tcf-radio-pill input[type="radio"]:checked + span {
    color: #fff !important;
    background: linear-gradient(135deg, #1a4b8c 0%, #2563c4 100%) !important;
    border-color: #1a4b8c !important;
    box-shadow: 0 4px 16px rgba(26,75,140,0.28) !important;
}

.tcf-wrapper .tcf-radio-pill:hover span {
    border-color: #1a4b8c !important;
    color: #1a4b8c !important;
    background: #eef4ff !important;
}

/* ============================================
   RADIOS OUI / PAS SÛR / NON
   ============================================ */
.tcf-wrapper .tcf-radio-row { display:flex !important; flex-wrap:wrap !important; gap:8px !important; }
.tcf-wrapper .tcf-radio-check { display:flex !important; cursor:pointer !important; }
.tcf-wrapper .tcf-radio-check input[type="radio"] { display:none !important; }

.tcf-wrapper .tcf-radio-check span {
    display: inline-flex !important;
    align-items: center !important;
    padding: 9px 18px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #6b7fa8 !important;
    background: #f5f8ff !important;
    border: 2px solid #dce6f7 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all .18s ease !important;
}

.tcf-wrapper .tcf-radio-check input[type="radio"]:checked + span {
    color: #fff !important;
    background: linear-gradient(135deg, #1a73e8 0%, #2563c4 100%) !important;
    border-color: #1a73e8 !important;
    box-shadow: 0 3px 12px rgba(26,115,232,0.3) !important;
}

.tcf-wrapper .tcf-radio-check:hover span {
    border-color: #1a73e8 !important;
    color: #1a73e8 !important;
}

/* ============================================
   INPUTS — smooth & clean
   ============================================ */
.tcf-wrapper .tcf-field-wrap { position: relative !important; }

.tcf-wrapper .tcf-ico {
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 15px !important;
    pointer-events: none !important;
    z-index: 2 !important;
    opacity: 0.5 !important;
    transition: opacity .2s !important;
}

.tcf-wrapper .tcf-field-wrap:focus-within .tcf-ico {
    opacity: 0.85 !important;
}

.tcf-wrapper .tcf-input {
    display: block !important;
    width: 100% !important;
    padding: 13px 14px 13px 42px !important;
    font-size: 14px !important;
    color: #1a2a4a !important;
    background: #f8faff !important;
    border: 2px solid #dce6f7 !important;
    border-radius: 10px !important;
    outline: none !important;
    transition: border-color .22s ease, box-shadow .22s ease, background .22s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    line-height: 1.4 !important;
}

.tcf-wrapper .tcf-input::placeholder {
    color: #a0aec0 !important;
    font-size: 13.5px !important;
}

.tcf-wrapper .tcf-input:focus {
    border-color: #1a73e8 !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(26,115,232,0.12) !important;
}

.tcf-wrapper .tcf-input:valid:not(:placeholder-shown) {
    border-color: #34a853 !important;
    background: #fff !important;
}

/* Selects sans icone gauche */
.tcf-wrapper .tcf-select-noi { padding-left: 14px !important; }
.tcf-wrapper .tcf-select { cursor:pointer !important; color:#1a2a4a !important; padding-right:36px !important; }
.tcf-wrapper .tcf-select option { background:#fff !important; color:#1a2a4a !important; }
.tcf-wrapper .tcf-caret {
    position:absolute !important; right:13px !important; top:50% !important;
    transform:translateY(-50%) !important; font-size:10px !important;
    color:#6b7fa8 !important; pointer-events:none !important; z-index:2 !important;
}

/* Fichier */
.tcf-wrapper .tcf-file-zone {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    width: 100% !important;
    padding: 13px !important;
    font-size: 13.5px !important;
    color: #6b7fa8 !important;
    background: #f5f8ff !important;
    border: 2px dashed #c7d9ff !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: all .2s ease !important;
}
.tcf-wrapper .tcf-file-zone:hover {
    border-color: #1a73e8 !important;
    color: #1a73e8 !important;
    background: #eef4ff !important;
}
.tcf-wrapper .tcf-file-zone em { font-style:normal !important; opacity:0.6 !important; font-size:12px !important; }

/* CGU */
.tcf-wrapper .tcf-cgu-label {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    cursor: pointer !important;
    padding: 11px 14px !important;
    background: #f0faff !important;
    border: 1px solid #c7e8ff !important;
    border-radius: 8px !important;
    transition: background .18s !important;
}
.tcf-wrapper .tcf-cgu-label:hover { background: #e3f4ff !important; }
.tcf-wrapper .tcf-cgu-label input[type="checkbox"] {
    width: 17px !important; height: 17px !important; min-width: 17px !important;
    margin-top: 2px !important; accent-color: #1a73e8 !important;
    cursor: pointer !important; padding: 0 !important;
}
.tcf-wrapper .tcf-cgu-label span {
    font-size: 13px !important; color: #3a5080 !important; line-height: 1.5 !important;
}
.tcf-wrapper .tcf-cgu-label a { color: #1a73e8 !important; text-decoration: underline !important; font-weight: 600 !important; }

/* Erreur */
.tcf-wrapper .tcf-error {
    display: none !important;
    font-size: 13.5px !important;
    color: #c0392b !important;
    background: #fff5f5 !important;
    border: 1.5px solid #ffb3b3 !important;
    border-radius: 8px !important;
    padding: 11px 14px !important;
    margin-bottom: 12px !important;
    line-height: 1.5 !important;
}

/* Bouton submit */
.tcf-wrapper .tcf-btn-submit {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 16px 24px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    color: #fff !important;
    background: linear-gradient(135deg, #1d8348 0%, #27ae60 100%) !important;
    border: none !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all .22s ease !important;
    box-shadow: 0 4px 18px rgba(29,131,72,0.35) !important;
    margin-bottom: 10px !important;
    line-height: 1 !important;
}
.tcf-wrapper .tcf-btn-submit:hover {
    background: linear-gradient(135deg, #27ae60 0%, #2ecc71 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 7px 24px rgba(29,131,72,0.45) !important;
}
.tcf-wrapper .tcf-btn-submit:active { transform: translateY(0) !important; }
.tcf-wrapper .tcf-btn-submit:disabled { opacity:.6 !important; cursor:not-allowed !important; transform:none !important; }

.tcf-wrapper .tcf-btn-spin {
    display: none !important;
    width: 16px !important; height: 16px !important;
    border: 2px solid rgba(255,255,255,.35) !important;
    border-top-color: #fff !important;
    border-radius: 50% !important;
    animation: tcf-spin .65s linear infinite !important;
    flex-shrink: 0 !important;
}
.tcf-wrapper .tcf-btn-submit.tcf-loading .tcf-btn-label { display:none !important; }
.tcf-wrapper .tcf-btn-submit.tcf-loading .tcf-btn-spin  { display:inline-block !important; }
@keyframes tcf-spin { to { transform:rotate(360deg); } }

.tcf-wrapper .tcf-legal {
    font-size: 12px !important;
    color: #a0aec0 !important;
    text-align: center !important;
    line-height: 1.5 !important;
}

/* Succès */
.tcf-wrapper .tcf-success {
    display: none !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 60px 30px !important;
    min-height: 400px !important;
}
.tcf-wrapper .tcf-success.tcf-visible {
    display: flex !important;
    animation: tcf-fadein .4s ease !important;
}
.tcf-wrapper .tcf-success-check {
    width: 70px !important; height: 70px !important;
    background: linear-gradient(135deg, #1d8348, #27ae60) !important;
    color: #fff !important; font-size: 32px !important;
    border-radius: 50% !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    margin-bottom: 20px !important;
    box-shadow: 0 8px 24px rgba(29,131,72,0.4) !important;
}
.tcf-wrapper .tcf-success h3 {
    font-size: 26px !important; font-weight: 800 !important;
    color: #0f2d5e !important; margin-bottom: 12px !important;
}
.tcf-wrapper .tcf-success-msg {
    font-size: 15px !important; color: #4a5a7a !important; line-height: 1.7 !important;
}

@keyframes tcf-fadein {
    from { opacity:0; transform:translateY(12px); }
    to   { opacity:1; transform:translateY(0); }
}

/* ==============================================
   COLONNE DROITE — bleu clair élégant
   ============================================== */
.tcf-wrapper .tcf-col-right {
    background: linear-gradient(160deg, #eef4ff 0%, #f0faff 100%) !important;
    padding: 32px 28px !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 100% !important;
}

.tcf-wrapper .tcf-right-header {
    margin-bottom: 22px !important;
    padding-bottom: 18px !important;
    border-bottom: 2px solid #dce6f7 !important;
}

.tcf-wrapper .tcf-right-badge {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: #0f2d5e !important;
    margin-bottom: 6px !important;
    display: block !important;
}

.tcf-wrapper .tcf-right-horaires {
    font-size: 14px !important;
    color: #4a5a7a !important;
    line-height: 1.6 !important;
    font-weight: 500 !important;
}

/* Bouton CTA unique */
.tcf-wrapper .tcf-cta-wrap {
    margin-bottom: 20px !important;
}

.tcf-wrapper .tcf-cta-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 16px 20px !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    color: #0f2d5e !important;
    background: linear-gradient(135deg, #00c8ff 0%, #1a73e8 100%) !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    transition: all .22s ease !important;
    box-shadow: 0 5px 22px rgba(26,115,232,0.35) !important;
}
.tcf-wrapper .tcf-cta-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 9px 30px rgba(26,115,232,0.45) !important;
    color: #fff !important;
}

/* Shortcode wrapper (popup buttons etc.) */
.tcf-wrapper .tcf-shortcode-btn a,
.tcf-wrapper .tcf-shortcode-btn button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    padding: 16px 20px !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    transition: all .22s ease !important;
}

.tcf-wrapper .tcf-divider {
    height: 1px !important;
    background: #dce6f7 !important;
    margin: 6px 0 18px !important;
}

/* Features */
.tcf-wrapper .tcf-features {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    gap: 0 !important;
}

.tcf-wrapper .tcf-feature {
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
    padding: 13px 0 !important;
    border-bottom: 1px solid #e4ecf8 !important;
}
.tcf-wrapper .tcf-feature:last-child { border-bottom: none !important; }

.tcf-wrapper .tcf-feat-ico {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important; height: 44px !important;
    background: #fff !important;
    border: 1.5px solid #dce6f7 !important;
    border-radius: 10px !important;
    font-size: 20px !important;
    flex-shrink: 0 !important;
    box-shadow: 0 2px 8px rgba(26,75,140,0.07) !important;
}

.tcf-wrapper .tcf-feature strong {
    display: block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #0f2d5e !important;
    line-height: 1.3 !important;
    margin-bottom: 3px !important;
}
.tcf-wrapper .tcf-feature p {
    font-size: 13px !important;
    color: #6b7fa8 !important;
    line-height: 1.4 !important;
}

/* ==============================================
   RESPONSIVE
   ============================================== */
@media (max-width:860px) {
    .tcf-wrapper .tcf-grid { grid-template-columns: 1fr !important; }
    .tcf-wrapper .tcf-col-right {
        border-top: 1px solid #dce6f7 !important;
    }
    .tcf-wrapper .tcf-features {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
    }
    .tcf-wrapper .tcf-feature { border-bottom: none !important; }
}
@media (max-width:520px) {
    .tcf-wrapper .tcf-col-left  { padding: 22px 18px !important; }
    .tcf-wrapper .tcf-col-right { padding: 22px 18px !important; }
    .tcf-wrapper .tcf-row-2     { grid-template-columns: 1fr !important; }
    .tcf-wrapper .tcf-form-title { font-size: 23px !important; }
    .tcf-wrapper .tcf-features   { grid-template-columns: 1fr !important; }
}


/* =============================================
   Mode popup Elementor : une seule colonne + bloc droit en bas
   ============================================= */
.tcf-wrapper.tcf-popup-mode {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-grid {
    grid-template-columns: 1fr !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-col-left {
    padding: 24px !important;
    border-right: 0 !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-row-2 {
    grid-template-columns: 1fr !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-recall-banner {
    display: none !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-form-title {
    font-size: 24px !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-col-right {
    display: flex !important;
    border-top: 1px solid #dce6f7 !important;
    padding: 22px 24px !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-features {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-feature {
    padding: 10px 0 !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-success {
    min-height: auto !important;
    padding: 36px 20px !important;
}
.tcf-wrapper.tcf-popup-mode .tcf-success.tcf-visible {
    display: flex !important;
}
