:root {
    /* Exam Jeetoo header/menu palette */
    --ej-white: #ffffff;
    --ej-black: #000000;
    --ej-border: #d1d5db;
    --ej-border-light: #e5e7eb;
    --ej-primary: #6b8e23;
    --ej-primary-hover: #5a7a1e;
    --ej-text: #374151;
    --ej-text-muted: #4b5563;
    --ej-text-placeholder: #9ca3af;
    --ej-tagline: #8b6914;
    --ej-cart-icon: #6b7280;
    --ej-bg-input: #f3f4f6;
    --ej-bg-hover: #f3f4f6;
    --ej-shadow: rgba(0, 0, 0, 0.12);

    /* Shared */
    --color-error: #dc2626;

    /* Feedback */
    --color-success-bg: #d4edda;
    --color-success-text: #155724;
    --color-error-bg: #f8d7da;
    --color-error-text: #721c24;
    --color-error: red;

    /* Shadows & overlays */
    --color-shadow: #00000040;
    --color-shadow-gray: #80808040;
    --color-overlay: rgba(0, 0, 0, 0.5);
    --color-box-shadow: rgba(0, 0, 0, 0.2);
    --color-box-shadow-strong: rgba(0, 0, 0, 0.25);

    /* Neutrals */
    --color-white: #fff;
    --color-black: #000;
    --color-gray-100: #f5f5f5;
    --color-gray-200: #eee;
    --color-gray-300: #E8E8E8;
    --color-gray-400: #ddd;
    --color-gray-500: #D9D9D9;
    --color-gray-600: #dbdbdb;
    --color-gray-700: #999999;
    --color-gray-800: #919191;
    --color-gray-900: #666;
    --color-gray-950: #555555;
    --color-silver: #B4B4B4;
    --color-slate: #585858;
    --color-muted: #ADA9A9;
    --color-placeholder: #aaa;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: "Inter", sans-serif;
}

body {
    position: relative;
    scroll-behavior: smooth;
}

a {
    text-decoration: none;
}

button {
    cursor: pointer;
}

img {
    width: 100%;
    height: auto;
    display: block;
}

.clearfix::after {
    content: "";
    clear: both;
    display: table;
}

.error {
    color: var(--color-error);
    font-size: 0.7em;
}


/************ Exam Jeetoo Header *************/

.inner{
    width: 95%;
    margin: 1.5vw auto 0;
}

.ej-header {
    background-color: var(--ej-white);
    border-bottom: 0.05vw solid var(--ej-border-light);
    font-family: "Poppins", ui-sans-serif, system-ui, sans-serif;
}

.disclaimer {
    background-color: #FF9437;
    color: #000;
    padding: 0.7vw 0;
    text-align: center;
    font-size: 0.8vw;
    font-weight: 600;
}

.ej-header-inner {
    max-width: 90vw;
    margin: 0 auto;
}

.ej-header-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5vw;
    padding: 0.7vw 0;
}

.ej-logo {
    flex: 0 0 auto;
    max-width: 10vw;
}

.ej-logo img {
    width: auto;
    height: 7vw;
}

.ej-logo-link {
    display: block;
}

.ej-search-wrap {
    flex: 1 1 auto;
    max-width: 45vw;
}

.ej-search-form {
    display: flex;
    align-items: center;
    background-color: var(--ej-bg-input);
    border: 0.05vw solid var(--ej-border-light);
    border-radius: 999px;
    overflow: hidden;
}

.ej-search-input {
    flex: 1 1 auto;
    border: none;
    outline: none;
    background: transparent;
    padding: 0.6vw 1vw;
    font-size: 0.9vw;
    color: var(--ej-text);
}

.ej-search-input::placeholder {
    color: var(--ej-text-placeholder);
}

.ej-search-btn {
    flex: 0 0 auto;
    width: 2.2vw;
    height: 2.2vw;
    margin: 0.2vw;
    border-radius: 50%;
    border: none;
    background-color: var(--ej-primary);
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.ej-search-btn i {
    font-size: 0.9vw;
}

.ej-search-btn:hover {
    background-color: var(--ej-primary-hover);
}

.ej-header-actions {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 1vw;
    font-size: 1.1vw;
}

.ej-cart {
    position: relative;
    color: var(--ej-cart-icon);
    font-size: 1.1vw;
}

.ej-cart:hover {
    color: var(--ej-primary);
}

.ej-cart-count {
    position: absolute;
    top: -0.4vw;
    right: -0.5vw;
    min-width: 1vw;
    height: 1vw;
    border-radius: 999px;
    background-color: var(--ej-primary);
    color: #ffffff;
    font-size: 0.6vw;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.2vw;
}

.ej-signin {
    color: var(--ej-text-muted);
    text-decoration: none;
    font-weight: 500;
}

.ej-signin:hover {
    color: var(--ej-primary);
}

.ej-signup {
    display: inline-flex;
    align-items: center;
    gap: 0.7vw;
    padding: 0.8vw 1.2vw 0.7vw 1.2vw;
    border-radius: 0.3vw;
    background-color: var(--ej-primary);
    color: #ffffff;
    text-decoration: none;
    font-weight: 500;
    font-size: 1.1vw;
}

.ej-signup i {
    font-size: 0.9vw;
}

.ej-signup:hover {
    background-color: var(--ej-primary-hover);
}

.ej-account-dropdown {
    position: relative;
}

.ej-account-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.25vw;
}

