/* ══════════════════════════════════════════════
   Ecommerce Infinity — Auth Form v4.0
   Spocket-inspired layout
   All rules !important to override Elementor/theme
══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── Outer wrapper ── */
.ei-wrap {
    font-family: 'Inter', sans-serif !important;
    max-width: 460px !important;
    width: 100% !important;
    margin: 40px auto !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
}

/* ── Title ── */
.ei-title,
h1.ei-title,
h2.ei-title {
    font-family: 'Inter', sans-serif !important;
    font-size: 30px !important;
    font-weight: 800 !important;
    color: #1a1a2e !important;
    letter-spacing: -0.6px !important;
    line-height: 1.25 !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    display: block !important;
}

/* ── Subtitle ── */
.ei-subtitle,
p.ei-subtitle {
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    color: #6b7280 !important;
    line-height: 1.65 !important;
    margin: 0 0 32px 0 !important;
    padding: 0 !important;
    display: block !important;
}

/* ── Grouped fields box (Spocket style) ── */
.ei-fields-group {
    border: 1px solid #d1d9e6 !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    margin-bottom: 20px !important;
    background: #fff !important;
}

.ei-field {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    position: relative !important;
}

/* divider between fields */
.ei-field + .ei-field {
    border-top: 1px solid #e5e9f0 !important;
}

.ei-field input,
.ei-field input[type="text"],
.ei-field input[type="email"],
.ei-field input[type="tel"] {
    width: 100% !important;
    box-sizing: border-box !important;
    background: #ffffff !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 16px 16px !important;
    font-size: 15px !important;
    font-family: 'Inter', sans-serif !important;
    color: #1a1a2e !important;
    outline: none !important;
    display: block !important;
    box-shadow: none !important;
    margin: 0 !important;
    height: auto !important;
    line-height: 1.5 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: background 0.15s ease !important;
}

.ei-field input::placeholder {
    color: #9ca3b0 !important;
    font-family: 'Inter', sans-serif !important;
}

.ei-field input:focus,
.ei-field input[type="text"]:focus,
.ei-field input[type="email"]:focus,
.ei-field input[type="tel"]:focus {
    background: #fafbff !important;
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}

/* ── Gradient Pill Button ── */
.ei-btn,
button.ei-btn,
a.ei-btn {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: linear-gradient(90deg, #5b9cf6 0%, #3b72f0 50%, #2563eb 100%) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 16px 24px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    font-family: 'Inter', sans-serif !important;
    text-align: center !important;
    text-decoration: none !important;
    cursor: pointer !important;
    letter-spacing: -0.1px !important;
    line-height: 1.5 !important;
    box-shadow: 0 4px 20px rgba(59, 114, 240, 0.38) !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: opacity 0.2s ease, transform 0.1s ease, box-shadow 0.2s ease !important;
    margin: 0 !important;
}

.ei-btn:hover,
button.ei-btn:hover,
a.ei-btn:hover {
    opacity: 0.92 !important;
    color: #ffffff !important;
    text-decoration: none !important;
    box-shadow: 0 6px 28px rgba(59, 114, 240, 0.48) !important;
}

.ei-btn:active,
button.ei-btn:active {
    transform: scale(0.98) !important;
}

/* ── Privacy note ── */
.ei-note,
p.ei-note {
    font-family: 'Inter', sans-serif !important;
    text-align: center !important;
    font-size: 12px !important;
    color: #9ca3b0 !important;
    line-height: 1.7 !important;
    margin: 18px 0 0 0 !important;
    padding: 0 !important;
    display: block !important;
}

.ei-note a {
    color: #3b72f0 !important;
    text-decoration: underline !important;
    font-weight: 500 !important;
}

/* ── Error ── */
.ei-error {
    background: #fff2f2 !important;
    border: 1px solid #fcc !important;
    border-radius: 8px !important;
    padding: 11px 14px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    color: #cc2200 !important;
    margin-bottom: 16px !important;
    line-height: 1.5 !important;
    display: block !important;
}

/* ════════════════════════════════════
   THANK YOU PAGE
════════════════════════════════════ */

.ei-ty {
    text-align: center !important;
    padding: 20px 0 !important;
}

.ei-tick {
    width: 64px !important;
    height: 64px !important;
    background: linear-gradient(135deg, #5b9cf6 0%, #2563eb 100%) !important;
    color: #ffffff !important;
    border-radius: 50% !important;
    font-size: 28px !important;
    line-height: 64px !important;
    font-weight: 700 !important;
    font-family: 'Inter', sans-serif !important;
    margin: 0 auto 24px !important;
    display: block !important;
    text-align: center !important;
}

.ei-ty-title,
h2.ei-ty-title {
    font-family: 'Inter', sans-serif !important;
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #1a1a2e !important;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    letter-spacing: -0.5px !important;
    line-height: 1.3 !important;
    border: none !important;
    background: none !important;
    display: block !important;
}

.ei-ty-sub,
p.ei-ty-sub {
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    color: #6b7280 !important;
    line-height: 1.7 !important;
    margin: 0 0 32px 0 !important;
    padding: 0 !important;
    display: block !important;
}

.ei-ty-btn {
    display: inline-block !important;
    width: auto !important;
    padding: 16px 52px !important;
}

/* ════════════════════════════════════
   RESPONSIVE
════════════════════════════════════ */

@media (max-width: 520px) {
    .ei-wrap {
        margin: 24px auto !important;
        padding: 0 16px !important;
    }

    .ei-title,
    h1.ei-title,
    h2.ei-title {
        font-size: 24px !important;
    }

    .ei-ty-title,
    h2.ei-ty-title {
        font-size: 22px !important;
    }

    .ei-ty-btn {
        width: 100% !important;
        display: block !important;
    }
}
