/* ╔═══════════════════════════════════════════════════════════╗
   ║ LTC CONTACT FORM — 5 layouts                              ║
   ║ split-dark / split-light / stacked / card / minimal       ║
   ╚═══════════════════════════════════════════════════════════╝ */

.ltc-cf{
    --ltc-primary:#1679BE;
    --ltc-secondary:#000000;
    --ltc-dark:#0f0f10;
    --ltc-text:#0f0f10;
    --ltc-text-soft:#5a5a60;
    --ltc-border:rgba(15,15,16,0.08);
    --ltc-border-focus:var(--ltc-primary);
    width:100%;
    max-width:1200px;
    margin:0 auto;
    border-radius:16px;
    box-sizing:border-box;
    position:relative;
}

/* ──────────────── EN-TÊTE ──────────────── */
.ltc-cf__header{
    text-align:center;
    margin-bottom:48px;
}
.ltc-cf--align-left .ltc-cf__header{text-align:left;}
.ltc-cf--align-right .ltc-cf__header{text-align:right;}
.ltc-cf__eyebrow{
    display:inline-block;
    font-size:12px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    color:var(--ltc-primary);
    margin-bottom:14px;
    padding:6px 14px;
    border:1px solid currentColor;
    border-radius:999px;
    background:rgba(22,121,190,0.04);
}
.ltc-cf__heading{
    font-size:clamp(1.8rem, 3.4vw, 2.6rem);
    font-weight:700;
    margin:0 0 16px;
    color:var(--ltc-dark);
    letter-spacing:-0.02em;
    line-height:1.2;
}
.ltc-cf__subheading{
    font-size:16px;
    color:var(--ltc-text-soft);
    line-height:1.7;
    margin:0;
    max-width:640px;
}
.ltc-cf--align-center .ltc-cf__subheading{margin:0 auto;}
.ltc-cf--align-right .ltc-cf__subheading{margin:0 0 0 auto;}

/* ──────────────── INNER (le conteneur principal info+form) ──────────────── */
.ltc-cf__inner{
    display:grid;
    overflow:hidden;
    border-radius:inherit;
    box-sizing:border-box;
}

/* Animation d'apparition */
.ltc-cf--animate .ltc-cf__inner{
    opacity:0;
    transform:translateY(24px);
    animation:ltcCfFadeUp .8s cubic-bezier(.25,.8,.25,1) forwards .15s;
}
@keyframes ltcCfFadeUp{to{opacity:1; transform:translateY(0);}}

/* ╔══════════════════════════════════════════════════════════╗
   ║ BLOC INFO (commun)                                        ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf__info{
    padding:48px 40px;
    position:relative;
    overflow:hidden;
}
.ltc-cf__company{
    font-size:clamp(22px, 2.6vw, 30px);
    font-weight:700;
    margin:0 0 12px;
    letter-spacing:-0.02em;
    line-height:1.2;
    position:relative;
    z-index:1;
}
.ltc-cf__tagline{
    font-size:15px;
    line-height:1.7;
    margin:0 0 32px;
    opacity:0.9;
    position:relative;
    z-index:1;
}
.ltc-cf__details{
    display:flex;
    flex-direction:column;
    gap:14px;
    position:relative;
    z-index:1;
}
.ltc-cf__detail{
    display:flex;
    align-items:flex-start;
    gap:14px;
    padding:12px 14px;
    border-radius:10px;
    text-decoration:none !important;
    color:inherit;
    transition:all .35s cubic-bezier(.25,.8,.25,1);
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
}
.ltc-cf__detail:hover{
    background:rgba(255,255,255,0.12);
    border-color:rgba(255,255,255,0.20);
    transform:translateX(4px);
}
.ltc-cf__detail-icon{
    width:38px; height:38px;
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,0.18);
    border-radius:50%;
    font-size:14px;
}
.ltc-cf__detail-content{
    display:flex;
    flex-direction:column;
    gap:2px;
    min-width:0;
    flex:1;
}
.ltc-cf__detail-label{
    font-size:11px;
    font-weight:700;
    letter-spacing:1.5px;
    text-transform:uppercase;
    opacity:0.7;
}
.ltc-cf__detail-text{
    font-size:14px;
    font-weight:500;
    line-height:1.5;
    word-wrap:break-word;
}

/* Réseaux sociaux */
.ltc-cf__socials{
    display:flex;
    gap:10px;
    margin-top:28px;
    position:relative;
    z-index:1;
}
.ltc-cf__social{
    width:42px; height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:rgba(255,255,255,0.10);
    border:1px solid rgba(255,255,255,0.18);
    color:inherit;
    text-decoration:none !important;
    transition:all .35s;
    font-size:15px;
}
.ltc-cf__social:hover{
    background:rgba(255,255,255,0.20);
    border-color:rgba(255,255,255,0.40);
    transform:translateY(-3px);
}