.ej-account-menu {
    position: absolute;
    top: 100%;
    right: 0;
    min-width: 10vw;
    padding: 0.4vw 0;
    margin-top: 0.25vw;
    background-color: #ffffff;
    border-radius: 0.3vw;
    box-shadow: 0 0.3vw 1vw 0 var(--ej-shadow);
    display: none;
    z-index: 20;
}

.ej-account-dropdown:hover .ej-account-menu {
    display: block;
}

.ej-account-menu a {
    display: block;
    padding: 0.5vw 0.9vw;
    font-size: 1.05vw;
    color: var(--ej-text);
    text-decoration: none;
}

.ej-account-menu a:hover {
    background-color: var(--ej-bg-hover);
    color: var(--ej-primary);
}


/************ Exam Jeetoo Menu *************/

.ej-menu {
    border-top: 0.05vw solid var(--ej-border-light);
    border-bottom: 0.05vw solid var(--ej-border-light);
    background-color: var(--ej-white);
}

.ej-menu-inner {
    max-width: 90vw;
    margin: 0 auto;
}

.ej-menu-list {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.8vw;
    padding: 0.7vw 0;
    font-size: 0.85vw;
    color: var(--ej-text-muted);
}

.ej-menu-item a {
    display: inline-flex;
    align-items: center;
    gap: 0.3vw;
    color: var(--ej-text-muted);
    text-decoration: none;
    white-space: nowrap;
}

.ej-menu-item a:hover {
    color: var(--ej-primary);
}

.ej-has-dropdown {
    position: relative;
}

.ej-has-dropdown > a i {
    font-size: 0.7vw;
}

.ej-submenu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 12vw;
    padding: 0.5vw 0;
    margin-top: 0.15vw;
    list-style: none;
    background-color: #ffffff;
    border-radius: 0.3vw;
    box-shadow: 0 0.3vw 1vw 0 var(--ej-shadow);
    display: none;
    z-index: 15;
}

.ej-submenu li a {
    display: block;
    padding: 0.4vw 1vw;
    font-size: 0.8vw;
    color: var(--ej-text);
}

.ej-submenu li a:hover {
    background-color: var(--ej-bg-hover);
    color: var(--ej-primary);
}

.ej-has-dropdown:hover .ej-submenu {
    display: block;
}

.ej-menu-news a {
    border: 0.08vw solid var(--ej-primary);
    border-radius: 0.3vw;
    padding: 0.15vw 0.7vw;
    font-size: 0.75vw;
    color: var(--ej-primary);
    background-color: rgba(107, 142, 35, 0.08);
}


/* .demo-class-banner,
.mock-test-banner,
.live-class-banner {
    width: 95%;
    margin: 1.5vw auto 0;
} */

.banner img:nth-child(1), .demo-class-banner img:nth-child(1), .live-class-banner img:nth-child(1), .notes-banner img:nth-child(1), .mock-test-banner img:nth-child(1){display: block;}
.banner img:nth-child(2), .demo-class-banner img:nth-child(2), .live-class-banner img:nth-child(2), .notes-banner img:nth-child(2), .mock-test-banner img:nth-child(2){display: none;}



