﻿/* ===========================================
   FORGOT PASSWORD — Vape & More
   =========================================== */

.forgot-wrap {
    min-height: 70vh;
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #22C55E 0%, #16A34A 50%, #15803D 100%);
    padding: 60px 20px;
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
}

    .forgot-wrap::before {
        content: '';
        position: absolute;
        width: 380px;
        height: 380px;
        background: rgba(255,255,255,0.08);
        border-radius: 50%;
        top: -120px;
        right: -100px;
        pointer-events: none;
    }

    .forgot-wrap::after {
        content: '';
        position: absolute;
        width: 220px;
        height: 220px;
        background: rgba(255,255,255,0.06);
        border-radius: 50%;
        bottom: -60px;
        left: -50px;
        pointer-events: none;
    }

    .forgot-wrap .container_row {
        display: block !important;
        gap: 0 !important;
        flex-wrap: unset !important;
        justify-content: unset !important;
    }

    .forgot-wrap .container_first_cell,
    .forgot-wrap .container_last_cell {
        display: none !important;
    }

    .forgot-wrap .container_cell,
    .forgot-wrap .container_cell_col8,
    .forgot-wrap .container_cell_col4,
    .forgot-wrap .container_cell_col6 {
        flex: unset !important;
        min-width: unset !important;
        max-width: unset !important;
        overflow: visible !important;
    }

    /* Card */
    .forgot-wrap .payment-details {
        background: #ffffff;
        border-radius: 24px;
        border: none;
        box-shadow: 0 24px 64px rgba(0,0,0,0.20);
        overflow: hidden;
        width: 100%;
        max-width: 460px;
        margin: 0 auto;
        position: relative;
        z-index: 1;
    }

        /* Green top accent bar */
        .forgot-wrap .payment-details::before {
            content: '';
            display: block;
            height: 5px;
            background: linear-gradient(90deg, #22C55E, #15803D);
        }

    .forgot-wrap .title-container {
        padding: 32px 36px 0;
        text-align: center;
    }

    /* Title */
    .forgot-wrap .title-large {
        font-family: 'Luckiest Guy', cursive !important;
        font-size: clamp(1.5rem, 3.5vw, 2rem) !important;
        color: #111111 !important;
        margin: 0 !important;
        line-height: 1.2 !important;
        letter-spacing: 0.02em !important;
    }

    .forgot-wrap .mb-30 {
        margin-bottom: 0 !important;
    }

    .forgot-wrap hr.thick,
    .forgot-wrap hr.no-margins {
        border: none !important;
        border-top: 2px solid #22C55E !important;
        margin: 20px 36px !important;
        opacity: 0.4;
    }

    .forgot-wrap .tab-nav {
        display: none !important;
    }

    .forgot-wrap .tab-panes > div,
    .forgot-wrap .tab-panes .active {
        display: block !important;
        opacity: 1 !important;
        visibility: visible !important;
    }

    .forgot-wrap .tab-content {
        padding: 8px 36px 36px !important;
    }

    .forgot-wrap .registro_area {
        padding: 0 !important;
        margin: 0 !important;
    }

    .forgot-wrap .container_blocks {
        display: block;
    }

    .forgot-wrap .container_block_row {
        display: flex !important;
        flex-direction: column !important;
        gap: 14px !important;
    }

    /* Input */
    .forgot-wrap .form-email,
    .forgot-wrap .form-element {
        width: 100% !important;
        max-width: none !important;
        box-sizing: border-box !important;
        float: none !important;
        display: block !important;
        padding: 14px 22px !important;
        border: 2px solid #e0e0e0 !important;
        border-radius: 50px !important;
        font-family: 'Poppins', sans-serif !important;
        font-weight: 500 !important;
        font-size: 0.95rem !important;
        color: #111111 !important;
        background: #f9f9f9 !important;
        outline: none !important;
        transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
        -webkit-appearance: none !important;
        appearance: none !important;
    }

        .forgot-wrap .form-email:focus,
        .forgot-wrap .form-element:focus {
            border-color: #22C55E !important;
            background: #ffffff !important;
            box-shadow: 0 0 0 4px rgba(34,197,94,0.18) !important;
        }

        .forgot-wrap .form-email::placeholder {
            font-family: 'Poppins', sans-serif;
            font-weight: 400;
            color: #aaaaaa;
        }

    /* Submit button */
    .forgot-wrap .form-submit-button {
        width: 100% !important;
        padding: 15px 24px !important;
        background: #22C55E !important;
        color: #111111 !important;
        font-family: 'Poppins', sans-serif !important;
        font-weight: 700 !important;
        font-size: 0.95rem !important;
        text-transform: uppercase !important;
        letter-spacing: 0.08em !important;
        border: none !important;
        border-radius: 50px !important;
        cursor: pointer !important;
        box-shadow: 0 4px 16px rgba(34,197,94,0.40) !important;
        transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.15s ease !important;
        display: block !important;
        box-sizing: border-box !important;
        -webkit-appearance: none !important;
        appearance: none !important;
        float: none !important;
    }

        .forgot-wrap .form-submit-button:hover {
            background: #16A34A !important;
            transform: translateY(-2px) !important;
            box-shadow: 0 8px 24px rgba(34,197,94,0.50) !important;
        }

        .forgot-wrap .form-submit-button:active {
            transform: translateY(1px) !important;
            box-shadow: 0 2px 8px rgba(34,197,94,0.30) !important;
        }

@media (max-width: 520px) {
    .forgot-wrap {
        padding: 40px 16px;
        align-items: flex-start;
    }

        .forgot-wrap .payment-details {
            border-radius: 18px;
        }

        .forgot-wrap .title-container {
            padding: 28px 20px 0 !important;
        }

        .forgot-wrap hr.thick {
            margin: 16px 20px !important;
        }

        .forgot-wrap .tab-content {
            padding: 8px 20px 28px !important;
        }

        .forgot-wrap .title-large {
            font-size: 1.3rem !important;
        }
}