/* Emoji décoratif */
.ltc-cf__deco{
    position:absolute;
    bottom:-30px; right:-20px;
    font-size:160px;
    opacity:0.06;
    pointer-events:none;
    line-height:1;
    z-index:0;
}

/* ╔══════════════════════════════════════════════════════════╗
   ║ FORMULAIRE (commun)                                       ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf__form{
    padding:48px 40px;
    background:#ffffff;
    position:relative;
    box-sizing:border-box;
}

.ltc-cf__form-inner{display:flex; flex-direction:column; gap:18px;}

.ltc-cf__row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}
@media(max-width:640px){
    .ltc-cf__row{grid-template-columns:1fr;}
}

.ltc-cf__field label{
    display:block;
    font-size:13px;
    font-weight:600;
    color:var(--ltc-text);
    margin-bottom:8px;
    letter-spacing:0.3px;
}

.ltc-cf__field input,
.ltc-cf__field textarea,
.ltc-cf__field select{
    width:100%;
    padding:14px 16px;
    border:1.5px solid var(--ltc-border);
    border-radius:10px;
    background:#fff;
    color:var(--ltc-text);
    font-size:14.5px;
    font-family:inherit;
    transition:all .35s cubic-bezier(.25,.8,.25,1);
    box-sizing:border-box;
    line-height:1.5;
}
.ltc-cf__field textarea{
    resize:vertical;
    min-height:120px;
}
.ltc-cf__field select{
    appearance:none;
    -webkit-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235a5a60' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 16px center;
    padding-right:44px;
    cursor:pointer;
}
.ltc-cf__field input:focus,
.ltc-cf__field textarea:focus,
.ltc-cf__field select:focus{
    outline:none;
    border-color:var(--ltc-primary);
    box-shadow:0 0 0 4px rgba(22,121,190,0.10);
}
.ltc-cf__field input::placeholder,
.ltc-cf__field textarea::placeholder{
    color:#a8a8ad;
    opacity:1;
}

/* RGPD */
.ltc-cf__rgpd{font-size:12.5px; color:var(--ltc-text-soft); line-height:1.6; margin-top:4px;}
.ltc-cf__rgpd label{
    display:flex;
    align-items:flex-start;
    gap:10px;
    cursor:pointer;
}
.ltc-cf__rgpd-check{
    flex-shrink:0;
    margin-top:3px;
    width:16px; height:16px;
    accent-color:var(--ltc-primary);
    cursor:pointer;
}
.ltc-cf__rgpd a{color:var(--ltc-primary); text-decoration:underline;}