/************ Demo Class *************/
.demo-class{
    background-image: url(../images/demo-class-bg.jpg);
    background-size: cover;
    background-position: center;
    padding: 4vw 0;
}
.demo-class-inner{
    /* max-width: 1200px; */
    margin: 0 auto;
    padding: 0 2vw;
}
.demo-class-title{
    text-align: center;
    margin-bottom: 3vw;
}
.demo-class-subheading{
    text-align: center;
    margin-bottom: 2vw;
    font-size: 1.3vw;
    color: var(--ej-text);
;
}
.demo-class-subheading span{
    font-weight: 700;
    color: var(--ej-primary);
}
.demo-class-subheading button{
    margin-top: 1vw;
    background-color: #89a30c;
    font-size: 1.3vw;
    font-weight: 700;
    color: var(--ej-white);
    padding: 0.5vw 1.3vw 0.7vw;
    border: none;
    outline: none;
    border-radius: 20px;
}
.demo-class-tabs{
    display: flex;
    flex-direction: column;
    align-items: center;
}
.tab-buttons{
    display: flex;
    justify-content: center;
    gap: 1vw;
    margin-bottom: 3vw;
    flex-wrap: wrap;
    background-color: #fff;
    width: fit-content;
    padding: 0.5vw;
    border-radius: 0.5vw;
}
.tab-btn{
    padding: 0.5vw 0.7vw;
    color: #676767;
    font-size: 1vw;
    font-weight: 700;
    border: none;
    border-radius: 0.5vw;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-block;
    background-color: transparent;
}
/* .tab-btn[data-tab="11"]{ background-color: var(--ej-primary); }
.tab-btn[data-tab="12"]{ background-color: #EC8234; }
.tab-btn[data-tab="10"]{ background-color: #77359C; }
.tab-btn[data-tab="9"]{ background-color: #7F9313; }
.tab-btn[data-tab="8"]{ background-color: #5099CE; }
.tab-btn[data-tab="7"]{ background-color: #118E8C; } */
.tab-btn.active{
    /* border-color: #FFD900;
    box-shadow: 0 0 10px rgba(255, 217, 0, 0.5); */
    background-color: #cadc76;
}
.tab-content{width: 100%;}
.tab-pane{
    display: none;
}
.tab-pane.active{
    display: block;
}
.demo-live-banner{
    position: relative;
    /* display: flex;
    justify-content: center;
    align-items: center; */
    margin-bottom: 2vw;
    max-width: 100%;
}
.demo-live-banner img{
    width: 100%;
    height: auto;
    border-radius: 20px;
    display: block;
}
.demo-live-banner-content{
    position: absolute;
    top: 50%;
    left: 4%;
    transform: translateY(-50%);
    color: #222;
    max-width: 40%;
    display: flex;
    flex-direction: column;
    gap: 0.8vw;
    padding: 1.5vw;
}
.demo-live-banner-title{
    font-size: 2vw;
    font-weight: 700;
    color: #111;
    text-transform: uppercase;
}
.demo-live-banner-content p{
    margin: 0;
    color: #222;
    font-size: 1.4vw;
    line-height: 1.5;
}
.demo-live-banner-btn{
    display: inline-block;
    align-self: center;
    margin-top: 1vw;
    padding: 0.9vw 2.2vw;
    background-color: #89b332;
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    border-radius: 30px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    width: 100%;
    text-align: center;
    font-size: 1.4vw;
}
.demo-live-banner-btn:hover{
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.12);
}

@media (max-width: 640px) {
    .demo-live-banner{
        margin-bottom: 1.5rem;
    }
    .demo-live-banner-content{
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        max-width: 80%;
        text-align: center;
        padding: 1rem;
    }
    .demo-live-banner-title{
        font-size: 5vw;
    }
    .demo-live-banner-content p{
        font-size: 3.5vw;
    }
    .demo-live-banner-btn{
        padding: 0.9rem 1.5rem;
        font-size: 3.5vw;
    }
}

.demo-class-body{
    display: flex;
    justify-content: start;
    align-items: center;
    flex-wrap: wrap;
    gap: 1.8vw;
}
.demo-class-box{
    width: 32%;
    min-width: 150px;
}
.demo-class-box-banner{
    background-size: cover;
    background-position: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: start;
    gap: 0.3vw;
    border-radius: 12px;
    text-align: left;
    width: 100%;
    padding: 2vw 11vw 3vw 2vw;
}
.subject-name{
    color: var(--ej-text);
    font-size: 1.5vw;
    font-weight: 600;
    width: 100%;
    height: 3.5vw;
    margin: 0;
}
.subject-subtxt{
    height: 6vw;
    color: var(--ej-text);
    font-size: 1vw;
    line-height: 1.4vw;
}
.demo-class-box-btn{
    display: block;
    width: 11vw;
    padding: 0.6vw;
    color: var(--ej-white);
    background-color: #919191;
    font-size: 1vw;
    text-align: center;
    margin-top: 0.5vw;
    border-radius: 20px;
    cursor: not-allowed;
    text-decoration: none;
}



