:root {
    --tyn-font-sans-serif: 'Lexend', sans-serif;
}

@font-face {
    font-family: 'bootstrap-icons';
    font-display: swap;
}

.lcp-image {
    opacity: 1 !important;
    transition: none !important;
}

:root,
[data-bs-theme="light"] {
    --tyn-border-radius: .75rem;
    --tyn-primary: #ff0701;
    --tyn-primary-rgb: 255, 7, 1;
    --tyn-primary-text-emphasis: #cc0601;
    --tyn-primary-bg-subtle: #ffe6e5;
    --tyn-primary-border-subtle: #ffb3b0;
}

[data-bs-theme="dark"] {
    --tyn-primary-text-emphasis: #ff5a55;
    --tyn-primary-bg-subtle: #2b1515;
    --tyn-primary-border-subtle: #4a1e1e;
}

.btn-primary {
    --tyn-btn-bg: #ff0701;
    --tyn-btn-color: #fff;
    --tyn-btn-border-color: #ff0701;
    --tyn-btn-hover-bg: #cc0601;
    --tyn-btn-hover-color: #fff;
    --tyn-btn-hover-border-color: #cc0601;
    --tyn-btn-active-bg: #b30501;
    --tyn-btn-active-border-color: #b30501;
    --tyn-btn-disabled-bg: #ff0701;
    --tyn-btn-disabled-border-color: #ff0701;
    --tyn-btn-disabled-color: #fff;
}

.btn-outline-primary {
    --tyn-btn-color: #ff0701;
    --tyn-btn-border-color: #ff0701;
    --tyn-btn-hover-bg: #ff0701;
    --tyn-btn-hover-color: #fff;
    --tyn-btn-hover-border-color: #ff0701;
    --tyn-btn-active-bg: #cc0601;
    --tyn-btn-active-border-color: #cc0601;
    --tyn-btn-disabled-color: #ff0701;
    --tyn-btn-disabled-border-color: #ff0701;
}



label:has(+ input[required])::after,
label:has(+ textarea[required])::after,
label:has(+ select[required])::after,
label:has(+ .tom-select-custom select[required])::after {
    content: " *";
    color: red;
}

.invalid-feedback strong {
    font-weight: 400 !important;
}

.card {
    --tyn-card-spacer-y: .75rem;
    --tyn-card-spacer-x: .75rem;
}

.card.job-card {
    transition: border-color .3s ease-in-out;
    cursor: pointer;
}

.card.job-card:hover {
    border-color: var(--tyn-primary);
    --tyn-card-border-color: var(--tyn-primary);
}

@media (min-width: 992px) {
    .navbar-expand-lg .navbar-nav>.nav-item>.nav-link:before {
        bottom: -.65rem !important;
    }

    .navbar-expand-lg .header-secondary .navbar-nav>.nav-item>.nav-link:before {
        bottom: -.5rem !important;
    }

}

.btn-group-xs>.btn-icon.btn,
.btn-icon.btn-xs {
    --tyn-btn-size: 1rem;
}

