/* =========================================================
   SBI 8.0P.65 - CONTACT MOBILE STRUCTURE ALIGNMENT
   ---------------------------------------------------------
   Scope isolé page contact : coin inférieur aligné sur la page connexion,
   template email et assistant feedback conservés.
   ========================================================= */

body[data-sbi-public-page="contact"] {
    background:
        radial-gradient(circle at 18% 28%, rgba(0, 81, 255, 0.12), transparent 34%),
        radial-gradient(circle at 88% 18%, rgba(0, 119, 255, 0.10), transparent 30%),
        #04070d;
}

.contact-page {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(3, 7, 14, 0.98) 0%, rgba(4, 7, 12, 0.96) 42%, rgba(2, 6, 15, 0.99) 100%);
}

.contact-premium-hero {
    position: relative;
    min-height: calc(100vh - var(--header-height));
    padding-top: calc(var(--header-height) + clamp(2.2rem, 4vw, 4.2rem));
    padding-bottom: clamp(3.5rem, 6vw, 6rem);
    isolation: isolate;
    overflow: hidden;
}

.contact-premium-hero::before,
.contact-premium-hero::after {
    content: '';
    position: absolute;
    pointer-events: none;
    z-index: -1;
}

.contact-premium-hero::before {
    inset: 0;
    background:
        linear-gradient(127deg, transparent 0 18%, rgba(0, 81, 255, 0.42) 18.08%, transparent 18.6% 100%),
        linear-gradient(127deg, transparent 0 70%, rgba(0, 132, 255, 0.42) 70.08%, transparent 70.58% 100%),
        linear-gradient(127deg, transparent 0 83%, rgba(255, 255, 255, 0.10) 83.03%, transparent 83.26% 100%);
    opacity: 0.52;
}

.contact-premium-hero::after {
    width: 46vw;
    height: 46vw;
    right: -18vw;
    top: 10vh;
    border: 1px solid rgba(0, 81, 255, 0.18);
    border-radius: 999px;
    box-shadow:
        inset 0 0 70px rgba(0, 81, 255, 0.05),
        0 0 70px rgba(0, 81, 255, 0.06);
    opacity: 0.58;
}

.contact-video-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.12;
    filter: grayscale(1) contrast(1.28) brightness(0.55) saturate(1.28);
    mix-blend-mode: screen;
    pointer-events: none;
    z-index: -3;
}

.contact-video-mask {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: -2;
    background:
        linear-gradient(90deg, rgba(4, 5, 8, 0.98) 0%, rgba(4, 5, 8, 0.76) 34%, rgba(4, 5, 8, 0.92) 100%),
        radial-gradient(circle at 72% 52%, rgba(0, 81, 255, 0.10), transparent 38%),
        radial-gradient(circle at 21% 66%, rgba(0, 81, 255, 0.12), transparent 32%);
}

.contact-orbit {
    position: absolute;
    pointer-events: none;
    border: 1px solid rgba(157, 190, 246, 0.18);
    transform: rotate(-29deg);
    z-index: 0;
}

.contact-orbit-one {
    width: 94px;
    height: 94px;
    right: 48%;
    bottom: 24%;
    border-radius: 999px;
    box-shadow: 0 0 28px rgba(0, 81, 255, 0.18);
}

.contact-orbit-two {
    width: 78px;
    height: 78px;
    right: 7%;
    top: 16%;
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
    border-radius: 0;
    opacity: 0.45;
}

.contact-premium-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(420px, 0.78fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
    max-width: 1440px;
    margin: 0 auto;
}

.contact-story {
    position: relative;
    min-height: 760px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(1rem, 2vw, 2rem) 0;
}

.contact-title {
    margin-top: 0.85rem;
    color: #fff;
    font-size: clamp(3.1rem, 6.3vw, 7rem);
    line-height: 0.94;
    letter-spacing: -0.065em;
    text-shadow: 0 18px 42px rgba(0, 0, 0, 0.48);
}

.contact-title .text-blue {
    display: inline-block;
    color: var(--sbi-blue);
}

.contact-lead {
    position: relative;
    z-index: 2;
    max-width: 570px;
    margin-top: 1.6rem;
    color: rgba(255, 255, 255, 0.86);
    font-size: clamp(1rem, 1.15vw, 1.18rem);
    line-height: 1.75;
}

.contact-lead::before {
    content: '';
    display: block;
    width: 72px;
    height: 3px;
    margin-bottom: 1.45rem;
    background: var(--sbi-blue);
    box-shadow: 0 0 18px rgba(0, 81, 255, 0.7);
}

.contact-direct-lines {
    position: relative;
    z-index: 3;
    display: flex;
    flex-wrap: wrap;
    gap: 0.72rem;
    margin-top: 1.1rem;
}

.contact-direct-link {
    display: inline-grid;
    gap: 0.16rem;
    min-width: min(230px, 100%);
    padding: 0.78rem 0.95rem;
    color: #fff;
    text-decoration: none;
    border: 1px solid rgba(157, 190, 246, 0.22);
    background: rgba(255, 255, 255, 0.026);
    box-shadow: 0 0 20px rgba(0, 81, 255, 0.055);
    transition:
        border-color 0.22s ease,
        background 0.22s ease,
        transform 0.22s ease;
}

.contact-direct-link:hover {
    border-color: rgba(0, 132, 255, 0.62);
    background: rgba(0, 81, 255, 0.08);
    transform: translateY(-1px);
}

.contact-direct-link span {
    color: var(--sbi-blue);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.contact-direct-link strong {
    font-size: 0.98rem;
    line-height: 1.1;
}

.contact-ghost-logo {
    position: absolute;
    z-index: -1;
    width: min(72vw, 720px);
    max-width: none;
    left: 5%;
    top: 28%;
    opacity: 0.18;
    filter:
        grayscale(1)
        contrast(1.22)
        brightness(0.46)
        drop-shadow(0 0 34px rgba(0, 81, 255, 0.34));
    transform: rotate(-4deg);
    user-select: none;
    pointer-events: none;
    mix-blend-mode: screen;
}

.contact-feature-list {
    position: relative;
    z-index: 3;
    display: grid;
    gap: 1.3rem;
    max-width: 560px;
    margin-top: auto;
    padding-top: clamp(2.6rem, 6vw, 5rem);
}

.contact-feature {
    display: grid;
    grid-template-columns: 62px minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
}

.contact-feature-icon {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.72);
    background:
        linear-gradient(135deg, rgba(0, 81, 255, 0.18), rgba(255, 255, 255, 0.02));
    clip-path: polygon(50% 0, 94% 25%, 94% 75%, 50% 100%, 6% 75%, 6% 25%);
    box-shadow: 0 0 24px rgba(0, 81, 255, 0.10);
}