/* Demo Modal */
.demo-modal {
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    justify-content: center;
    align-items: center;
    display: none;
}
.demo-modal-content {
    background-color: var(--ej-white);
    padding: 2vw;
    border-radius: 10px;
    width: 90%;
    max-width: 500px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-height: 90vh;
    overflow-y: auto;
}
.demo-modal-close {
    position: absolute;
    top: 1vw;
    right: 1vw;
    font-size: 2vw;
    cursor: pointer;
    color: #333;
}
.demo-modal h2 {
    text-align: center;
    margin-bottom: 2vw;
    color: var(--ej-primary);
}
.form-group {
    margin-bottom: 1.5vw;
}
.form-group input,
.form-group select {
    width: 100%;
    padding: 0.8vw;
    border: 1px solid #ccc;
    border-radius: 5px;
    font-size: 1vw;
}
.submit-btn {
    width: 100%;
    padding: 1vw;
    background-color: var(--ej-primary);
    color: var(--ej-white);
    border: none;
    border-radius: 5px;
    font-size: 1.2vw;
    cursor: pointer;
}
.submit-btn:hover {
    background-color: #4c6616;
}


/************ Success Stories *************/

.success-stories {
    width: 95%;
    margin: 3vw auto 4vw;
}

.success-stories-inner {
    background-color: #ffffff;
}

.heading {
    text-align: center;
    font-size: 1.4vw;
    letter-spacing: 0.12vw;
    font-weight: 600;
    color: #111827;
    margin-bottom: 2vw;
    position: relative;
}

.heading::before {
    content: "";
    position: absolute;
    bottom: -0.7vw;
    left: 46%;
    width: 7%;
    height: 0.2vw;
    background-color: var(--ej-primary);
}

.success-swiper {
    /* padding-bottom: 2vw; */
    padding: 0 3vw;
}

.success-swiper .swiper-wrapper {
    padding-bottom: 1.2vw;
    height: fit-content;
}

.success-card {
    border-radius: 0.4vw;
    border: 0.05vw solid #e5e7eb;
    box-shadow: 0 0.3vw 1vw rgba(0, 0, 0, 0.05);
    padding: 1.4vw 1.6vw;
    background-color: #ffffff;
    height: 15vw;
}

.success-card-header {
    display: flex;
    align-items: flex-start;
    gap: 1vw;
    margin-bottom: 1vw;
}

.success-avatar {
    flex: 0 0 auto;
    width: 3vw;
    height: 3vw;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}



.success-meta {
    flex: 1 1 auto;
    font-size: 0.8vw;
    color: #111827;
    line-height: 1.5;
}

.success-meta span {
    font-weight: 600;
}

.success-rating {
    margin-top: 0.2vw;
}

.success-rating-stars {
    color: #facc15;
    margin-left: 0.4vw;
    margin-right: 0.2vw;
}

.success-quote {
    margin-top: 0.5vw;
    font-size: 0.85vw;
    color: #4b5563;
    font-style: italic;
    line-height: 1.6;
}