/* Bouton submit */
.ltc-cf__submit{
    margin-top:8px;
    padding:16px 28px;
    background:linear-gradient(135deg, var(--ltc-primary) 0%, var(--ltc-secondary) 100%);
    background-size:200% 200%;
    color:#fff !important;
    border:none;
    border-radius:999px;
    font-size:15px;
    font-weight:700;
    letter-spacing:0.5px;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    transition:all .4s cubic-bezier(.25,.8,.25,1);
    box-shadow:0 8px 24px rgba(22,121,190,0.28);
    font-family:inherit;
    animation:ltcCfBtnGradient 6s ease infinite;
}
@keyframes ltcCfBtnGradient{
    0%,100%{background-position:0% 50%;}
    50%{background-position:100% 50%;}
}
.ltc-cf__submit:hover{
    transform:translateY(-2px);
    box-shadow:0 12px 32px rgba(22,121,190,0.40);
}
.ltc-cf__submit:active{transform:translateY(0);}
.ltc-cf__submit i{font-size:14px;}

/* Succès */
.ltc-cf__success{
    text-align:center;
    padding:40px 20px;
    animation:ltcCfFadeUp .55s cubic-bezier(.25,.8,.25,1);
}
.ltc-cf__success-icon{
    width:72px; height:72px;
    margin:0 auto 20px;
    background:linear-gradient(135deg, #16a34a 0%, #059669 100%);
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:36px;
    color:#fff;
    font-weight:700;
    box-shadow:0 8px 24px rgba(16,163,74,0.32);
    animation:ltcCfPop .6s cubic-bezier(.34,1.56,.64,1);
}
@keyframes ltcCfPop{
    0%{transform:scale(0); opacity:0;}
    100%{transform:scale(1); opacity:1;}
}
.ltc-cf__success p{
    color:var(--ltc-text);
    font-size:15.5px;
    line-height:1.7;
    margin:0;
}

/* Loading */
.ltc-cf__loading{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,0.85);
    backdrop-filter:blur(4px);
    z-index:10;
    border-radius:inherit;
}
.ltc-cf__spinner{
    width:50px; height:50px;
    border:4px solid rgba(22,121,190,0.20);
    border-top-color:var(--ltc-primary);
    border-radius:50%;
    animation:ltcCfSpin .8s linear infinite;
}
@keyframes ltcCfSpin{to{transform:rotate(360deg);}}