.contact-feature-icon svg {
    color: var(--sbi-blue);
    filter: drop-shadow(0 0 8px rgba(0, 81, 255, 0.72));
}

.contact-feature h2 {
    margin: 0 0 0.22rem;
    color: #fff;
    font-size: clamp(1rem, 1.35vw, 1.25rem);
    line-height: 1.15;
}

.contact-feature p {
    margin: 0;
    color: rgba(255, 255, 255, 0.68);
    line-height: 1.45;
}

.contact-form-card {
    --contact-corner-band: #000000;
    --contact-corner-separator: rgba(255, 255, 255, 0.15);
    --contact-corner-border: rgba(157, 190, 246, 0.32);

    position: relative;
    min-height: 720px;
    padding: 1px;
    border: 1px solid rgba(92, 131, 196, 0.52);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(0, 81, 255, 0.18) 42%, rgba(255, 255, 255, 0.03));
    box-shadow:
        0 32px 80px rgba(0, 0, 0, 0.52),
        0 0 46px rgba(0, 81, 255, 0.08);
    overflow: visible;
    transition:
        border-color 0.26s ease,
        box-shadow 0.26s ease,
        transform 0.26s ease;
}

.contact-form-card::before {
    content: '';
    position: absolute;
    inset: -1px;
    border: 1px solid transparent;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.26s ease;
}

.contact-form-card.is-loading {
    --contact-corner-band: rgba(0, 81, 255, 0.34);
    --contact-corner-separator: rgba(255, 255, 255, 0.12);
    --contact-corner-border: rgba(0, 81, 255, 0.44);
    border-color: rgba(0, 81, 255, 0.54);
    box-shadow:
        0 32px 80px rgba(0, 0, 0, 0.52),
        0 0 34px rgba(0, 81, 255, 0.12);
}

.contact-form-card.is-success {
    --contact-corner-band: var(--sbi-blue);
    --contact-corner-separator: rgba(255, 255, 255, 0.18);
    --contact-corner-border: rgba(0, 132, 255, 0.76);
    border-color: rgba(0, 132, 255, 0.88);
    box-shadow:
        0 32px 80px rgba(0, 0, 0, 0.52),
        0 0 42px rgba(0, 81, 255, 0.2);
}

.contact-form-card.is-success::before {
    opacity: 1;
    border-color: rgba(0, 132, 255, 0.38);
    animation: contactSuccessFlash 0.62s ease-out;
}

.contact-form-card.is-error {
    --contact-corner-band: #ff4a4a;
    --contact-corner-separator: rgba(255, 255, 255, 0.16);
    --contact-corner-border: rgba(255, 74, 74, 0.66);
    border-color: rgba(255, 74, 74, 0.76);
    box-shadow:
        0 32px 80px rgba(0, 0, 0, 0.52),
        0 0 30px rgba(255, 74, 74, 0.12);
    animation: contactErrorShake 0.34s ease;
}

.contact-form-card.is-error::before {
    opacity: 1;
    border-color: rgba(255, 74, 74, 0.34);
}

.contact-card-inner {
    position: relative;
    min-height: inherit;
    padding: clamp(2rem, 3.6vw, 3rem);
    background:
        linear-gradient(180deg, rgba(7, 12, 23, 0.94), rgba(3, 7, 14, 0.96)),
        radial-gradient(circle at 88% 0%, rgba(0, 81, 255, 0.16), transparent 36%);
    border: 1px solid rgba(157, 190, 246, 0.18);
    overflow: hidden;
}

.contact-card-inner::before,
.contact-card-inner::after {
    content: '';
    position: absolute;
    pointer-events: none;
}

.contact-card-inner::before {
    inset: 0;
    background:
        linear-gradient(130deg, transparent 0 68%, rgba(0, 81, 255, 0.16) 68.2%, transparent 69% 100%);
    opacity: 0.62;
}

.contact-card-inner::after {
    width: 280px;
    height: 280px;
    right: -170px;
    top: 8%;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(0, 81, 255, 0.16), transparent 68%);
    filter: blur(3px);
}

.contact-card-badge {
    top: 20px;
    left: 20px;
    width: 46px;
    height: 46px;
    z-index: 5;
}

/* Coin bas droit : aligné sur la logique de la page connexion */
.contact-card-cut {
    position: absolute;
    right: -1px;
    bottom: -1px;
    z-index: 5;
    width: 60px;
    height: 60px;
    pointer-events: none;
    border-right: 1px solid var(--contact-corner-border);
    border-bottom: 1px solid var(--contact-corner-border);
    background: linear-gradient(
        -45deg,
        #040508 0%,
        #040508 18px,
        var(--contact-corner-band) 18px,
        var(--contact-corner-band) 36px,
        var(--contact-corner-separator) 36px,
        var(--contact-corner-separator) 37px,
        transparent 37px
    );
    transition:
        background 0.24s ease,
        border-color 0.24s ease,
        filter 0.24s ease;
}

.contact-card-cut::before,
.contact-card-cut::after {
    content: none;
    display: none;
}

.contact-form-card.is-loading .contact-card-cut {
    animation: contactCornerPulse 0.9s ease-in-out infinite alternate;
}

.contact-card-kicker,
.contact-card-title,
.contact-card-copy,
.contact-premium-form {
    position: relative;
    z-index: 2;
}

.contact-card-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    margin-left: 34px;
    color: var(--sbi-blue);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.04em;
}

.contact-kicker-icon {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    color: var(--sbi-blue);
    border: 1px solid rgba(0, 81, 255, 0.42);
    clip-path: polygon(50% 0, 94% 25%, 94% 75%, 50% 100%, 6% 75%, 6% 25%);
    background: rgba(0, 81, 255, 0.08);
}

.contact-card-title {
    margin-top: 1.45rem;
    color: #fff;
    font-size: clamp(2.1rem, 3.6vw, 3.25rem);
    line-height: 1;
    letter-spacing: -0.04em;
}

.contact-card-copy {
    max-width: 430px;
    margin-top: 0.9rem;
    color: rgba(255, 255, 255, 0.72);
    line-height: 1.65;
}

.contact-premium-form {
    display: grid;
    gap: 1rem;
    margin-top: 1.8rem;
}

.contact-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.contact-field,
.contact-profile-tabs {
    color: #fff;
    font-weight: 850;
}

.contact-field {
    display: grid;
    gap: 0.45rem;
}

.contact-profile-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.62rem;
    margin: 0;
    padding: 0;
    border: 0;
}

.contact-profile-tabs legend {
    flex: 1 0 100%;
    margin-bottom: 0.1rem;
    color: #fff;
    font-weight: 850;
}