.success-swiper-button {
    position: absolute;
    top: 45%;
    transform: translateY(-50%);
    width: 2.2vw;
    height: 2.2vw;
    border-radius: 50%;
    background-color: #ffffff;
    box-shadow: 0 0.2vw 0.6vw rgba(0, 0, 0, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6b7280;
    cursor: pointer;
    z-index: 5;
}

.success-swiper-prev {
    left: 0.4vw;
}

.success-swiper-next {
    right: 0.4vw;
}

.success-swiper-button i {
    font-size: 0.8vw;
}

.success-swiper-button.swiper-button-disabled {
    opacity: 0.35;
    cursor: default;
}

.success-swiper-pagination {
    text-align: center;
}

.success-swiper-pagination .swiper-pagination-bullet {
    background-color: #d1d5db;
    opacity: 1;
}

.success-swiper-pagination .swiper-pagination-bullet-active {
    background-color: var(--ej-primary);
}

/************ Footer *************/

.ej-footer {
    /* background-color: var(--ej-primary); */
    color: #ffffff;
    /* margin-top: 3vw; */
}

.ej-footer-inner {
    /* max-width: 90vw; */
    margin: 0 auto;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 2.5vw 5vw 1.8vw;
    gap: 4vw;
    background-color: #557301;
}

.ej-footer-col {
    /* flex: 1 1 0; */
}

.ej-footer-col-logo {
    /* flex: 0 0 auto; */
    max-width: 18vw;
}

.ej-footer-logo img {
    width: auto;
    height: 10vw;
}

.ej-footer-heading {
    font-size: 0.9vw;
    letter-spacing: 0.12vw;
    font-weight: 700;
    margin-bottom: 1vw;
    position: relative;
    display: inline-block;
}
.ej-footer-heading::before {
    content: "";
    position: absolute;
    bottom: -0.7vw;
    left: 0;
    width: 100%;
    height: 0.15vw;
    background-color: #ffffff;
}

.ej-footer-links {
    list-style: none;
    font-size: 0.85vw;
}

.ej-footer-links li + li {
    margin-top: 0.4vw;
}

.ej-footer-links a {
    color: #f9fafb;
}

.ej-footer-links a:hover {
    text-decoration: underline;
}

.ej-footer-col-contact {
    text-align: left;
    font-size: 0.85vw;
}

.ej-footer-block + .ej-footer-block {
    margin-top: 0.8vw;
}

.ej-footer-block p,
.ej-footer-block a {
    color: #f9fafb;
}

.ej-footer-block a:hover {
    text-decoration: underline;
}

.ej-footer-bottom {
    border-top: 0.05vw solid rgba(255, 255, 255, 0.3);
    text-align: center;
    padding: 0.7vw 0;
    font-size: 0.75vw;
    background-color: #455300e8;
}















/************ Account and auth pages ************/
.account-wrapper {
    /* min-height: 100vh; */
    display: flex;
    align-items: center;
    justify-content: end;
    /* background-color: #f3f4f6; */
    padding: 3vw 8vw 8vw 8vw;
    background-size: cover;
    background-position: center;
}

.signup-wrapper{
    background-image: url(../images/sign-up.png);
}
.signin-wrapper{
    background-image: url(../images/sign-in.png);
    padding: 13vw 8vw;
}

.login-box {
    width: 35vw;
    /* max-width: 1000px; */
    background: transparent;
    display: flex;
    flex-direction: row-reverse;
    border-radius: 1vw;
    overflow: hidden;
    /* box-shadow: 0 0.3vw 1vw rgba(0, 0, 0, 0.1); */
}

.login-box-left {
    width: 100%;
}

.login-box-right {
    width: 35%;
}

.login-box-left {
    padding: 5vw 3vw 3vw 3vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* #otp-message{position: absolute;top: 0%;} */

/* header tabs above form */
.auth-tabs {
    display: flex;
    gap: 1vw;
    justify-content: center;
    margin-bottom: 2vw;
}
.auth-tabs a {
    padding: 0.7vw 2vw;
    border-radius: 1vw;
    font-size: 1vw;
    font-weight: 600;
    text-decoration: none;
}
.auth-tabs a.register {
    background: var(--ej-primary);
    color: #fff;
}
.auth-tabs a.signin {
    background: #e5e7eb;
    color: var(--ej-text);
}
.auth-tabs a.register.active {
    box-shadow: 0 0 0 0.1vw var(--ej-primary);
}

/* hide original title since tabs indicate action */
.login-title {
    display: none;
}

.social-sign {
    text-align: center;
    margin-bottom: 1.5vw;
}

.social-sign-links {
    margin-bottom: 1vw;
}

.social-sign-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3vw;
    height: 3vw;
    font-size: 1.2vw;
    border: 0.05vw solid #ccc;
    border-radius: 50%;
    color: #555;
}

.social-sign-btn.google-sign {
    color: #db4437;
}

.signup-header {
    margin-bottom: 0.5vw;
    text-align: center;
}

.signup-header h1 {
    font-size: 2vw;
    font-weight: 700;
    margin-bottom: 0.6vw;
    color: var(--ej-primary);
}

.signup-header p {
    font-size: 1vw;
    color: #4A4A4A;
}

.form-label {
    display: block;
    font-size: 1.1vw;
    color: #4A4A4A;
    margin-bottom: 0.5vw;
    font-weight: 500;
}

.form-inner {
    /* display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5vw; */
    width: 100%;
    overflow: hidden;
}

.form-inner .login-input {
    grid-column: 1 / -1;
}

.form-inner .login-input.half {
    grid-column: span 1;
}

.form-slider{ display: flex; width: 100%; height: auto; /* flex-wrap: wrap; */ transition: transform 0.4s ease-in-out; }
.form-step{ width: 100%; padding: 1vw; flex-shrink: 0; }
.btn-group{ display: flex; justify-content: space-between; align-items: center; }

.login-input {
    width: 100%;
    position: relative;
    margin-bottom: 1.4vw;
}

.login-input input,
.login-input select {
    width: 100%;
    padding: 0.8vw 1vw;
    border: none;
    border-radius: 3vw;
    font-size: 1vw;
    background: #F3F3F3;
}

.login-input input[type="button"] {
    position: absolute;
    top: 69%;
    right: 0.8vw;
    transform: translateY(-50%);
    padding: 0.3vw 0vw;
    font-size: 0.85vw;
    border: none;
    border-radius: 2vw;
    background: #69A200;
    color: #fff;
    cursor: pointer;
    width: 6vw;
}

.login-input.input-with-action input[type="text"],
.login-input.input-with-action input[type="tel"],
.login-input.input-with-action input[type="email"],
.login-input.input-with-action input[type="password"] {
    padding-right: 6vw;
}

.login-input .toggle-password {
    position: absolute;
    top: 71%;
    right: 0.8vw;
    transform: translateY(-50%);
    cursor: pointer;
    color: #6b7280;
    font-size: 1.1vw;
}

.field-error {
    color: var(--color-error);
    font-size: 0.8vw;
    margin-top: 0.4vw;
}

.log-in-btn {
    grid-column: 1 / -1;
}

.log-in-btn button {
    width: 100%;
    padding: 0.7vw;
    background: var(--ej-primary);
    color: #fff;
    border: none;
    border-radius: 20px;
    font-size: 1.3vw;
}

.btn-group button{width: 48%;font-size: 1.2vw;}

.sign-up-txt-link {
    margin-top: 0.5vw;
    font-size: 1.1vw;
    text-align: center;
}

.sign-up-txt-link a {
    color: var(--ej-primary);
}

.login-box-right {
    position: relative;
    overflow: hidden;
}

.login-box-banner {
    width: 100%;
    height: 100%;
}

.login-box-banner img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
    border-radius: 27px;
}