/* ╔══════════════════════════════════════════════════════════╗
   ║ LAYOUT 1 — SPLIT DARK (info sombre + form clair)         ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf--split-dark .ltc-cf__inner{
    grid-template-columns:1fr 1fr;
    box-shadow:0 4px 24px rgba(0,0,0,0.06), 0 24px 48px rgba(0,0,0,0.08);
}
.ltc-cf--split-dark .ltc-cf__info{
    background:linear-gradient(135deg, var(--ltc-dark) 0%, #2a2a2e 60%, #3a3a3e 100%);
    color:#fff;
}
/* Halos animés sur fond sombre */
.ltc-cf--split-dark .ltc-cf__info::before{
    content:'';
    position:absolute;
    top:-160px; right:-160px;
    width:380px; height:380px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(22,121,190,0.30) 0%, transparent 65%);
    animation:ltcCfHaloFloat 14s ease-in-out infinite;
    pointer-events:none;
}
.ltc-cf--split-dark .ltc-cf__info::after{
    content:'';
    position:absolute;
    bottom:-140px; left:-140px;
    width:320px; height:320px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(0,0,0,0.40) 0%, transparent 70%);
    animation:ltcCfHaloFloat 16s ease-in-out infinite reverse;
    pointer-events:none;
}
@keyframes ltcCfHaloFloat{
    0%,100%{transform:translate(0,0) scale(1);}
    50%{transform:translate(-20px,20px) scale(1.05);}
}
.ltc-cf--split-dark .ltc-cf__company{
    background:linear-gradient(135deg, #fff 0%, rgba(255,255,255,0.85) 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
}

/* Si info à droite, on inverse l'ordre */
.ltc-cf--split-dark.ltc-cf--info-right .ltc-cf__info{order:2;}
.ltc-cf--split-dark.ltc-cf--info-right .ltc-cf__form{order:1;}


/* ╔══════════════════════════════════════════════════════════╗
   ║ LAYOUT 2 — SPLIT LIGHT (les deux clairs, accent rouge)   ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf--split-light .ltc-cf__inner{
    grid-template-columns:1fr 1fr;
    box-shadow:0 4px 24px rgba(0,0,0,0.04), 0 16px 40px rgba(0,0,0,0.04);
    border:1px solid var(--ltc-border);
}
.ltc-cf--split-light .ltc-cf__info{
    background:linear-gradient(135deg, #fafafa 0%, #f0f0f2 100%);
    color:var(--ltc-text);
    border-right:1px solid var(--ltc-border);
}
.ltc-cf--split-light .ltc-cf__company{color:var(--ltc-dark);}
.ltc-cf--split-light .ltc-cf__tagline{color:var(--ltc-text-soft);}
.ltc-cf--split-light .ltc-cf__detail{
    background:#fff;
    border-color:var(--ltc-border);
    color:var(--ltc-text);
}
.ltc-cf--split-light .ltc-cf__detail:hover{
    background:#fff;
    border-color:rgba(22,121,190,0.25);
    box-shadow:0 4px 12px rgba(22,121,190,0.10);
}
.ltc-cf--split-light .ltc-cf__detail-icon{
    background:rgba(22,121,190,0.10);
    color:var(--ltc-primary);
}
.ltc-cf--split-light .ltc-cf__detail-label{
    color:var(--ltc-primary);
    opacity:1;
}
.ltc-cf--split-light .ltc-cf__social{
    background:rgba(22,121,190,0.08);
    border-color:rgba(22,121,190,0.20);
    color:var(--ltc-primary);
}
.ltc-cf--split-light .ltc-cf__social:hover{
    background:var(--ltc-primary);
    color:#fff;
    border-color:var(--ltc-primary);
}
.ltc-cf--split-light .ltc-cf__deco{opacity:0.04;}

/* Si info à droite */
.ltc-cf--split-light.ltc-cf--info-right .ltc-cf__info{
    order:2;
    border-right:none;
    border-left:1px solid var(--ltc-border);
}
.ltc-cf--split-light.ltc-cf--info-right .ltc-cf__form{order:1;}


/* ╔══════════════════════════════════════════════════════════╗
   ║ LAYOUT 3 — STACKED (info au-dessus, form en dessous)     ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf--stacked .ltc-cf__inner{
    grid-template-columns:1fr;
    box-shadow:0 4px 24px rgba(0,0,0,0.04), 0 16px 40px rgba(0,0,0,0.04);
    border:1px solid var(--ltc-border);
}
.ltc-cf--stacked .ltc-cf__info{
    background:linear-gradient(135deg, var(--ltc-dark) 0%, #2a2a2e 100%);
    color:#fff;
    text-align:center;
}
.ltc-cf--stacked .ltc-cf__details{
    flex-direction:row;
    flex-wrap:wrap;
    justify-content:center;
    gap:14px;
}
.ltc-cf--stacked .ltc-cf__detail{flex:1 1 220px; max-width:280px;}
.ltc-cf--stacked .ltc-cf__socials{justify-content:center;}
.ltc-cf--stacked .ltc-cf__company{
    background:linear-gradient(135deg, #fff 0%, rgba(255,255,255,0.85) 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
}

/* Si pas de bloc info */
.ltc-cf--stacked.ltc-cf--no-info .ltc-cf__info{display:none;}


/* ╔══════════════════════════════════════════════════════════╗
   ║ LAYOUT 4 — CARD (form seul dans une carte centrée)       ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf--card{max-width:1100px;}
.ltc-cf--card .ltc-cf__inner{
    grid-template-columns:1fr;
    box-shadow:0 8px 32px rgba(0,0,0,0.06), 0 24px 56px rgba(22,121,190,0.10);
    border:1px solid var(--ltc-border);
    background:#fff;
    overflow:hidden;
    position:relative;
}
.ltc-cf--card .ltc-cf__inner::before{
    content:'';
    position:absolute;
    top:0; left:0; right:0;
    height:5px;
    background:linear-gradient(90deg, var(--ltc-primary) 0%, var(--ltc-secondary) 100%);
    z-index:2;
}
.ltc-cf--card.ltc-cf--no-info .ltc-cf__info{display:none;}
.ltc-cf--card .ltc-cf__info{
    background:#fafafa;
    color:var(--ltc-text);
    text-align:center;
    border-bottom:1px solid var(--ltc-border);
}
.ltc-cf--card .ltc-cf__company{color:var(--ltc-dark);}
.ltc-cf--card .ltc-cf__tagline{color:var(--ltc-text-soft);}
.ltc-cf--card .ltc-cf__details{
    flex-direction:row;
    flex-wrap:wrap;
    justify-content:center;
    gap:12px;
}
.ltc-cf--card .ltc-cf__detail{
    background:#fff;
    border-color:var(--ltc-border);
    color:var(--ltc-text);
    flex:1 1 calc(50% - 18px);
    max-width:none;
    min-width:0;
}
/* DESKTOP : élargir les cartes info pour que email/adresse tiennent sur 1-2 lignes
   S'applique à TOUS les presets (card, stacked, split-light, split-dark, etc.)
   On cible explicitement chaque preset pour spécificité supérieure aux règles existantes */
@media (min-width:769px){
    .ltc-cf--card .ltc-cf__details,
    .ltc-cf--stacked .ltc-cf__details,
    .ltc-cf--split-light .ltc-cf__details,
    .ltc-cf--split-dark .ltc-cf__details,
    .ltc-cf--minimal .ltc-cf__details{
        gap:18px !important;
    }
    .ltc-cf--card .ltc-cf__detail,
    .ltc-cf--stacked .ltc-cf__detail,
    .ltc-cf--split-light .ltc-cf__detail,
    .ltc-cf--split-dark .ltc-cf__detail,
    .ltc-cf--minimal .ltc-cf__detail{
        flex:1 1 calc(50% - 18px) !important;
        max-width:none !important;
        min-width:0 !important;
        width:calc(50% - 9px) !important;
        padding:18px 20px !important;
        box-sizing:border-box !important;
    }
    .ltc-cf--card .ltc-cf__detail-text,
    .ltc-cf--stacked .ltc-cf__detail-text,
    .ltc-cf--split-light .ltc-cf__detail-text,
    .ltc-cf--split-dark .ltc-cf__detail-text,
    .ltc-cf--minimal .ltc-cf__detail-text{
        font-size:15px !important;
        word-break:break-word !important;
        overflow-wrap:break-word !important;
        white-space:normal !important;
    }
    .ltc-cf--card .ltc-cf__detail-content,
    .ltc-cf--stacked .ltc-cf__detail-content,
    .ltc-cf--split-light .ltc-cf__detail-content,
    .ltc-cf--split-dark .ltc-cf__detail-content,
    .ltc-cf--minimal .ltc-cf__detail-content{
        min-width:0 !important;
        flex:1 1 auto !important;
        overflow:hidden !important;
    }
}
.ltc-cf--card .ltc-cf__detail-icon{
    background:rgba(22,121,190,0.10);
    color:var(--ltc-primary);
}
.ltc-cf--card .ltc-cf__detail-label{color:var(--ltc-primary); opacity:1;}
.ltc-cf--card .ltc-cf__socials{justify-content:center;}


/* ╔══════════════════════════════════════════════════════════╗
   ║ LAYOUT 5 — MINIMAL (form épuré, infos en bas)            ║
   ╚══════════════════════════════════════════════════════════╝ */
.ltc-cf--minimal{max-width:720px;}
.ltc-cf--minimal .ltc-cf__inner{
    grid-template-columns:1fr;
    grid-template-areas:'form' 'info';
    box-shadow:none;
    border:none;
    background:transparent;
}
.ltc-cf--minimal .ltc-cf__form{grid-area:form; padding:0; background:transparent;}
.ltc-cf--minimal .ltc-cf__info{grid-area:info; padding:32px 0 0; background:transparent; color:var(--ltc-text); text-align:center; border-top:1px solid var(--ltc-border); margin-top:24px;}
.ltc-cf--minimal.ltc-cf--no-info .ltc-cf__info{display:none;}

/* Champs underline only */
.ltc-cf--minimal .ltc-cf__field input,
.ltc-cf--minimal .ltc-cf__field textarea,
.ltc-cf--minimal .ltc-cf__field select{
    border:none;
    border-bottom:1.5px solid var(--ltc-border);
    border-radius:0;
    background:transparent;
    padding:12px 0;
}
.ltc-cf--minimal .ltc-cf__field input:focus,
.ltc-cf--minimal .ltc-cf__field textarea:focus,
.ltc-cf--minimal .ltc-cf__field select:focus{
    border-bottom-color:var(--ltc-primary);
    box-shadow:0 1px 0 0 var(--ltc-primary);
}
.ltc-cf--minimal .ltc-cf__field select{
    background-position:right 0 center;
    padding-right:24px;
}

.ltc-cf--minimal .ltc-cf__company{color:var(--ltc-dark); font-size:18px;}
.ltc-cf--minimal .ltc-cf__tagline{color:var(--ltc-text-soft); font-size:14px;}
.ltc-cf--minimal .ltc-cf__details{
    flex-direction:row;
    flex-wrap:wrap;
    justify-content:center;
    gap:18px;
}
.ltc-cf--minimal .ltc-cf__detail{
    background:transparent;
    border:none;
    padding:6px 0;
    color:var(--ltc-text);
}
.ltc-cf--minimal .ltc-cf__detail:hover{
    transform:none;
    background:transparent;
    color:var(--ltc-primary);
}
.ltc-cf--minimal .ltc-cf__detail-icon{
    background:transparent;
    color:var(--ltc-primary);
    width:auto; height:auto;
    font-size:14px;
}
.ltc-cf--minimal .ltc-cf__deco{display:none;}


/* ╔══════════════════════════════════════════════════════════╗
   ║ RESPONSIVE                                                ║
   ╚══════════════════════════════════════════════════════════╝ */
@media(max-width:900px){
    .ltc-cf--split-dark .ltc-cf__inner,
    .ltc-cf--split-light .ltc-cf__inner{
        grid-template-columns:1fr;
    }
    .ltc-cf--split-light.ltc-cf--info-right .ltc-cf__info{
        border-left:none;
        border-bottom:1px solid var(--ltc-border);
    }
    .ltc-cf--split-light .ltc-cf__info{
        border-right:none;
        border-bottom:1px solid var(--ltc-border);
    }
}

@media(max-width:640px){
    .ltc-cf__info,
    .ltc-cf__form{
        padding:32px 24px;
    }
    .ltc-cf__details{flex-direction:column !important;}
    .ltc-cf__detail{flex:1 1 auto !important; max-width:100% !important;}
    .ltc-cf__company{font-size:22px;}
    .ltc-cf__tagline{font-size:14px;}
    .ltc-cf--minimal .ltc-cf__form{padding:0;}
    .ltc-cf--minimal .ltc-cf__info{padding-top:24px;}
    .ltc-cf__submit{width:100%;}
}

@media(max-width:420px){
    .ltc-cf__info,
    .ltc-cf__form{
        padding:24px 18px;
    }
    .ltc-cf__field input,
    .ltc-cf__field textarea,
    .ltc-cf__field select{
        padding:12px 14px;
        font-size:14px;
    }
    .ltc-cf__detail-text{font-size:13px;}
}
