﻿@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;700&display=swap');

html {
    background: #FFFFFF;
}

body {
    font-family: 'Poppins', Arial, Helvetica, sans-serif !important;
}

/* Bootstrap Overrides
--------------------------------------------------- */

.alert {
    border: none;
    border-radius: 10px;
}

.alert-danger {
    background-color: #DC3545;
    color: #FFF;
}

.alert-success {
    background-color: #28A745;
    color: #FFF;
}

.alert-warning {
    background-color: #FFCD17;
    color: #000;
}

.alert-info {
    background-color: #a63190;
    color: #FFF;
}

.alert-dismissible .close:hover {
    color: #FFF;
}

.badge-info {
    background-color: #a63190;
}

.bg-primary {
    background-color: #2bbeb3 !important;
}

.bg-secondary {
    background-color: #197973 !important;
}

.bg-info {
    background-color: #a63190 !important;
}

.bg-info-dark {
    background-color: #a63190 !important;
}

.btn {
    border-radius: 0;
    font-weight: 700;
    font-family: 'Poppins', Arial, Helvetica, sans-serif !important;
}

    .btn:not(.btn-link):not(.btn-link-custom):not(.close) {
        border-radius: 50rem;
        font-size: 20px;
        padding-left: 32px;
        padding-right: 32px;
        text-transform: uppercase;
    }

.btn-primary {
    color: #FFFFFF;
    background: #2bbeb3;
    border-color: #2bbeb3;
}

    .btn-primary:hover {
        color: #FFFFFF;
        background: #2c3038;
        border-color: #2c3038;
        transition: 0.3s;
    }

    .btn-primary.disabled, .btn-primary:disabled {
        color: #888;
        background-color: #EFEFEF;
        border-color: #EFEFEF;
    }

.btn-outline-primary {
    color: #2bbeb3;
    border-color: #2bbeb3;
}

    .btn-outline-primary:hover {
        color: #FFFFFF;
        border-color: #2c3038;
        background-color: #2c3038;
        transition: 0.3s;
    }

.card {
    border: none;
    border-radius: 0;
}

.col-form-label {
    font-weight: 600;
    color: #197973;
}

@media (min-width: 576px) {
    .form-group.row > .col-form-label {
        text-align: right;
    }
}

.form-control {
    border: 1px solid #B4B4B4;
    border-radius: 0 !important;
    color: #343a40;
}

    .form-control:focus {
        border-color: #888888;
        box-shadow: 0 0 0 0.2rem rgba(80, 80, 80, 0.25);
    }

.form-check-input:checked {
    background-color: #197973;
    border-color: #197973;
}

.input-group-text {
    border-color: #B4B4B4;
}

.modal-content {
    border: 1px solid #B4B4B4;
    border-radius: 0;
}

.navbar-toggler {
    border: none;
    padding: 8px 10px;
}

    .navbar-toggler:focus {
        border: none;
    }

.dropdown-menu {
    border: 1px solid #221e1f;
    border-radius: 0;
}

.nav-item.dropdown .dropdown-menu .dropdown-item {
    padding-top: 8px;
    padding-bottom: 8px;
}

    .nav-item.dropdown .dropdown-menu .dropdown-item:active {
        background-color: inherit;
    }

.nav-link {
    text-transform: uppercase;
}

.navbar .dropdown * {
    text-transform: uppercase !important;
}

.nav-pills .nav-link {
    border-radius: 0;
    font-size: 20px;
    font-family: 'Poppins', Arial, Helvetica, sans-serif !important;
}

    .nav-pills .nav-link.active {
        background-color: #2bbeb3;
    }

.navbar-dark .nav-item > a {
    color: #FFFFFF !important;
    font-family: 'Poppins', Arial, Helvetica, sans-serif !important;
}

.navbar-light .nav-item > a {
    color: #197973 !important;
    font-family: 'Poppins', Arial, Helvetica, sans-serif !important;
}

.text-primary {
    color: #2bbeb3 !important;
}

.text-secondary {
    color: #197973 !important;
}

.text-info {
    color: #a63190 !important;
}


/* Custom
--------------------------------------------------- */

h1, .h1, h2, .h2 {
    font-family: 'Poppins', Arial, Helvetica, sans-serif;
}