.login-signup-logo {
    position: absolute;
    top: 2vw;
    right: 2vw;
    z-index: 5;
}

.login-signup-logo-text {
    color: #fff;
    font-size: 1.5vw;
    font-weight: 600;
}

.remember-forgot{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2vw;
    font-size: 1.1vw;
}

.forgot-pass{color: var(--ej-primary);}

/*********Forgot passowrd Modal css ************************/
.forgot-password-modal { position: fixed; inset: 0; z-index: 9999; align-items: center; justify-content: center; padding: 20px; }
.forgot-password-modal-overlay { position: absolute; inset: 0; background: var(--color-overlay); }
.forgot-password-modal-box { position: relative; background: var(--ej-white); border-radius: 12px; max-width: 420px; width: 100%; box-shadow: 0 20px 60px var(--color-box-shadow);}
.forgot-password-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--color-gray-200); }
.forgot-password-modal-header h3 { margin: 0; font-size: 1.25rem; font-weight: 600; }
.forgot-password-modal-close { background: none; border: none; font-size: 28px; line-height: 1; cursor: pointer; color: var(--color-gray-900); padding: 0; }
.forgot-password-modal-close:hover { color: var(--ej-black); }
.forgot-password-modal-body { padding: 24px; }
.forgot-password-modal-text { margin: 0 0 20px; color: var(--color-gray-950); font-size: 0.95rem; }
.forgot-password-modal-body .login-input { margin-bottom: 16px; }
.forgot-password-modal-body .login-input input { width: 100%; padding: 12px 16px; border: 1px solid var(--color-gray-400); border-radius: 8px; font-size: 1rem; }
.forgot-form-message { padding: 10px 12px; border-radius: 8px; margin-bottom: 16px; font-size: 0.9rem; }
.forgot-form-message.success { background: var(--color-success-bg); color: var(--color-success-text); }
.forgot-form-message.error { background: var(--color-error-bg); color: var(--color-error-text); }
.forgot-password-modal-actions { display: flex; gap: 12px; justify-content: flex-end; margin-top: 20px; }
.forgot-password-modal-cancel, .forgot-password-modal-submit { padding: 10px 20px; border-radius: 8px; font-size: 0.95rem; cursor: pointer; border: 1px solid var(--color-gray-400); background: var(--ej-white); }
.forgot-password-modal-cancel:hover { background: var(--color-gray-100); }
.forgot-password-modal-submit { background: var(--ej-primary); color: var(--ej-white);}
/* .forgot-password-modal-submit:hover { background: var(--ej-black); } */
.forgot-password-modal-submit:disabled { opacity: 0.7; cursor: not-allowed; }


/***********************************  Responsive CSS *********************************************/