/* Swiper performance optimizations - reduce forced reflows */
.swiper,
.swiper-wrapper {
    will-change: transform;
    transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.swiper-slide {
    will-change: transform;
    transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

section.banner {
    margin-bottom: 10rem;
}

section.banner .swiper-slide {
    padding: 5rem 0 8rem;
}


section.banner .prev-wrapper {
    top: 50%;
    left: 0;
}

section.banner .next-wrapper {
    top: 50%;
    right: 0;
}

.list-card-link .card {
    transition: border-color .3s ease-in-out;
}

.list-card-link:hover .card {
    border-color: var(--tyn-btn-hover-border-color) !important;
}

.list-card-link .image-wrapper {
    height: 100%;
    min-height: 100%;
    max-height: 200px;
}

.list-card-link .image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media (min-width: 768px) {
    .list-card-link .row .row .col-md-4 {
        border-left: var(--tyn-border-width) var(--tyn-border-style) var(--tyn-border-color) !important;
    }
}

@media (max-width: 768px) {
    section.banner .swiper-slide {
        padding: 2rem 0 8rem !important;
    }

    section.banner .prev-wrapper {
        top: 70% !important;
        left: 39% !important;
    }

    section.banner .next-wrapper {
        top: 70% !important;
        right: 39% !important;
    }
}

.login-right {
    max-width: 1000px;
}

@media (max-width: 1620px) {
    .login-right {
        max-width: clamp(500px, 55vw, 800px);
    }
}

@media (min-width: 1024px) {
    aside .sticky-lg-top {
        top: 6rem;
    }
}

.swiper-pagination-bullet.swiper-pagination-bullet-active {
    background-color: var(--tyn-primary);
    width: 16px;
    margin: 0;
}

.swiper-pagination-bullet {
    width: 8px;
    margin: 0 3px !important;
    border-radius: 50rem;
    transition: width 0.3s ease-in-out;
}

.nav-underline .nav-link:before {
    background-color: var(--tyn-primary);
    height: 3px;
}

.avatar-stack {
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.avatar-stack .avatar {
    overflow: hidden;
    margin-left: -8px;
    border: 1px solid #fff;
}

.avatar {
    --bs-avatar-width: 24px;
    --bs-avatar-bg: var(--tyn-primary-bg-subtle);
    position: relative;
    width: var(--bs-avatar-width);
    height: var(--bs-avatar-width);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--tyn-primary-text-emphasis);
    line-height: 1;
    font-size: 14px;
    border-radius: 50%;
    -o-object-fit: cover;
    object-fit: cover;
    background-color: var(--bs-avatar-bg);
}

section.companies .swiper:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: 100%;
    background: linear-gradient(to right, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
    z-index: 99;
}

section.companies .swiper:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100px;
    height: 100%;
    background: linear-gradient(to left, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
    z-index: 99;
}

.fade-lr {
    position: relative;
    mask-image: linear-gradient(90deg, transparent 0%, #000 20%, #000 80%, transparent 100%);
}

@media (max-width: 768px) {
    ol.breadcrumb {
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        white-space: nowrap;
    }

    ol.breadcrumb>li {
        flex-shrink: 0;
    }

}

.home-navigation {
    top: 100%;
    min-height: 200px;
    will-change: transform;
}

@media (max-width: 768px) {
    .home-navigation {
        top: 120%;
        min-height: 250px;
    }
}

.content-wrapper {
    margin-top: 0;
    padding-top: 0;
}

section.banner {
    min-height: 420px;
    position: relative;
}

section.banner + .home-navigation {
    position: absolute;
    top: calc(420px - 100px);
}

@media (max-width: 768px) {
    section.banner {
        min-height: 490px;
    }
    section.banner + .home-navigation {
        top: calc(490px - 50px);
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    section.banner {
        min-height: 580px;
    }
    section.banner + .home-navigation {
        top: calc(580px - 100px);
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    section.banner {
        min-height: 470px;
    }
    section.banner + .home-navigation {
        top: calc(470px - 100px);
    }
}

@media (min-width: 1200px) and (max-width: 1399px) {
    section.banner {
        min-height: 420px;
    }
    section.banner + .home-navigation {
        top: calc(420px - 100px);
    }
}

@media (min-width: 1400px) {
    section.banner {
        min-height: 420px;
    }
    section.banner + .home-navigation {
        top: calc(420px - 100px);
    }
}

section.vitrin {
    margin-bottom: 3rem;
    margin-top: 3rem;
}

@media (max-width: 768px) {
    section.vitrin {
        margin-top: 21rem;
    }
}

.seo-text-content :is(h1, h2, h3, h4, h5) {
    font-weight: 600;
    font-size: 16px !important;
}

.seo-text-content p {
    font-size: 16px !important;
}

.vitrin-badge {
    --white: #e6ebf6;
    transform: translate(-29.29%, -100%) rotate(-45deg);
    background: linear-gradient(rgba(0, 0, 0, 0.5) 0 0) bottom / 100% 6px no-repeat var(--tyn-primary);
    clip-path: polygon(0 0, 100% 0, 100% 100%, calc(100% - 6px) calc(100% - 6px), 6px calc(100% - 6px), 0 100%);
    -webkit-mask: linear-gradient(135deg, transparent calc(50% - 6px * 0.707), var(--white) 0) bottom left, linear-gradient(-135deg, transparent calc(50% - 6px * 0.707), var(--white) 0) bottom right;
    -webkit-mask-size: 300vmax 300vmax;
    -webkit-mask-composite: destination-in, xor;
    mask-composite: intersect;
    z-index: 10;
    font-size: 11px;
    font-weight: 500;
    background-clip: padding-box;
    text-align: center;
    padding: 5px 30px 10px;
    border: 1px solid transparent;
    border-bottom: 0;
    border-left: 1px solid transparent;
    transform-origin: bottom right;
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
}

.glightbox-clean .gclose path,
.glightbox-clean .gnext path,
.glightbox-clean .gprev path {
    fill: #000;
}

@media (min-width: 640px) {

    .choices__list--dropdown .choices__item--selectable,
    .choices__list[aria-expanded] .choices__item--selectable {
        padding-right: 20px !important;
    }
}

@media (min-width: 768px) {
    .d-md-table-header-group {
        display: table-header-group !important;
    }
}

@media (max-width: 768px) {
    .category-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
        overflow: hidden;
    }

    .category-container .col-lg-9>div:first-child {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

}

.btn-doping {
    position: relative;
    color: #fff;
    border: none;
    background: linear-gradient(
        120deg,
        #ff0701,
        #ff6a00,
        #ff0701
    );
    background-size: 300% 300%;
    animation: bgFlow 4s ease infinite;
    transition: transform .2s ease, box-shadow .2s ease;
}

.btn-doping i {
    transition: transform .3s ease;
}

.btn-doping:hover {
    animation-duration: 1.5s;
    color: #fff;
}

.btn-doping:hover i {
    transform: translateX(5px) rotate(-12deg);
}

@keyframes bgFlow {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}