h3, .h3, h4, .h4, h5, .h5, h6 .h6 {
    font-family: 'Poppins', Arial, Helvetica, sans-serif;
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6 .h6 {
    color: #181614;
    font-weight: 700 !important;
}

a {
    color: #2bbeb3;
    text-decoration: none;
    background-color: transparent;
}

    a:hover {
        color: #197973;
    }

select.select-box[size] {
    height: 400px;
    overflow-x: auto;
}

.alert-rounded {
    border-radius: 8px;
}

.bg-lighter {
    background-color: #FAFAFA;
}

.bg-login {
    background-image: url(/client/img/ep_bg_login.PNG);
    background-size: cover;
    background-position: center;
    filter: brightness(100%);
}

.bg-navbar {
    background-color: #221e1f;
}

.btn-action {
    min-width: 100px;
    padding: 10px 16px;
}

.btn-inline {
    font-size: 1rem !important;
}

.btn-link-custom {
    background: none !important;
    border: none;
    padding: 0 !important;
    color: #2bbeb3;
    text-decoration: none;
    cursor: pointer;
}

    .btn-link-custom:hover {
        color: #23396F;
        text-decoration: underline;
    }

    .btn-link-custom[disabled] {
        color: #B4B4B4;
    }

        .btn-link-custom[disabled]:hover {
            text-decoration: none;
            cursor: default;
        }

.card-accent-bottom {
    border-bottom: 5px solid #2bbeb3;
}

.card-custom {
    border: 1px solid #B4B4B4;
}

.card-ticket {
    border: 1px solid #B4B4B4;
    /*    border: 25px solid #343a40;
    -moz-border-image: url(/img/ticket-bg.svg) 25 25 repeat;
    -o-border-image: url(/img/ticket-bg.svg) 25 25 repeat;
    -webkit-border-image: url(/img/ticket-bg.svg) 25 25 repeat;
    border-image: url(/img/ticket-bg.svg) 25 25 repeat;*/
}

.footer {
    background: #221e1f;
    color: #FFFFFF;
}

    .footer a {
        color: #FFFFFF;
    }

.form-check.form-check-large {
    margin-bottom: 10px;
}

    .form-check.form-check-large input[type=checkbox] {
        position: absolute !important;
        height: 1px;
        width: 1px;
        overflow: hidden;
        clip: rect(1px 1px 1px 1px);
        IE6, IE7 clip: rect(1px, 1px, 1px, 1px);
    }

        .form-check.form-check-large input[type=checkbox] + label {
            line-height: 24px;
        }

            .form-check.form-check-large input[type=checkbox] + label::before {
                display: flex;
                content: '';
                position: relative;
                display: inline-block;
                margin-right: 10px;
                width: 24px;
                height: 24px;
                background: #FFFFFF;
                border: 1px solid #2bbeb3;
                border-radius: 0px;
                vertical-align: -25%;
            }

        .form-check.form-check-large input[type=checkbox]:checked + label::before {
            background: #2bbeb3 url(../../img/check-white.svg) no-repeat center;
            background-size: 16px 16px;
            color: #FFFFFF;
        }

        .form-check.form-check-large input[type=checkbox]:disabled + label::before {
            background: #EFEFEF;
            border-color: #888;
        }

    .form-check.form-check-large input[type='checkbox']:focus + label::before {
        border-color: #888888;
        box-shadow: 0 0 0 0.2rem rgba(80, 80, 80, 0.25);
    }

    .form-check.form-check-large input[type=radio] {
        position: absolute !important;
        height: 1px;
        width: 1px;
        overflow: hidden;
        clip: rect(1px 1px 1px 1px);
        IE6, IE7 clip: rect(1px, 1px, 1px, 1px);
    }

        .form-check.form-check-large input[type=radio] + label {
            line-height: 24px;
        }

            .form-check.form-check-large input[type=radio] + label::before {
                display: flex;
                content: '';
                position: relative;
                display: inline-block;
                margin-right: 10px;
                width: 24px;
                height: 24px;
                background: #FFFFFF;
                border: 1px solid #2bbeb3;
                border-radius: 50%;
                vertical-align: -25%;
            }

        .form-check.form-check-large input[type=radio]:checked + label::before {
            background-color: #2bbeb3;
            background-clip: content-box;
            background-size: 16px 16px;
            padding: 3px;
            color: #FFFFFF;
        }

        .form-check.form-check-large input[type=radio]:disabled + label::before {
            background: #EFEFEF;
            border-color: #888;
        }

    .form-check.form-check-large input[type='radio']:focus + label::before {
        border-color: #888888;
        box-shadow: 0 0 0 0.2rem rgba(80, 80, 80, 0.25);
    }

.form-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: #197973;
}