@media (max-width: 1024px) {
    .ej-header-inner {
        max-width: 100%;
        padding: 0 3vw;
    }

    .ej-header-top {
        flex-wrap: wrap;
        /* align-items: flex-start; */
    }

    .ej-logo {
        max-width: 22vw;
    }

    .ej-logo img {
        height: 6vw;
    }

    .ej-search-wrap {
        order: 3;
        flex-basis: 100%;
        max-width: 100%;
        margin-top: 1.5vw;
    }

    .ej-search-input {
        font-size: 1.2vw;
        padding: 1vw 1.4vw;
    }

    .ej-search-btn {
        width: 3vw;
        height: 3vw;
        margin: 0.4vw;
    }

    .ej-search-btn i {
        font-size: 1.1vw;
    }

    .ej-header-actions {
        order: 2;
        font-size: 1.1vw;
        gap: 1.4vw;
    }

    .ej-cart {
        font-size: 1.6vw;
    }

    .ej-cart-count {
        font-size: 0.8vw;
        min-width: 1.4vw;
        height: 1.4vw;
    }

    .ej-signup {
        padding: 0.7vw 1.6vw;
        font-size: 1.1vw;
    }

    .ej-menu-inner {
        max-width: 100%;
        padding: 0 3vw;
    }

    .ej-menu-list {
        gap: 1.2vw;
        font-size: 1.1vw;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .ej-menu-list::-webkit-scrollbar {
        height: 0.5vw;
    }

    .ej-menu-list::-webkit-scrollbar-thumb {
        background-color: rgba(0, 0, 0, 0.15);
        border-radius: 999px;
    }

    .heading{
        font-size: 18px;
    letter-spacing: 1px;
    margin-bottom: 14px;
    }

    .heading::before{
        bottom: -9px;
    left: 45%;
    width: 50px;
    height: 2px;
    }

    .inner{margin: 14px auto 0;}

    .demo-class-row-title{
        padding: 5px 10px;
        font-size: 12px;
        margin-bottom: 10px;
    }

    .demo-class-row {
        margin-bottom: 18px;
    }
    .login-box {
        flex-direction: column;
    }
    .login-box-left,
    .login-box-right {
        width: 100%;
    }
    .login-box-right {
        height: 40vw;
    }


}

@media (max-width: 640px) {
    .heading{margin-bottom: 26px;}
    .disclaimer{
        padding: 10px;
        font-size: 12px;
    }
    .ej-header-top {
        gap: 15px;
        padding: 12px 0;
        flex-direction: column;
        align-items: center;
    }

    .ej-header-inner{padding: 0 12px;}

    .ej-logo {
        max-width: none;
    }

    .ej-logo img {
        height: 80px;
    }

    .ej-header-actions {
        width: 100%;
        justify-content: center;
        gap: 16px;
        font-size: 14px;
    }

    .ej-search-wrap {
        margin-top: 0;
        order: 2;
        width: 70%;
    }

    .ej-search-input {
        font-size: 12px;
        padding: 10px 10px;
    }

    .ej-search-btn {
        width: 30px;
        height: 28px;
        margin: 5px;
    }

    .ej-search-btn i {
        font-size: 12px;
    }



    .ej-cart {
        font-size: 16px;
    }

    .ej-signup {
        padding: 6px 12px;
        font-size: 14px;
        gap: 8px;
        border-radius: 5px;
    }

    .ej-signup i {
        font-size: 12px;
    }



    .ej-menu-list {
        padding: 1.5vw 0;
        gap: 2vw;
    }

    .ej-menu-item a {
        font-size: 2.8vw;
    }

    .ej-menu-news a {
        font-size: 2.4vw;
        padding: 0.4vw 1.6vw;
    }

    .signup-wrapper, .signin-wrapper{background-image: url(../images/sign-in-mob.png);}

    .remember-forgot{
        margin-bottom: 20px;
    font-size: 14px;
    }
    .login-input .toggle-password{right: 20px;font-size: 14px;}

    .banner img:nth-child(1), .demo-class-banner img:nth-child(1), .live-class-banner img:nth-child(1), .notes-banner img:nth-child(1), .mock-test-banner img:nth-child(1){display: none;}
    .banner img:nth-child(2), .demo-class-banner img:nth-child(2), .live-class-banner img:nth-child(2), .notes-banner img:nth-child(2), .mock-test-banner img:nth-child(2){display: block;}
    .demo-class {
        /* margin-top: 14px; */
    }
    .demo-live-banner-content{
        position: absolute;
        top: 71%;
        left: 0;
        transform: translateY(-50%);
        width: 100%;
        gap: 4px;
        padding: 16px;
        max-width: none;
    }
    .demo-live-banner-title{
        font-size: 18px;
    }
    .demo-live-banner-content p{
        font-size: 14px;
    }
    .demo-live-banner-btn{
        padding: 12px 22px;
        font-size: 14px;
    }
    .demo-class-body{gap: 12px;}
    .demo-class-row {
        margin-bottom: 30px;
    }
    .demo-class-box {
        width: 31%;
    }
    /* .demo-class-box-banner{
        gap: 5px;height: 100px;
    } */
    .demo-class-box-banner p{font-size: 14px;}
    /* .demo-class-box-btn{padding: 6px;margin-top: 6px;font-size: 11px;} */
    .subject-subtxt{line-height: 17px;height: 70px;font-size: 12px !important;}

    .success-stories {
        width: 94%;
        margin: 6vw auto 7vw;
    }
    .demo-class{
        padding: 40px 0;
        /* margin-top: 20px; */
    }
    .demo-class-inner{
        padding: 0 20px;
    }
    .demo-class-title{
        margin-bottom: 30px;
    }
    .tab-buttons{
        gap: 10px;
        margin-bottom: 30px;
        padding: 5px;
        border-radius: 7px;
    }
    .tab-btn{
        padding: 5px 7px;
        font-size: 14px;
        border-radius: 7px;
        border: 2px solid transparent;
    }
    .demo-class-body{
        gap: 18px;
    }
    .demo-class-box{
        width: 100%;
        min-width: 0;
    }
    .demo-class-box-banner{
        gap: 5px;
        padding: 10px 137px 10px 13px;
    }
    .subject-name{
        font-size: 15px;
        height: 30px;
    }
    .demo-class-box-btn{
        width: auto;
        padding: 6px 14px;
        font-size: 12px;
        margin-top: 5px;
    }
    .demo-class-subheading{
        margin-bottom: 14px;
    font-size: 14px;
    }
    .demo-class-subheading button{
        margin-top: 12px;
        font-size: 16px;
        padding: 6px 14px;
    }
    .demo-modal-content {
        padding: 20px;
        max-width: 90%;
    }
    .demo-modal-close {
        font-size: 24px;
        top: 10px;
        right: 10px;
    }
    .demo-modal h2 {
        margin-bottom: 20px;
        font-size: 18px;
    }
    .form-group {
        margin-bottom: 15px;
    }
    .form-group input,
    .form-group select {
        padding: 10px;
        font-size: 14px;
    }
    .submit-btn {
        padding: 12px;
        font-size: 16px;
    }


    .success-card {
        padding: 10px;
        border-radius: 10px;
        border: 1px solid #e5e7eb;
        height: 300px;
    }

    .success-card-header {
        flex-direction: column;
        gap: 5px;
        margin-bottom: 12px;
    }

    .success-avatar {
        width: 40px;
        height: 40px;
    }

    .success-meta, .success-quote {
        font-size: 14px;
    }

    .success-swiper-button {
        width: 6vw;
        height: 6vw;
    }

    .success-swiper-button i {
        font-size: 2.4vw;
    }

    .ej-footer-inner {
        max-width: none;
        flex-direction: column;
        align-items: flex-start;
        padding: 14px;
        gap: 20px;
    }

    .ej-footer-col-logo {
        max-width: none;
    }

    .ej-footer-logo img {
        height: 100px;
    }

    .ej-footer-heading {
        font-size: 14px;
        margin-bottom: 14px;
    }

    .ej-footer-links, .ej-footer-col-contact {
        font-size: 14px;
    }
    .ej-footer-links li{
        padding-bottom: 6px;
    }
    .ej-footer-block{padding-bottom: 6px;}
    .ej-footer-bottom {
        font-size: 14px;
        padding: 10px 0;
    }
    .account-wrapper {
        padding: 12px 0;
    }
    .login-box {
        width: 100vw;
        border-radius: 0;
        box-shadow: none;
    }
    .login-box-left {
        padding: 12px;
    }
    .login-title {
        display: none;
    }
    .auth-tabs a {
        padding: 8px 16px;
        font-size: 14px;
        border-radius: 5px;
    }
    .social-sign-btn {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }
    .signup-header h1{
        font-size: 18px;
        margin-bottom: 12px;
    }
    .signup-header p{font-size: 12px;}
    .form-inner {
        grid-template-columns: 1fr;
        gap: 18px;
    }
    .form-inner .login-input.half {
        grid-column: 1 / -1;
    }
    .form-label {
        font-size: 14px;
        margin-bottom: 8px;
    }
    .login-input{margin-bottom: 24px;}
    .login-input input,
    .login-input select {
        padding: 12px 10px;
        font-size: 14px;
        border-radius: 27px;
    }
    .login-input.input-with-action {
        display: flex;
        flex-direction: column;
        gap: 0px;
    }
    .login-input.input-with-action input[type="button"] {
        position: static;
        width: 100px;
        padding: 5px 0px;
        margin-top: 10px;;
        font-size: 14px;
        transform: none;
        /* right: 10px;
        top: 49%; */
    }
    .login-input.input-with-action input[type="text"],
    .login-input.input-with-action input[type="tel"],
    .login-input.input-with-action input[type="email"],
    .login-input.input-with-action input[type="password"] {
        padding-right: 1rem;
    }
    .log-in-btn button {
        padding: 12px;
        font-size: 16px;
    }
    .sign-up-txt-link {
        font-size: 14px;
        margin-top: 20px;
    }
    .login-box-right {
        display: none;
    }
    .login-signup-logo {
        top: 12px;
        right: 12px;
    }
    .login-signup-logo-text {
        font-size: 20px;
    }
}




