@import url('https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600&display=swap');

:root {
    --bxradius: 5px;  
    --space: 15px;
}
/*--------------------------------------------------------------         
# General style           
--------------------------------------------------------------*/         
* {
    box-sizing: border-box;
}

body {
    font-family: "Rubik", sans-serif;
    background-color: #f1f1f1;
    position: relative;
    max-width: 100%;
    width: 100%;
}

a,
a:hover {
    text-decoration: none;
    transition: all 0.4s ease-in-out;
}

h1,
h2,
h3,
h4,
h5,
h6,
.display-1, .display-2, .display-3, .display-4, .display-5 {
    font-weight: 600;
}

p {
    font-size: 16px;
    line-height: 26px;
    text-align: justify;
}

.parentdiv {
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
    background-color: #fff;
    padding-top: var(--space);
    padding-bottom: var(--space);
    border-radius: var(--bxradius);
    margin-top: 20px;
    margin-bottom: 20px;
}

.event-title {
    display: inline-block;
    color: var(--prcolor);
    font-size: 28px;
    margin: 15px auto 15px auto;
    padding: 0 var(--space) 8px var(--space);
    border-bottom: 1px solid #000;
    position: relative;
}

    .event-title:before {
        content: '';
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        bottom: -2px;
        width: 40px;
        height: 3px;
        background-color: var(--prcolor);
    }

.eventdatelocation {
    background-color: #f1f1f1;
    border-radius: var(--bxradius);
    padding: 10px var(--space);
}

.eventinfo {
    background-color: #f1f1f1;
    border-radius: var(--bxradius);
    padding: 25px var(--space) 10px var(--space);
    margin-top: 40px;
    position: relative;
}

    .eventinfo div.eventinfo{
        background-color: #d1d1d1 !important;
    }

    .eventinfotitle {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        top: -20px;
        display: inline-block;
        padding: 10px 16px;
        border-radius: 30px;
        box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
        background-color: var(--prcolor);
        color: #ffffff;
        font-size: 20px;
        line-height: 20px;
    }

.evedtae {
    display: inline-block;
    position: relative;
    padding-left: 25px;
    font-size: 14px;
    line-height: 14px;
}

    .evedtae i {
        position: absolute;
        left: 0;
        top: -1.5px;
        font-size: 16px;
        color: var(--prcolor);
    }

.form-div {
    padding-bottom: 15px;
}

    .form-div label {
        font-size: 16px;
        margin-bottom: 4px;
        padding-left: 4px;
    }

        .form-div label sup{
            color: red;
        }

        .form-input {
            display: block;
            width: 100%;
            border: 1px solid #333;
            padding: 7px 10px;
            border-radius: var(--bxradius);
            font-size: 16px;
            background-color: #fff;
        }

#mainMemberDetails .form-input{
    text-transform: uppercase;
}

.togpwd {
    position: absolute;
    right: 8px;
    top: 9px;
    font-size: 18px;
    cursor: pointer;
}

.reg-submit {
    display: inline-block;
    padding: 15px 40px;
    font-size: 18px;
    line-height: 18px;
    border-radius: var(--bxradius);
    background-color: var(--prcolor);
    color: #fff;
    border: none;
}

.paymentsummary {
    margin-top: 10px;
    border-radius: var(--bxradius);
    padding: 15px;
    background-color: #fff;
    border: 1px solid #ced4da;
}

.mob-label {
    font-size: 20px;
    margin-bottom: 15px;
    display: block;
    text-align: center;
}

.mob-textbx {
    display: block;
    width: 100%;
    max-width: 400px;
    font-size: 18px;
    line-height: 1;
    border: 1px solid #333;
    border-radius: var(--bxradius);
    padding: 12px;
    text-align: center;
}

.mob-reldiv {
    position: relative;
    border: 1px solid #d7d7d7;
    border-radius: var(--bxradius);
    width: 100%;
}

    .mob-reldiv .mob-textbx {
        border: none;
        outline: none;
        padding: 12px 12px 12px 98px;
        text-align: left;
    }

    .mob-reldiv .india {
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        padding: 5px 10px 5px 5px;
        background-color: #d7d7d7;
        display: inline-flex;
        align-items: center;
        gap: 10px;
    }

        .mob-reldiv .india img{
            max-width: 35px;
        }

        .mob-submit {
            margin: 20px auto 12px auto;
            background-color: var(--prcolor);
            border: none;
            outline: none;
            padding: 12px 30px;
            font-size: 18px;
            line-height: 1;
            color: #fff;
            border-radius: var(--bxradius);
        }