.img-event {
    height: 90px;
    width: 90px;
    object-position: center;
    object-fit: contain;
}

.img-logo {
    height: 100px;
}

.link-tile:hover {
    text-decoration: none;
    filter: brightness(80%);
}

.list-group-item {
    border: 1px solid #B4B4B4;
    border-radius: 0;
}

.max-lines-2 {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.no-padding {
    margin: 0 !important;
    padding: 0 !important;
}

.no-scroll {
    overflow: hidden;
}

.snackbar {
    position: fixed;
    bottom: 64px;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: 999;
}

@media (max-width: 576px) {
    .btn-action {
        width: 100%;
    }
}


/* Animations
--------------------------------------------------- */

.loader,
.loader:before,
.loader:after {
    border-radius: 50%;
    width: 2.5em;
    height: 2.5em;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation: load7 1.8s infinite ease-in-out;
    animation: load7 1.8s infinite ease-in-out;
}

.loader {
    color: #197973;
    font-size: 4px;
    margin: 16px auto;
    position: relative;
    text-indent: -9999em;
    -webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-animation-delay: -0.16s;
    animation-delay: -0.16s;
}

    .loader:before,
    .loader:after {
        content: '';
        position: absolute;
        top: 0;
    }

    .loader:before {
        left: -3.5em;
        -webkit-animation-delay: -0.32s;
        animation-delay: -0.32s;
    }

    .loader:after {
        left: 3.5em;
    }

@-webkit-keyframes load7 {
    0%, 80%, 100% {
        box-shadow: 0 2.5em 0 -1.3em;
    }

    40% {
        box-shadow: 0 2.5em 0 0;
    }
}

@keyframes load7 {
    0%, 80%, 100% {
        box-shadow: 0 2.5em 0 -1.3em;
    }

    40% {
        box-shadow: 0 2.5em 0 0;
    }
}

/* Step bar ----------------------------------------------------------------- */

.stepper-wrapper {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}

.stepper-item {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    font-family: 'Poppins', Arial, Helvetica, sans-serif;
}

    .stepper-item::before {
        position: absolute;
        content: "";
        border-bottom: 2px solid #ccc;
        width: 100%;
        top: 20px;
        left: -50%;
        z-index: 2;
    }

    .stepper-item::after {
        position: absolute;
        content: "";
        border-bottom: 2px solid #ccc;
        width: 100%;
        top: 20px;
        left: 50%;
        z-index: 2;
    }

    .stepper-item .step-counter {
        position: relative;
        z-index: 5;
        display: flex;
        justify-content: center;
        align-items: center;
        width: 40px;
        height: 40px;
        border-radius: 50%;
        background: #ccc;
        margin-bottom: 6px;
    }

    .stepper-item.active {
        font-weight: bold;
    }

    .stepper-item.completed .step-counter {
        background-color: #197973;
        color: #ffffff;
    }

    .stepper-item.completed::after {
        position: absolute;
        content: "";
        border-bottom: 2px solid #197973;
        width: 100%;
        top: 20px;
        left: 50%;
        z-index: 3;
    }

    .stepper-item:first-child::before {
        content: none;
    }

    .stepper-item:last-child::after {
        content: none;
    }

/* Telerik ------------------------------------------------------------------ */

.k-widget * {
    font-family: 'Poppins', Arial, Helvetica, sans-serif !important;
}

.k-event {
    color: #FFFFFF;
    background-color: #2bbeb3;
    font-weight: 500;
}

    .k-event.k-state-selected {
        color: #FFFFFF;
        background-color: #2bbeb3;
        font-weight: 500;
        box-shadow: none;
    }

.k-more-events {
    content: 'More events...';
}

.k-button-solid-base.k-selected {
    border-color: #2c3038;
    color: #fff;
    background-color: #2c3038;
}

.k-icon {
    font-family: WebComponentsIcons !important;
}