.contact-profile-tab {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0.74rem 0.92rem;
    border: 1px solid rgba(157, 190, 246, 0.24);
    background: rgba(255, 255, 255, 0.025);
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.88rem;
    font-weight: 850;
    cursor: pointer;
    transition:
        border-color 0.2s ease,
        background 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease;
}

.contact-profile-tab:hover {
    border-color: rgba(0, 81, 255, 0.52);
    color: #fff;
    transform: translateY(-1px);
}

.contact-profile-tab input {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
}

.contact-profile-tab:has(input:checked) {
    border-color: rgba(0, 132, 255, 0.86);
    background:
        linear-gradient(135deg, rgba(0, 81, 255, 0.28), rgba(0, 132, 255, 0.09));
    color: #fff;
    box-shadow: 0 0 22px rgba(0, 81, 255, 0.14);
}

.contact-premium-form input,
.contact-premium-form select,
.contact-premium-form textarea {
    width: 100%;
    min-height: 52px;
    border: 1px solid rgba(157, 190, 246, 0.24);
    border-radius: 2px;
    background: rgba(0, 0, 0, 0.18);
    color: #fff;
    padding: 0.95rem 1rem;
    font: inherit;
    font-style: italic;
    transition:
        border-color 0.24s ease,
        box-shadow 0.24s ease,
        background 0.24s ease;
}

.contact-premium-form input::placeholder,
.contact-premium-form textarea::placeholder {
    color: rgba(255, 255, 255, 0.36);
}

.contact-premium-form input:focus,
.contact-premium-form select:focus,
.contact-premium-form textarea:focus {
    outline: none;
    border-color: rgba(0, 132, 255, 0.86);
    background: rgba(3, 8, 16, 0.72);
    box-shadow: 0 0 0 3px rgba(0, 81, 255, 0.10);
}

.contact-form-card.is-error .contact-premium-form input:invalid,
.contact-form-card.is-error .contact-premium-form select:invalid,
.contact-form-card.is-error .contact-premium-form textarea:invalid {
    border-color: rgba(255, 74, 74, 0.54);
}

.contact-input-wrap {
    position: relative;
    display: block;
}

.contact-input-wrap svg {
    position: absolute;
    left: 1rem;
    top: 50%;
    z-index: 2;
    color: rgba(255, 255, 255, 0.62);
    transform: translateY(-50%);
    pointer-events: none;
}

.contact-input-wrap input {
    padding-left: 3rem;
}

.contact-premium-form textarea {
    min-height: 128px;
    resize: vertical;
    padding-bottom: 2rem;
}

.contact-message-count {
    justify-self: end;
    margin-top: -2rem;
    margin-right: 0.9rem;
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.78rem;
    pointer-events: none;
}

.contact-legal-box {
    display: grid;
    gap: 0.72rem;
    margin-top: 0.15rem;
    padding: 1rem;
    border: 1px solid rgba(157, 190, 246, 0.18);
    background: rgba(255, 255, 255, 0.024);
}

.contact-consent {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 0.75rem;
    align-items: start;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.86rem;
    line-height: 1.42;
    font-weight: 650;
}

.contact-consent input {
    width: 18px;
    min-height: 18px;
    height: 18px;
    margin-top: 0.05rem;
    accent-color: var(--sbi-blue);
}

.contact-legal-note {
    margin: 0;
    color: rgba(255, 255, 255, 0.52);
    font-size: 0.78rem;
    line-height: 1.55;
}

.contact-form-status {
    min-height: 1.3rem;
    margin: 0;
    color: #c6ddff;
    font-size: 0.9rem;
    font-weight: 750;
    line-height: 1.35;
}

.contact-form-status.is-error {
    color: #ff8c8c;
}

.contact-form-status.is-success {
    color: #c6ddff;
}

.contact-submit {
    width: 100%;
    min-height: 58px;
    justify-content: center;
    font-size: 1.05rem;
}

.contact-submit[disabled] {
    cursor: wait;
    opacity: 0.82;
    transform: none;
}

.sbi-signal-contact {
    --signal-size: 30px;
    --signal-bubble-lift: -10px;
    --signal-pointer-y: 72%;

    position: absolute;
    top: 2.15rem;
    right: -17px;
    bottom: auto;
    z-index: 80;
    flex-direction: row-reverse;
}

.sbi-signal-contact::before {
    left: auto;
    right: calc(var(--signal-size) * 0.5);
    background: linear-gradient(
        270deg,
        rgba(0, 81, 255, 0.62),
        rgba(0, 81, 255, 0.22),
        transparent
    );
}

.sbi-signal-contact::after {
    left: auto;
    right: calc(var(--signal-size) + 0.52rem);
    top: calc(50% + var(--signal-bubble-lift) + 8px);
    clip-path: polygon(100% 50%, 0 0, 0 100%);
}

.sbi-signal-contact .sbi-signal-panel {
    max-width: min(320px, 72vw);
    white-space: normal;
    line-height: 1.25;
    transform: translateX(14px) scale(0.96);
}

.sbi-signal-contact.is-revealed .sbi-signal-panel,
.sbi-signal-contact:hover .sbi-signal-panel,
.sbi-signal-contact:focus-visible .sbi-signal-panel {
    transform: translateX(0) scale(1);
}

.contact-form-card.is-error .sbi-signal-contact {
    --signal-blue: #ff4a4a;
    --signal-panel-border: rgba(255, 74, 74, 0.58);
}

.contact-form-card.is-error .sbi-signal-dot {
    background: linear-gradient(135deg, rgba(255, 74, 74, 0.94), rgba(255, 74, 74, 1));
    box-shadow:
        0 0 12px rgba(255, 74, 74, 0.58),
        0 0 26px rgba(255, 74, 74, 0.24);
}

.contact-form-card.is-error .sbi-signal-dot::before {
    background: radial-gradient(
        circle,
        rgba(255, 74, 74, 0.48) 0%,
        rgba(255, 74, 74, 0.20) 38%,
        rgba(255, 74, 74, 0.06) 58%,
        transparent 74%
    );
}

.contact-form-card.is-success .sbi-signal-contact {
    --signal-blue: var(--sbi-blue);
    --signal-panel-border: rgba(0, 132, 255, 0.82);
}

.contact-form-card.is-success .sbi-signal-contact.is-revealed .sbi-signal-panel {
    opacity: 1;
    pointer-events: auto;
}

@keyframes contactCornerPulse {
    0% { filter: brightness(0.9); }
    100% { filter: brightness(1.18); }
}

@keyframes contactSuccessFlash {
    0% { box-shadow: inset 0 0 0 rgba(0, 81, 255, 0); }
    45% { box-shadow: inset 0 0 28px rgba(0, 81, 255, 0.11); }
    100% { box-shadow: inset 0 0 0 rgba(0, 81, 255, 0); }
}

