body {
    color: #22272C;
    font-family: 'Poppins', sans-serif;
    min-height: 98vh;
    padding: 2em;
}

    body#login-page, body#subscription-list-page {
        background: #EAEAEA;
    }

#loginForm, #subscriptionList {
    background: #ffffff;
    border-radius: 1.25em;
    padding: 2em;
    width: 100%;
}

#loginForm {
    max-width: 600px;
}

#subscriptionList {
    width: 100%;
    min-height: 900px;
}

.leftside-nav {
    background: #ffffff;
    border-radius: 1.25em;
    padding: 2em;
    width: 20%;
    margin-right: 2em;
    min-width: 240px;
    max-height: 850px;
    position: sticky;
    top: 3%;
}

.rightside-body {
    width: 100% !important;
}

div.form {
    padding: 4em 0;
}

.mass-comm-location {
    background: #28a745;
    border-radius: 50px;
    margin-bottom: 2em;
    padding: .8em 1.3em;
}

    .mass-comm-location svg, .btn-with-icon svg, .nav-link svg {
        margin-right: .5em;
    }

    .mass-comm-location p, .send-message-btn, .logout-btn {
        color: #22272C;
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 2px;
        line-height: 20px;
        margin: 0;
        text-transform: uppercase;
    }

#loginForm h1, #subscriptionList h1 {
    font-size: 2.5em;
    font-weight: 500;
    line-height: 1.1em;
    margin: 0 0 .5em;
}

#loginForm h1 {
    text-align: center;
}

#subscriptionList h1 {
    margin-bottom: 0;
}

#loginForm .messages-community-logo {
    max-width: 45%;
}

.nav-link-container {
    flex-grow: 2;
}

.leftside-nav .messages-community-logo {
    margin-bottom: 2em;
}

.leftside-nav .nav-link {
    border-radius: .5em;
    color: #22272C;
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    font-weight: 500;
    margin-bottom: .5em;
    padding: .5em;
    text-decoration: none;
    transition: ease-in-out all .3s;
}

.nav-link:hover {
    background: #F3F3F3;
}

.login-fields-container input#txtUserID, .login-fields-container input#txtPassword, .login-fields-container input#btnLogin {
    border-radius: 1.25em;
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    font-weight: 500;
    min-width: 300px;
    padding: .8em 1.5em;
}

.login-fields-container input#txtUserID, .login-fields-container input#txtPassword {
    border: 2px solid #EAEAEA;
    margin-bottom: .5em;
}

.login-fields-container input#btnLogin {
    background: #fbc8b3;
    border: none;
    color: #6A243D;
    transition: ease-in-out all .3s;
}

    .login-fields-container input#btnLogin:hover {
        background: #f68d72;
        color: #6A243D;
        cursor: pointer;
    }

#btnUpdate, #btnSendMessage {
    border-radius: 1.25em;
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    font-weight: 500;
    min-width: 300px;
    padding: 0.8em 1.5em;
    background: #FABBB4;
    border: none;
    color: #F15C64;
    transition: ease-in-out all .3s;
}

    #btnUpdate:hover, #btnSendMessage:hover {
        border-radius: 1.25em;
        font-family: 'Poppins', sans-serif;
        font-size: 16px;
        font-weight: 500;
        min-width: 300px;
        padding: 0.8em 1.5em;
        background: #F15C64;
        color: #2E333A;
        cursor: pointer;
    }

.contact-us-callout p {
    font-weight: 500;
    text-align: center;
    margin-top: 0;
}

    .contact-us-callout p a {
        color: #F19C24;
        text-decoration: none;
        transition: ease-in-out all .3s;
    }

.contact-us-callout a:hover {
    cursor: pointer;
    opacity: .7;
}

.btn-with-icon {
    border-radius: 50px;
    padding: 0.8em 1.3em;
}

.btn-with-icon {
    transition: ease-in-out all .3s;
}

.send-message-btn {
    background: #fbc8b3;
    border: 2px solid #FABBB4;
    color: #6A243D;
    margin-right: .8em;
    text-decoration: none;
}

    .send-message-btn:hover {
        background: #f68d72;
        border: 2px solid #f68d72;
        color: #6A243D;
    }

#subscriptionList .divider {
    margin-top: 1.5em;
}

.field_required {
    color: #EF3054;
    font-weight: bold;
    margin-left: 3px;
}

a {
    color: #F15C64;
}

.msgLogEntry{
    background-color: #f7f7f7;
}

#pnlError {
    display: none;
}

select#ddlCellCarrier {
    width: 20%;
    margin-top: 10px;
}

.bd-callout {
    border-left-color: #5C92FF !important;
}

.bd-callout {
    padding: 1.25rem;
    margin-top: 1.25rem;
    margin-bottom: 1.25rem;
    border: 1px solid #eee;
    border-left-width: 0.25rem;
    border-radius: 0.25rem;
}

*, ::after, ::before {
    box-sizing: border-box;
}

.btn:not(:disabled):not(.disabled) {
    cursor: pointer;
}

[type=reset], [type=submit], button, html [type=button] {
    -webkit-appearance: button;
}