.info-icon .material-icons {
    color: #0d6efd;
    font-size: 20px;
}

.pay-summary {
    background-color: #fff;
    border: 1px solid #7c7c7c;
    padding: 10px;
    border-radius: var(--bxradius);
}

    .pay-summary h4 {
        font-size: 22px;
        margin: 5px auto 10px auto;
        text-align: center;
    }

.pay-flex {
    display: flex;
    align-items: center;
    background-color: #efefef;
    border-bottom: 1px solid #7c7c7c;
}

    .pay-flex > div {
        padding: 8px;
    }

.pay-type {
    width: 15%;
    font-size: 16px;
    padding-left: 50px !important;
    position: relative;
}

.pay-delbtn, .remove-addon-guest {
    position: absolute;
    left: 8px;
    top: 14px;
    padding: 5px 8px;
    background-color: #e31c1c;
    color: #fff;
    font-size: 18px;
    line-height: 1;
    border-radius: 4px;
    border: none;
    outline: none;
}

.pay-name {
    width: 25%;
}

.pay-relation {
    width: 20%;
}

.pay-mobile {
    width: 15%;
}

.pay-age {
    width: 10%;
}

.pay-amount {
    width: 15%;
    text-align: right;
    font-size: 16px;
    font-weight: 500;
}

.pay-txs {
    width: 85%;
    font-weight: 500;
    font-size: 16px;
    text-align: right;
}

.guestname {
    display: block;
}

.hidespan, .taxspan {
    display: none;
}

.mystable tr td:last-child{
    white-space: nowrap;
}

@media screen and (max-width: 767px) {
    .pay-flex > div {
        width: 100%;
    }

    .pay-txs {
        width: 85% !important;
    }

    .pay-final {
        width: 15% !important;
    }
}

@media (min-width: 991px) {
    .personName::placeholder,
    .mobileField::placeholder,
    .ageField::placeholder {
        opacity: 0;
    }
}

@media screen and (max-width: 767px) {
    .plushide {
        opacity: 0;
        display: none !important;
        height: 0;
        padding: 0 !important;
        border: 0 !important;
    }

    .mystable thead {
        display: none !important;
    }

    .mystable tbody tr {
        display: block !important;
        width: calc(100dvw - 85px) !important;
    }

        .mystable tbody tr td {
            display: block !important;
            width: 100% !important;
            position: relative;
        }

    .hidespan {
        display: inline-block;
        position: absolute;
        left: 0;
        top: 6px;
    }

    #subTotal::before {
        content: "Sub Total";
        font-weight: bold;
        display: inline-block;
        position: absolute;
        left: 14px;
        top: 8px;
    }

    .taxspan {
        display: inline-block;
        font-weight: bold;
        position: absolute;
        left: 14px;
        top: 8px;
    }

    #grandTotal::before {
        content: "Grand Total";
        font-weight: bold;
        display: inline-block;
        position: absolute;
        left: 14px;
        top: 8px;
    }
}



@media screen and (max-width: 500px) {
    .eventinfotitle {
        font-size: 18px;
        line-height: 20px;
        white-space: nowrap;
    }
}

.footdiv {
    border-top: 1px solid #a7a7a7;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 15px;
    margin-top: 15px;
    color: #a7a7a7;
}

.footdiv a{
    color: var(--prcolor);
    font-size: 16px;
    line-height: 16px;
}

.subpagecontent{
    padding: 0 15px 15px 15px;
}

.subpagedetails {
    display: block;
    width: 100%;
    border-radius: var(--bxradius);
    padding: 60px 15px 15px 15px;
    margin-top: 20px;
    position: relative;
    border: 1px solid #e1e1e1;
}

    .subpagedetails h3 {
        position: absolute;
        left: 0;
        top: 0px;
        display: inline-block;
        width: 100%;
        text-align: center;
        padding: 12px 25px;
        background-color: #ededed;
        font-size: 24px;
        line-height: 24px;
        color: var(--prcolor);
        margin: 0;
    }