@keyframes contactErrorShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-4px); }
    50% { transform: translateX(4px); }
    75% { transform: translateX(-2px); }
}

@media (max-width: 1180px) {
    .contact-premium-grid {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .contact-story {
        min-height: auto;
        padding-top: 0;
    }

    .contact-feature-list {
        margin-top: 0;
        padding-top: 2.4rem;
    }

    .contact-ghost-logo {
        width: min(90vw, 640px);
        left: 18%;
        top: 14%;
    }
}

@media (max-width: 768px) {
    .contact-premium-hero {
        min-height: auto;
        padding-top: calc(var(--header-height) + 1.6rem);
        padding-bottom: 2.8rem;
    }

    .contact-video-bg {
        display: none;
    }

    .contact-video-mask {
        background:
            radial-gradient(circle at 80% 12%, rgba(0, 81, 255, 0.14), transparent 38%),
            linear-gradient(180deg, rgba(4, 5, 8, 0.98), rgba(4, 5, 8, 0.94));
    }

    .contact-premium-hero::before {
        opacity: 0.35;
    }

    .contact-premium-hero::after,
    .contact-orbit {
        display: none;
    }

    .contact-title {
        font-size: clamp(2.75rem, 15vw, 4.4rem);
    }

    .contact-lead {
        font-size: 1rem;
        line-height: 1.62;
    }

    .contact-direct-lines {
        gap: 0.62rem;
    }

    .contact-direct-link {
        min-width: 100%;
    }

    .contact-ghost-logo {
        width: 112vw;
        left: 2%;
        top: 14%;
        opacity: 0.09;
    }

    .contact-feature-list {
        gap: 1rem;
    }

    .contact-feature {
        grid-template-columns: 54px minmax(0, 1fr);
    }

    .contact-feature-icon {
        width: 46px;
        height: 46px;
    }

    .contact-form-card {
        min-height: auto;
    }

    .contact-card-inner {
        padding: 2.2rem 1.2rem 2.4rem;
    }

    .contact-card-kicker {
        margin-left: 24px;
    }

    .contact-card-title {
        font-size: 2.25rem;
    }

    .contact-form-grid {
        grid-template-columns: 1fr;
    }

    .contact-profile-tab {
        flex: 1 1 calc(50% - 0.4rem);
        justify-content: center;
        text-align: center;
        padding-left: 0.7rem;
        padding-right: 0.7rem;
    }

    .sbi-signal-contact {
        position: relative;
        right: auto;
        bottom: auto;
        margin-top: 1.1rem;
        justify-content: flex-end;
    }

    .sbi-signal-contact .sbi-signal-panel,
    .sbi-signal-contact::after {
        display: none;
    }
}

@media (max-width: 480px) {
    .contact-profile-tab {
        flex-basis: 100%;
    }

    .contact-submit {
        min-height: 54px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .contact-card-cut,
    .contact-form-card,
    .sbi-signal-contact .sbi-signal-dot,
    .sbi-signal-contact .sbi-signal-dot::before,
    .sbi-signal-contact .sbi-signal-dot::after {
        animation: none !important;
    }
}


/* =========================================================
   SBI 8.0P.45 - CONTACT VISUAL CLEANUP + CONTACT DETAILS
   ---------------------------------------------------------
   Correctifs desktop : une seule vue, fond plus proche index,
   assistant plaqué sur l'arête, bouton allumé seulement quand prêt.
   ========================================================= */

body[data-sbi-public-page="contact"] .contact-orbit,
body[data-sbi-public-page="contact"] .contact-premium-hero::after {
    display: none;
}

body[data-sbi-public-page="contact"] .sbi-bg-parallax,
body[data-sbi-public-page="contact"] .sbi-line {
    display: none !important;
}

body[data-sbi-public-page="contact"] .contact-premium-hero::before {
    background:
        radial-gradient(circle at 26% 26%, rgba(0, 81, 255, 0.13), transparent 30%),
        radial-gradient(circle at 74% 54%, rgba(0, 132, 255, 0.11), transparent 38%),
        radial-gradient(circle at 50% 96%, rgba(0, 81, 255, 0.08), transparent 42%);
    opacity: 0.82;
}

body[data-sbi-public-page="contact"] .contact-video-bg {
    opacity: 0.46;
    filter: contrast(1.15) brightness(0.94) saturate(1.12);
    mix-blend-mode: normal;
}

body[data-sbi-public-page="contact"] .contact-video-mask {
    background:
        linear-gradient(90deg, rgba(4, 5, 8, 0.88) 0%, rgba(4, 5, 8, 0.46) 42%, rgba(4, 5, 8, 0.78) 100%),
        radial-gradient(circle at 54% 44%, rgba(0, 81, 255, 0.07), transparent 34%),
        radial-gradient(circle at 20% 70%, rgba(0, 81, 255, 0.08), transparent 34%);
}

body[data-sbi-public-page="contact"] .contact-card-inner::before {
    background:
        radial-gradient(circle at 100% 0%, rgba(0, 81, 255, 0.075), transparent 34%),
        radial-gradient(circle at 0% 100%, rgba(0, 132, 255, 0.045), transparent 40%);
    opacity: 0.72;
}

body[data-sbi-public-page="contact"] .contact-card-inner::after {
    content: none;
    display: none;
}

body[data-sbi-public-page="contact"] .contact-submit {
    background: rgba(0, 81, 255, 0.42);
    border-color: rgba(157, 190, 246, 0.20);
    box-shadow: none;
    filter: saturate(0.72) brightness(0.88);
}

body[data-sbi-public-page="contact"] .contact-submit:hover {
    transform: none;
    background: rgba(0, 81, 255, 0.48);
    box-shadow: none;
}

body[data-sbi-public-page="contact"] .contact-submit.is-ready-to-send,
body[data-sbi-public-page="contact"] .contact-form-card.is-ready-to-send .contact-submit {
    background: var(--sbi-blue);
    border-color: rgba(255, 255, 255, 0.18);
    box-shadow:
        0 12px 26px rgba(0, 0, 0, 0.28),
        0 0 22px rgba(0, 81, 255, 0.24);
    filter: none;
}

body[data-sbi-public-page="contact"] .contact-submit.is-ready-to-send:hover,
body[data-sbi-public-page="contact"] .contact-form-card.is-ready-to-send .contact-submit:hover {
    transform: translateY(-2px);
    background: var(--sbi-blue-hover);
    box-shadow:
        0 12px 28px rgba(0, 0, 0, 0.32),
        0 0 26px rgba(0, 81, 255, 0.28);
}

body[data-sbi-public-page="contact"] .sbi-signal-contact {
    position: absolute;
    top: 2.05rem;
    right: -17px;
    bottom: auto;
    z-index: 80;
    flex-direction: row-reverse;
}

@media (min-width: 1025px) {
    body[data-sbi-public-page="contact"] {
        overflow: hidden;
    }

    body[data-sbi-public-page="contact"] #contact-footer {
        display: none;
    }

    body[data-sbi-public-page="contact"] .contact-page {
        height: 100dvh;
        min-height: 100dvh;
        overflow: hidden;
    }

    body[data-sbi-public-page="contact"] .contact-premium-hero {
        display: flex;
        align-items: center;
        min-height: 0;
        height: 100dvh;
        padding-top: calc(var(--header-height) + 0.55rem);
        padding-bottom: 0.75rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-grid {
        width: 100%;
        height: calc(100dvh - var(--header-height) - 1.3rem);
        max-height: 850px;
        grid-template-columns: minmax(0, 0.98fr) minmax(390px, 525px);
        gap: clamp(1.8rem, 4.6vw, 5rem);
        align-items: center;
    }

    body[data-sbi-public-page="contact"] .contact-story {
        min-height: 0;
        height: 100%;
        justify-content: center;
        padding: 0;
    }

    body[data-sbi-public-page="contact"] .contact-title {
        margin-top: 0.55rem;
        font-size: clamp(3.2rem, 5.35vw, 5.95rem);
        line-height: 0.9;
    }

    body[data-sbi-public-page="contact"] .contact-lead {
        max-width: 520px;
        margin-top: 0.95rem;
        font-size: clamp(0.9rem, 0.98vw, 1.02rem);
        line-height: 1.55;
    }

    body[data-sbi-public-page="contact"] .contact-lead::before {
        width: 58px;
        height: 2px;
        margin-bottom: 1rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-lines {
        gap: 0.52rem;
        margin-top: 0.78rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-link {
        min-width: 0;
        padding: 0.54rem 0.7rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-link span {
        font-size: 0.62rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-link strong {
        font-size: 0.82rem;
    }

    body[data-sbi-public-page="contact"] .contact-ghost-logo {
        width: min(48vw, 610px);
        left: 8%;
        top: 27%;
        opacity: 0.19;
    }

    body[data-sbi-public-page="contact"] .contact-feature-list {
        gap: 0.72rem;
        max-width: 520px;
        margin-top: 1.65rem;
        padding-top: 0;
    }

    body[data-sbi-public-page="contact"] .contact-feature {
        grid-template-columns: 44px minmax(0, 1fr);
        gap: 0.74rem;
    }

    body[data-sbi-public-page="contact"] .contact-feature-icon {
        width: 36px;
        height: 36px;
    }

    body[data-sbi-public-page="contact"] .contact-feature-icon svg {
        width: 17px;
        height: 17px;
    }

    body[data-sbi-public-page="contact"] .contact-feature h2 {
        margin-bottom: 0.08rem;
        font-size: 0.98rem;
    }

    body[data-sbi-public-page="contact"] .contact-feature p {
        font-size: 0.81rem;
        line-height: 1.25;
    }

    body[data-sbi-public-page="contact"] .contact-form-card {
        min-height: 0;
        height: 100%;
        max-height: calc(100dvh - var(--header-height) - 1.35rem);
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        display: flex;
        flex-direction: column;
        min-height: 100%;
        height: 100%;
        padding: clamp(0.95rem, 1.35vw, 1.45rem) clamp(1.15rem, 1.8vw, 1.85rem);
        overflow: visible;
    }

    body[data-sbi-public-page="contact"] .contact-card-badge {
        top: 16px;
        left: 16px;
        width: 36px;
        height: 36px;
    }

    body[data-sbi-public-page="contact"] .contact-card-cut {
        width: 60px;
        height: 60px;
    }

    body[data-sbi-public-page="contact"] .contact-card-kicker {
        margin-left: 30px;
        font-size: 0.68rem;
        gap: 0.46rem;
    }

    body[data-sbi-public-page="contact"] .contact-kicker-icon {
        width: 27px;
        height: 27px;
    }

    body[data-sbi-public-page="contact"] .contact-card-title {
        margin-top: 0.55rem;
        font-size: clamp(1.85rem, 2.35vw, 2.35rem);
    }

    body[data-sbi-public-page="contact"] .contact-card-copy {
        margin-top: 0.35rem;
        font-size: 0.84rem;
        line-height: 1.38;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form {
        flex: 1 1 auto;
        display: grid;
        align-content: start;
        gap: 0.54rem;
        margin-top: 0.72rem;
    }

    body[data-sbi-public-page="contact"] .contact-form-grid {
        gap: 0.62rem;
    }

    body[data-sbi-public-page="contact"] .contact-field,
    body[data-sbi-public-page="contact"] .contact-profile-tabs {
        gap: 0.24rem;
        font-size: 0.78rem;
        line-height: 1.12;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tabs {
        gap: 0.38rem;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tabs legend {
        margin-bottom: 0.02rem;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tab {
        min-height: 31px;
        padding: 0.42rem 0.56rem;
        font-size: 0.72rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form input,
    body[data-sbi-public-page="contact"] .contact-premium-form select,
    body[data-sbi-public-page="contact"] .contact-premium-form textarea {
        min-height: 38px;
        padding: 0.58rem 0.72rem;
        font-size: 0.8rem;
    }

    body[data-sbi-public-page="contact"] .contact-input-wrap input {
        padding-left: 2.42rem;
    }

    body[data-sbi-public-page="contact"] .contact-input-wrap svg {
        left: 0.78rem;
        width: 15px;
        height: 15px;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form textarea {
        min-height: 68px;
        max-height: 86px;
        padding-bottom: 1.45rem;
        resize: none;
    }

    body[data-sbi-public-page="contact"] .contact-message-count {
        margin-top: -1.55rem;
        margin-right: 0.65rem;
        font-size: 0.66rem;
    }

    body[data-sbi-public-page="contact"] .contact-legal-box {
        gap: 0.36rem;
        margin-top: 0;
        padding: 0.56rem 0.62rem;
    }

    body[data-sbi-public-page="contact"] .contact-consent {
        grid-template-columns: 14px minmax(0, 1fr);
        gap: 0.5rem;
        font-size: 0.68rem;
        line-height: 1.22;
    }

    body[data-sbi-public-page="contact"] .contact-consent input {
        width: 14px;
        height: 14px;
        min-height: 14px;
    }

    body[data-sbi-public-page="contact"] .contact-legal-note {
        font-size: 0.62rem;
        line-height: 1.26;
    }

    body[data-sbi-public-page="contact"] .contact-form-status {
        min-height: 0.9rem;
        font-size: 0.72rem;
        line-height: 1.2;
    }

    body[data-sbi-public-page="contact"] .contact-submit {
        min-height: 42px;
        padding-top: 0.56rem;
        padding-bottom: 0.56rem;
        font-size: 0.9rem;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact {
        top: 1.25rem;
        right: -17px;
        bottom: auto;
        z-index: 80;
    }
}

@media (min-width: 1025px) and (max-height: 780px) {
    body[data-sbi-public-page="contact"] .contact-card-copy,
    body[data-sbi-public-page="contact"] .contact-legal-note {
        display: none;
    }

    body[data-sbi-public-page="contact"] .contact-title {
        font-size: clamp(2.8rem, 4.8vw, 5.1rem);
    }

    body[data-sbi-public-page="contact"] .contact-lead {
        max-width: 500px;
        font-size: 0.84rem;
        line-height: 1.42;
    }

    body[data-sbi-public-page="contact"] .contact-feature-list {
        gap: 0.48rem;
        margin-top: 1.2rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-lines {
        margin-top: 0.62rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-link {
        padding-top: 0.44rem;
        padding-bottom: 0.44rem;
    }

    body[data-sbi-public-page="contact"] .contact-feature p {
        display: none;
    }

    body[data-sbi-public-page="contact"] .contact-card-title {
        margin-top: 0.32rem;
        font-size: 1.65rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form {
        gap: 0.38rem;
        margin-top: 0.48rem;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tab {
        min-height: 27px;
        padding-top: 0.32rem;
        padding-bottom: 0.32rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form input,
    body[data-sbi-public-page="contact"] .contact-premium-form select,
    body[data-sbi-public-page="contact"] .contact-premium-form textarea {
        min-height: 34px;
        padding-top: 0.45rem;
        padding-bottom: 0.45rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form textarea {
        min-height: 54px;
        max-height: 62px;
    }

    body[data-sbi-public-page="contact"] .contact-legal-box {
        gap: 0.28rem;
        padding: 0.46rem 0.54rem;
    }

    body[data-sbi-public-page="contact"] .contact-submit {
        min-height: 38px;
    }
}

/* =========================================================
   SBI 8.0P.65 - CONTACT MOBILE STRUCTURE ALIGNMENT
   ---------------------------------------------------------
   Mobile raccordé à la logique index : topbar commune via sbi-mobile,
   fond vidéo conservé en douceur et page empilée proprement.
   ========================================================= */

@media (max-width: 768px) {
    body[data-sbi-public-page="contact"] .contact-page {
        min-height: auto;
        overflow: hidden;
        background:
            radial-gradient(circle at 70% 0%, rgba(0, 81, 255, 0.12), transparent 42%),
            linear-gradient(180deg, rgba(3, 7, 14, 0.98), rgba(4, 7, 12, 0.98));
    }

    body[data-sbi-public-page="contact"] .contact-premium-hero {
        min-height: auto;
        padding-top: calc(78px + 1.1rem);
        padding-bottom: 3.2rem;
        overflow: hidden;
    }

    body[data-sbi-public-page="contact"] .contact-video-bg {
        display: block;
        opacity: 0.24;
        filter: grayscale(0.3) contrast(1.12) brightness(0.62) saturate(1.05);
        mix-blend-mode: screen;
        -webkit-mask-image:
            linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%),
            linear-gradient(180deg, transparent 0%, #000 8%, #000 82%, transparent 100%);
        mask-image:
            linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%),
            linear-gradient(180deg, transparent 0%, #000 8%, #000 82%, transparent 100%);
    }

    body[data-sbi-public-page="contact"] .contact-video-mask {
        background:
            linear-gradient(180deg, rgba(3, 7, 14, 0.94) 0%, rgba(3, 7, 14, 0.58) 34%, rgba(3, 7, 14, 0.96) 100%),
            radial-gradient(circle at 78% 12%, rgba(0, 81, 255, 0.14), transparent 40%),
            radial-gradient(circle at 18% 58%, rgba(0, 132, 255, 0.08), transparent 34%);
    }

    body[data-sbi-public-page="contact"] .contact-premium-hero::before {
        opacity: 0.38;
    }

    body[data-sbi-public-page="contact"] .contact-premium-grid {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 1.5rem;
        width: 100%;
        max-width: 640px;
        margin: 0 auto;
    }

    body[data-sbi-public-page="contact"] .contact-story {
        min-height: auto;
        padding: 0;
        justify-content: flex-start;
    }

    body[data-sbi-public-page="contact"] .contact-title {
        max-width: min(100%, 24rem);
        margin-top: 0.7rem;
        font-size: clamp(2.75rem, 14vw, 4.2rem);
        line-height: 0.96;
        letter-spacing: -0.062em;
    }

    body[data-sbi-public-page="contact"] .contact-lead {
        max-width: min(100%, 23rem);
        margin-top: 1.15rem;
        font-size: 0.98rem;
        line-height: 1.58;
    }

    body[data-sbi-public-page="contact"] .contact-lead::before {
        width: 54px;
        height: 2px;
        margin-bottom: 1rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-lines {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.72rem;
        margin-top: 1.2rem;
    }

    body[data-sbi-public-page="contact"] .contact-direct-link {
        min-width: 0;
        width: 100%;
        padding: 0.82rem 0.92rem;
    }

    body[data-sbi-public-page="contact"] .contact-ghost-logo {
        width: min(108vw, 460px);
        left: auto;
        right: -18%;
        top: 2.3rem;
        opacity: 0.075;
    }

    body[data-sbi-public-page="contact"] .contact-feature-list {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.85rem;
        max-width: none;
        margin-top: 1.35rem;
        padding-top: 0;
    }

    body[data-sbi-public-page="contact"] .contact-feature {
        grid-template-columns: 46px minmax(0, 1fr);
        gap: 0.8rem;
        padding: 0.95rem;
        background: rgba(255, 255, 255, 0.025);
        border: 1px solid rgba(157, 190, 246, 0.14);
    }

    body[data-sbi-public-page="contact"] .contact-feature-icon {
        width: 42px;
        height: 42px;
    }

    body[data-sbi-public-page="contact"] .contact-feature h2 {
        font-size: 0.98rem;
    }

    body[data-sbi-public-page="contact"] .contact-feature p {
        font-size: 0.82rem;
        line-height: 1.38;
    }

    body[data-sbi-public-page="contact"] .contact-form-card {
        min-height: auto;
        height: auto;
        margin-top: 0;
        border-color: rgba(157, 190, 246, 0.18);
        background:
            linear-gradient(145deg, rgba(7, 13, 27, 0.78), rgba(4, 8, 17, 0.92));
        box-shadow:
            0 20px 42px rgba(0, 0, 0, 0.34),
            inset 0 0 0 1px rgba(255, 255, 255, 0.035);
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        padding: 2rem 1.1rem 2.25rem;
    }

    body[data-sbi-public-page="contact"] .contact-card-kicker {
        margin-left: 22px;
    }

    body[data-sbi-public-page="contact"] .contact-card-title {
        font-size: clamp(2rem, 10vw, 2.65rem);
    }

    body[data-sbi-public-page="contact"] .contact-card-copy {
        font-size: 0.92rem;
        line-height: 1.45;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form {
        gap: 0.9rem;
        margin-top: 1.1rem;
    }

    body[data-sbi-public-page="contact"] .contact-form-grid {
        grid-template-columns: 1fr;
        gap: 0.9rem;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tabs {
        gap: 0.55rem;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tab {
        flex: 1 1 calc(50% - 0.4rem);
        justify-content: center;
        min-height: 42px;
        padding: 0.72rem 0.68rem;
        text-align: center;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form input,
    body[data-sbi-public-page="contact"] .contact-premium-form select,
    body[data-sbi-public-page="contact"] .contact-premium-form textarea {
        min-height: 48px;
        font-size: 0.95rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form textarea {
        min-height: 132px;
    }

    body[data-sbi-public-page="contact"] .contact-submit {
        min-height: 54px;
    }

    body[data-sbi-public-page="contact"] .contact-submit {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
        padding-left: 1rem;
        padding-right: 1rem;
        overflow: hidden;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
    }

    body[data-sbi-public-page="contact"] .contact-submit .arrow {
        flex: 0 0 auto;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact {
        position: relative;
        top: auto;
        right: auto;
        bottom: auto;
        margin-top: 1rem;
        justify-content: flex-end;
    }
}

@media (max-width: 480px) {
    body[data-sbi-public-page="contact"] .contact-feature-list {
        gap: 0.72rem;
    }

    body[data-sbi-public-page="contact"] .contact-profile-tab {
        flex-basis: 100%;
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        padding-left: 1rem;
        padding-right: 1rem;
    }


    body[data-sbi-public-page="contact"] .contact-submit {
        min-height: 50px;
        padding-left: 0.82rem;
        padding-right: 0.82rem;
        font-size: 0.88rem;
    }
}

/* =========================================================
   SBI 8.0P.69 - CONTACT MOBILE SUBMIT CONTAINMENT
   ---------------------------------------------------------
   Sécurise le bouton d'envoi sur petits écrans et évite tout
   débordement horizontal lié au texte, au padding ou à la flèche.
   ========================================================= */
body[data-sbi-public-page="contact"] .contact-premium-form,
body[data-sbi-public-page="contact"] .contact-form-card,
body[data-sbi-public-page="contact"] .contact-card-inner {
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

body[data-sbi-public-page="contact"] .contact-submit {
    inline-size: 100%;
    max-inline-size: 100%;
    min-inline-size: 0;
    box-sizing: border-box;
}

body[data-sbi-public-page="contact"] .contact-submit span:first-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 520px) {
    body[data-sbi-public-page="contact"] .contact-submit {
        display: flex;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        flex-wrap: nowrap;
        gap: 0.42rem;
        padding: 0.82rem 0.72rem;
        white-space: normal;
        overflow-wrap: anywhere;
        transform: none;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%);
    }

    body[data-sbi-public-page="contact"] .contact-submit:hover {
        transform: none;
    }

    body[data-sbi-public-page="contact"] .contact-submit .arrow {
        flex: 0 0 auto;
        margin-left: 0;
    }
}

@media (max-width: 380px) {
    body[data-sbi-public-page="contact"] .contact-card-inner {
        padding-left: 0.82rem;
        padding-right: 0.82rem;
    }

    body[data-sbi-public-page="contact"] .contact-submit {
        padding-left: 0.62rem;
        padding-right: 0.62rem;
        font-size: 0.82rem;
        letter-spacing: 0.01em;
    }
}


/* =========================================================
   SBI 8.0P.70 - CONTACT LOW HEIGHT CONTAINMENT
   ---------------------------------------------------------
   Corrige le débordement vertical du bouton d’envoi lorsque
   la hauteur d’écran est courte en desktop/intermédiaire.
   Le cadre n'est plus verrouillé à 100dvh : il peut grandir
   naturellement et rester scrollable au lieu de laisser le
   bouton sortir sous la bordure.
   ========================================================= */
@media (min-width: 1025px) and (max-height: 820px) {
    body[data-sbi-public-page="contact"] .contact-page {
        min-height: 100dvh;
        overflow-x: hidden;
        overflow-y: auto;
    }

    body[data-sbi-public-page="contact"] .contact-premium-hero {
        min-height: auto;
        height: auto;
        overflow: visible;
        padding-top: calc(var(--header-height) + 0.45rem);
        padding-bottom: 1.65rem;
    }

    body[data-sbi-public-page="contact"] .contact-premium-grid {
        height: auto;
        max-height: none;
        align-items: start;
    }

    body[data-sbi-public-page="contact"] .contact-form-card {
        min-height: 0;
        height: auto;
        max-height: none;
        align-self: start;
        overflow: visible;
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        min-height: 0;
        height: auto;
        padding-bottom: 1.9rem;
        overflow: hidden;
    }

    body[data-sbi-public-page="contact"] .contact-premium-form {
        flex: initial;
        align-content: start;
    }

    body[data-sbi-public-page="contact"] .contact-submit,
    body[data-sbi-public-page="contact"] .contact-submit:hover,
    body[data-sbi-public-page="contact"] .contact-submit.is-ready-to-send:hover,
    body[data-sbi-public-page="contact"] .contact-form-card.is-ready-to-send .contact-submit:hover {
        transform: none;
    }
}


/* =========================================================
   SBI 8.0P.72 - CONTACT MOBILE FRAME CLEANUP
   ---------------------------------------------------------
   Supprime le faux double cadre en bas du formulaire mobile.
   Le signal assistant décoratif était sorti du bloc interne et
   ajoutait une zone basse vide avec un losange bleu. Sur mobile,
   le statut visible reste géré par .contact-form-status.
   ========================================================= */
@media (max-width: 768px) {
    body[data-sbi-public-page="contact"] .contact-form-card {
        overflow: hidden;
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        min-height: 0;
        height: auto;
        padding-bottom: 2rem;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact {
        display: none !important;
    }

    body[data-sbi-public-page="contact"] .contact-card-cut {
        right: -1px;
        bottom: -1px;
    }
}


/* =========================================================
   SBI 8.0P.73 - CONTACT MOBILE SINGLE FRAME + ASSISTANT
   ---------------------------------------------------------
   Garde l'assistant visible sur mobile sans recréer une seconde
   zone sous le formulaire. Le cadre mobile n'a plus de double
   bordure interne/externe.
   ========================================================= */
@media (max-width: 768px) {
    body[data-sbi-public-page="contact"],
    body[data-sbi-public-page="contact"] .contact-page,
    body[data-sbi-public-page="contact"] .contact-premium-hero {
        overflow-x: hidden;
    }

    body[data-sbi-public-page="contact"] .contact-form-card {
        position: relative;
        padding: 1px;
        overflow: hidden;
        border-color: rgba(126, 181, 255, 0.30);
        background: linear-gradient(145deg, rgba(23, 39, 69, 0.42), rgba(4, 8, 17, 0.96));
        box-shadow: 0 18px 42px rgba(0, 0, 0, 0.36);
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        border: 0;
        min-height: 0;
        height: auto;
        padding-bottom: 2.25rem;
        overflow: hidden;
        background:
            linear-gradient(180deg, rgba(7, 12, 23, 0.95), rgba(3, 7, 14, 0.97)),
            radial-gradient(circle at 92% 0%, rgba(0, 81, 255, 0.10), transparent 36%);
    }

    body[data-sbi-public-page="contact"] .contact-card-inner::before {
        opacity: 0.38;
    }

    body[data-sbi-public-page="contact"] .contact-card-cut {
        right: 0;
        bottom: 0;
        width: 52px;
        height: 52px;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact {
        display: inline-flex !important;
        position: absolute;
        top: 1rem;
        right: 1rem;
        bottom: auto;
        z-index: 9;
        margin: 0;
        transform: none;
        flex-direction: row-reverse;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact::before,
    body[data-sbi-public-page="contact"] .sbi-signal-contact::after,
    body[data-sbi-public-page="contact"] .sbi-signal-contact .sbi-signal-panel {
        display: none !important;
    }
}


/* =========================================================
   SBI 8.0P.74 - CONTACT MOBILE FRAME + FEEDBACK ANCHOR
   ---------------------------------------------------------
   Mobile : un seul cadre lisible, assistant conservé en haut
   de carte et plus aucun faux double contour bas.
   ========================================================= */
@media (max-width: 768px) {
    body[data-sbi-public-page="contact"] .contact-form-card {
        padding: 0 !important;
        border: 1px solid rgba(92, 131, 196, 0.58);
        background: rgba(7, 12, 23, 0.96) !important;
        box-shadow:
            0 20px 54px rgba(0, 0, 0, 0.48),
            0 0 28px rgba(0, 81, 255, 0.06);
        overflow: visible;
    }

    body[data-sbi-public-page="contact"] .contact-form-card::before {
        content: none !important;
        display: none !important;
    }

    body[data-sbi-public-page="contact"] .contact-card-inner {
        min-height: auto !important;
        height: auto !important;
        border: 0 !important;
        background:
            linear-gradient(180deg, rgba(7, 12, 23, 0.96), rgba(3, 7, 14, 0.98)),
            radial-gradient(circle at 92% 0%, rgba(0, 81, 255, 0.10), transparent 36%) !important;
        box-shadow: none !important;
    }

    body[data-sbi-public-page="contact"] .contact-card-inner::before,
    body[data-sbi-public-page="contact"] .contact-card-inner::after {
        content: none !important;
        display: none !important;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact {
        position: absolute !important;
        top: 1.05rem !important;
        right: 0.9rem !important;
        bottom: auto !important;
        margin: 0 !important;
        z-index: 90;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact::before,
    body[data-sbi-public-page="contact"] .sbi-signal-contact::after {
        display: none !important;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact .sbi-signal-panel {
        display: none !important;
    }

    body[data-sbi-public-page="contact"] .sbi-signal-contact.is-revealed .sbi-signal-panel {
        display: inline-flex !important;
        max-width: min(62vw, 260px);
        min-width: 0;
        white-space: normal;
        line-height: 1.16;
        font-size: 0.68rem;
        padding: 0.66rem 0.78rem;
        transform: translateX(0) scale(1);
    }

    body[data-sbi-public-page="contact"] .contact-submit,
    body[data-sbi-public-page="contact"] .contact-submit.is-ready-to-send,
    body[data-sbi-public-page="contact"] .contact-form-card.is-ready-to-send .contact-submit {
        max-width: 100%;
        transform: none !important;
    }
}

/* =========================================================
   SBI 8.0P.82 - CONTACT CHECKBOX CLEANUP
   ---------------------------------------------------------
   Remplace le rendu natif Android/Samsung des cases par une
   case SBI contrôlée, sans double carré bleu parasite.
   ========================================================= */
body[data-sbi-public-page="contact"] .contact-consent input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    display: inline-grid;
    place-content: center;
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    min-height: 18px;
    margin: 0.05rem 0 0;
    padding: 0;
    border: 1px solid rgba(126, 181, 255, 0.58);
    border-radius: 4px;
    background: rgba(2, 8, 18, 0.92);
    box-shadow: inset 0 0 0 1px rgba(0, 81, 255, 0.10);
    outline: none;
    cursor: pointer;
}

body[data-sbi-public-page="contact"] .contact-consent input[type="checkbox"]::after {
    content: "";
    width: 5px;
    height: 9px;
    border: solid #ffffff;
    border-width: 0 2px 2px 0;
    opacity: 0;
    transform: rotate(45deg) translateY(-1px);
}

body[data-sbi-public-page="contact"] .contact-consent input[type="checkbox"]:checked {
    border-color: rgba(0, 81, 255, 0.95);
    background: var(--sbi-blue);
    box-shadow: 0 0 0 3px rgba(0, 81, 255, 0.12);
}

body[data-sbi-public-page="contact"] .contact-consent input[type="checkbox"]:checked::after {
    opacity: 1;
}

body[data-sbi-public-page="contact"] .contact-consent input[type="checkbox"]:focus-visible {
    outline: 2px solid rgba(126, 181, 255, 0.78);
    outline-offset: 3px;
}

@media (max-width: 768px) {
    body[data-sbi-public-page="contact"] .contact-consent {
        grid-template-columns: 18px minmax(0, 1fr) !important;
        gap: 0.58rem !important;
    }

    body[data-sbi-public-page="contact"] .contact-consent input[type="checkbox"] {
        width: 18px !important;
        height: 18px !important;
        min-height: 18px !important;
        margin-top: 0.02rem !important;
    }
}


/* =========================================================
   SBI 8.0P.87 - Contact frame stability
   ---------------------------------------------------------
   Garde un seul contour lisible sur la carte contact.
   ========================================================= */
body[data-sbi-public-page="contact"] .contact-card-inner {
    border-color: transparent !important;
    box-shadow: none !important;
}

body[data-sbi-public-page="contact"] .contact-form-card::before {
    inset: 0;
}