.btn-primary {
    color: #fff;
    background-color: #28a745;
    border-color: #28a745;
}

    .btn-primary:hover {
        background: #218838;
        border-color: #218838;
    }

.btn {
    display: inline-block;
    font-weight: 400;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    border: 1px solid transparent;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    line-height: 1.5;
    border-radius: 0.25rem;
    transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.wrapper {
    max-width: 882px;
}

.flex-parent {
    display: flex;
}

.flex-just-start {
    justify-content: flex-start;
}

.flex-just-center {
    justify-content: center;
}

.flex-just-spc-btwn {
    justify-content: space-between;
}

.flex-direction-col {
    flex-direction: column;
}

.flex-align-item-center {
    align-items: center;
}

.align-items-flex-start {
    align-items: flex-start;
}

.flex-wrap {
    flex-wrap: wrap;
}

.notify-email, .notify-text {
    border-radius: 8px;
    padding: 1em;
}

.notify-email {
    background: #C2D6FF;
}

.notify-text {
    background: #D4F3A5;
}

.col-1-2 {
    max-width: 50%;
    width: 100%;
    height: 100%;
    flex-grow: 1;
}

    .col-1-2:first-of-type {
        margin-right: 1.5em;
    }

.divider {
    border-top: 2px solid #e1e1e1;
    flex-grow: 2;
    height: 2px;
    margin-bottom: 1.5em;
    width: 100%;
    ;
}

div.section {
    margin-bottom: 2.5em;
}

#pnlError {
    background: #ffffff;
    border-radius: 8px;
    -webkit-box-shadow: 0px 0px 10px 0px rgba(153,153,153,0.6);
    -moz-box-shadow: 0px 0px 10px 0px rgba(153,153,153,0.6);
    box-shadow: 0px 0px 10px 0px rgba(153,153,153,0.6);
    padding: 1em;
    text-align: center;
    border: 2px solid red;
    margin-top: 3em !important;
}

#pnlTY {
    text-align: center;
    background: #ffffff;
    border-radius: 8px;
    -webkit-box-shadow: 0px 0px 10px 0px rgba(200,240,140,0.6);
    -moz-box-shadow: 0px 0px 10px 0px rgba(200,240,140,0.6);
    box-shadow: 0px 0px 10px 0px rgba(200,240,140,0.6);
    padding: 2em;
    text-align: center;
    border: 2px solid #8DD71D;
    margin-top: 3em !important;
}


/* Customize the label (the container) */
.container {
    display: block;
    position: relative;
    padding-left: 35px;
    cursor: pointer;
    font-size: 18px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    /* Hide the browser's default checkbox */
    .container input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

/* Create a custom checkbox */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 25px;
    width: 25px;
    background-color: #fff;
    border-radius: 3px;
}

.agree-checkbox .checkmark {
    background: #E0E0E0;
}

/* On mouse-over, add a grey background color */
.container:hover input ~ .checkmark {
    background-color: #ccc;
}

/* When the checkbox is checked, add a blue background */
.notify-email .container input:checked ~ .checkmark, .agree-checkbox.container input:checked ~ .checkmark {
    background-color: #5C92FF;
}

.notify-text .container input:checked ~ .checkmark {
    background-color: #8DD71D;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the checkmark when checked */
.container input:checked ~ .checkmark:after {
    display: block;
}

/* Style the checkmark/indicator */
.container .checkmark:after {
    left: 11px;
    top: 6px;
    width: 5px;
    height: 10px;
    border: solid white;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

input#txtEmail, input#txtPhoneNumber, input#txtOtherCarrier, select#ddlCellCarrier, input#txtFirstName, input#txtLastName {
    font-size: 16px;
    border-radius: 5px;
    padding: 0.3em;
}

input#txtEmail {
    border: 2px solid #5C92FF;
}

input#txtPhoneNumber, input#txtOtherCarrier, select#ddlCellCarrier {
    border: 2px solid #8DD71D;
}

input#txtOtherCarrier {
    margin-top: 8px;
}

select#ddlCellCarrier {
    width: 30%;
}

input#txtFirstName, input#txtLastName {
    width: 100%;
    background: #EAEAEA;
    border: none;
    padding: .5em !important;
}

.PersonalInfo h4, #spnEmail h4, #spnText h4 {
    font-size: 18px;
    font-weight: 400;
    margin-bottom: .5em;
    margin-top: 0;
}

.spnText-child:nth-of-type(2) h4 {
    margin-bottom: 0 !important;
}

#spnEmail, #spnText {
    margin-top: 1em;
}

.spnText-child {
    margin-bottom: 1em;
}

    .spnText-child:last-of-type {
        margin-bottom: 0;
    }

.agree-checkbox {
    width: fit-content;
}

/*===================================
TABS STYLING --- START
===================================*/
.tabbed-content {
    background: #ffffff;
    width: 100%;
    border-radius: 8px;
}

.tablinks {
    display: flex;
    align-items: center;
}

/* Style the tab */
.tab {
    overflow: hidden;
    margin-bottom: .5em;
}

    /* Style the buttons that are used to open the tab content */
    .tab button {
        background-color: inherit;
        font-family: 'Poppins', sans-serif;
        font-size: 16px;
        font-weight: 500;
        float: left;
        border: none;
        outline: none;
        cursor: pointer;
        padding: 14px 16px;
        transition: 0.3s;
    }

        .tab button svg {
            border: none !important;
            margin-right: .5em;
        }

        .tab button span {
            border-radius: 50px;
            font-size: 12px !important;
            margin-left: 1em;
            padding: .3em .5em;
        }

        .tab button.emailSub {
            border: 2px solid #C2D6FF;
            border-radius: 1em;
            margin-right: .5em;
        }

            .tab button.emailSub.active {
                background: #C2D6FF;
            }

            .tab button.emailSub span {
                background: #C2D6FF;
            }

        .tab button.smsSub {
            border: 2px solid #D4F3A5;
            border-radius: 1em;
        }

            .tab button.smsSub.active {
                background: #D4F3A5;
            }

            .tab button.smsSub span {
                background: #D4F3A5;
            }

        .tab button.active span {
            background: #ffffff;
        }

        /* Change background color of buttons on hover */
        .tab button.emailSub:hover {
            background-color: #E4EDFF;
        }

        .tab button.smsSub:hover {
            background-color: #F1FBE1;
        }


        /* Create an active/current tablink class */
        .tab button.active {
            background-color: #ccc;
        }

/* Style the tab content */
.tabcontent {
    display: none;
    padding: 1em;
    border-top: none;
}

div#emailSub {
    background: #F5F8FF;
    border-radius: 1em;
}

div#smsSub {
    background: #F8FDF0;
    border-radius: 1em;
}

.tabcontent {
    animation: fadeEffect 1s; /* Fading effect takes 1 second */
}

/* Go from zero to full opacity */
@keyframes fadeEffect {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}
/*===================================
TABS STYLING --- END
===================================*/

/*===================================
MEDIA QUERIES --- START
===================================*/
@media (max-width: 600px) {
    .flex-wrap {
        flex-wrap: wrap;
    }

    .col-1-2 {
        max-width: 100%;
    }

        .col-1-2:first-of-type {
            margin-bottom: 1em;
            margin-right: 0;
        }
}

/* Add this to your stylesheet */
#inventoryList, #smsSubscribers, #msgLog {
    width: 100%;
    border-collapse: collapse;
}

    #inventoryList th, #smsSubscribers th, #msgLog th,
    #inventoryList td, #smsSubscribers td, #msgLog td {
        padding: 6px;
        text-align: left;
        border-bottom: 1px solid #ddd;
    }

    #msgLog td {
        vertical-align: top;
    }

    #inventoryList tr:nth-child(even) {
        background-color: #E4EDFF;
    }
    #smsSubscribers tr:nth-child(even) {
        background-color: #EAF9D2;
    }

    #msgLog tr:last-of-type {
        display: none;
    }

.tableColumn1 {
    display: flex;
    justify-content: space-around;
    align-items: center;
}
    .tableColumn1 a {
        max-height: 24px;
    }

h2, h3, table b {
    font-weight: 500;
    margin-top: 0;
}

b {
    font-weight: 600;
}

table b {
    font-weight: 600;
    text-transform: uppercase;
    font-size: 15px;
    letter-spacing: 1px;
}

div.total-subs {
    padding: .8em 1.2em;
    background: #eeeeee;
    border: 2px solid #f7f7f7;
    border-radius: 50px;
    margin-left: .8em;
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    font-weight: 500;
}

.messageColumns {
    margin-bottom: 1em;
}

.SendMessage-page-header {
    margin-bottom: 2em;
}

    .SendMessage-page-header h2 {
        margin-bottom: 0;
    }

.info-alert {
    border: 2px solid #eeeeee;
    padding: .8em 1.2em;
    border-radius: 50px;
    margin-left: 1em;
}

    .info-alert svg {
        margin-right: .3em;
    }

.col-1-2.messageEmail, .col-1-2.messageSMS {
    border-radius: 1em;
    padding: 1em;
}

.col-1-2 h3 {
    margin-top: 0;
}

.messageEmail p, .messageSMS p {
    margin-bottom: .5em;
}

.messageEmail {
    background: #C2D6FF;
}

.messageSMS {
    background: #D4F3A5;
}

input#txtSubject, textarea#txtEmailMessage, input#txtTextMessage, .settings-table input, .settings-table textarea {
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    border-radius: 5px;
    padding: 0.3em;
    width: 100%;
}

input#txtSubject, textarea#txtEmailMessage {
    border: 2px solid #5C92FF;
}

input#txtTextMessage {
    border: 2px solid #8DD71D;
}

.settings-table td {
    padding-bottom: 1.5em;
    vertical-align: top;
}

    .settings-table td:first-of-type {
        padding-top: 7px;
    }

.settings-table input, .settings-table textarea {
    border: 2px solid #22272C;
}
    .settings-table input {
        min-width: 600px;
    }