:root {
    font-size: 16px;

    --white: #ffffff;
    --grey: #f6f7f8;
    --dark-grey: #c4c4c4;
    /* --grey-back: #fefefe; */
    --black: #1f1923;
    --blue: #edfcff;
    --aqua: #cdf5f5;
    --aqua-green: #abd3cd;
    --aqua-deep: #72a4a5;
    --orange: #e4843f;


    --border-radius: 1.875rem;

    --header-height: 111px;
    --slider-height: 770px;

    --container-padding: 30px;
}

.textured-back {
    background: url('/vendor/img/dot-grid.png');
    background-position: center;
    background-repeat: repeat;
}

body {
    color: var(--black);
    font-size: 1rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-optical-sizing: auto;
    line-height: 1.5;
    background-color: var(--white);
}

h1,
h2,
h3,
h4 {
    line-height: 1.5;
    margin: 0 0 0.5em;
}

h1 {
    font-size: 2.5rem;
    font-weight: 600;
}

h2 {
    font-size: 2rem;
    font-weight: 600;
}

h3 {
    font-size: 1.625rem;
    font-weight: 600;
}

h4 {
    font-size: 1.25rem;
    font-weight: 600;
}

a {
    color: var(--menu-items-font-color);
    text-decoration: none;
}

a[name] {
    --offset: calc( -1 * (var(--header-height)) - 60px );
    display: block;
    transform: translateY( var(--offset) );
}

.btn-prim {
    display: block;
    color: var(--white);
    background-color: var(--orange);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    letter-spacing: 0.05em;
    border: 2px solid var(--orange);
    border-radius: 1em;
    padding: 1em 3em;
    -webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
    transition: all .2s ease;
}

.btn-prim:hover,
.btn-prim:active {
    color: var(--orange);
    background-color: var(--white);
    text-decoration: none;
    border: 2px solid var(--orange);
}

.btn-prim.black {
    background-color: var(--black);
    font-size: 1rem;
    border: 2px solid var(--black);
}

.btn-prim.black:hover,
.btn-prim.black:active {
    color: var(--orange);
    border: 2px solid var(--black);
}

.btn-prim.orange {
    position: relative;
    background-color: var(--orange);
    color: var(--white);
    font-size: 1rem;
    border: 2px solid var(--orange);
    overflow: hidden;
    z-index: 1;
}

.btn-prim.orange::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 100%;
    height: 100%;
    background-color: var(--aqua-deep);
    -webkit-transform: translateY(100%);
    -ms-transform: translateY(100%);
    transform: translateY(100%);
    -webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
    transition: all .2s ease;
    z-index: -1;
}

.btn-prim.orange:hover,
.btn-prim.orange:active {
    border: 2px solid var(--aqua-deep);
}

.btn-prim.orange:hover::after,
.btn-prim.orange:active::after {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
}

.btn-neg {
    display: block;
    color: var(--white);
    background-color: transparent;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    letter-spacing: 0.05em;
    border: 2px solid var(--white);
    border-radius: 1em;
    padding: 1em 3em;
    -webkit-transition: all .1s ease;
	-moz-transition: all .1s ease;
    transition: all .1s ease;
}

.btn-neg.pink {
    color: var(--orange);
    border: 2px solid var(--orange);
}

.btn-neg:hover,
.btn-neg:active,
.btn-neg.active {
    color: var(--black);
    background-color: var(--white);
    border: 2px solid var(--white);
}

.btn-neg.pink:hover,
.btn-neg.pink:active,
.btn-neg.pink.active {
    color: var(--white);
    background-color: var(--orange);
    border: 2px solid var(--orange);
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
select,
textarea {
    width: 100%;
	color: var(--black);
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.5;
    background-color: var(--white);
    border: 2px solid var(--white);
    border-radius: 1em;
    padding: 1em 2em;
}

select i {
    position: absolute;
    right: 5%;
    top: 25%;
    cursor: pointer;
    color: #3097D1;
    pointer-events: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
select:focus,
textarea:focus {
    background-color: var(--white);
    border: 2px solid var(--black);
	outline: none !important;
    box-shadow: none;
}

.form-check-input {
    float: left;
    background-color: var(--orange);
    border: 2px solid var(--white);
    margin-right: 0.5rem;
    outline: none !important;
    box-shadow: none !important;
    
}

.form-check-input:checked,
.form-check-input:focus {
    background-color: var(--orange);
    border: 2px solid var(--white);
    outline: none !important;
    box-shadow: none !important;
}

hr {
    margin: 1rem 0;
    color: var(--dark-grey);
    background-color: var(--dark-grey);
    border: 0;
    opacity: 1;
}

input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="url"]::placeholder,
input[type="password"]::placeholder,
input[type="search"]::placeholder,
input[type="number"]::placeholder,
input[type="tel"]::placeholder,
input[type="range"]::placeholder,
input[type="date"]::placeholder,
input[type="month"]::placeholder,
input[type="week"]::placeholder,
input[type="time"]::placeholder,
input[type="datetime"]::placeholder,
input[type="datetime-local"]::placeholder,
select::placeholder,
option:disabled,
textarea::placeholder {
    color: var(--black);
    opacity: 0.75;
}

/* header */
.site-header {
    display: flex;
    flex-direction: row;
    background-color: var(--white);
    -webkit-transition: all .1s ease;
	-moz-transition: all .1s ease;
    transition: all .1s ease;
}

.site-header.move {
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1);
}

/* navbar */
.navbar {
    width: 100%;
    min-height: var(--header-height);
    padding: 0 var(--container-padding);
}
.navbar .navbar-brand img {
    width: 200px;
    height: auto;
}
.navbar .navbar-brand,
.navbar .cont-wrap .cont-wrap {
    flex-shrink: 0;
}

.navbar .navbar-brand {
    padding: 0;
}

.navbar .cont-wrap {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    align-items: center;
    margin-left: 7%;
}

.navbar .soc-icon {
    color: var(--black);
    background-color: transparent;
    font-size: 1rem;
    font-weight: 500;
    border: none;
    border-radius: 0.5em;
    padding: 0.5em;
}

.navbar .soc-icon:hover {
    background-color: var(--grey);
}

.navbar .soc-icon i {
    padding-right: 4px;
}

.navbar .phone {
    position: relative;
    display: block;
    color: var(--black);
    font-size: 1.375rem;
    font-weight: 500;
}

.navbar .phone:hover::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    display: block;
    width: 100%;
    height: 3px;
    background-color: var(--orange);
}

.navbar .navbar-nav {
    width: 100%;
    justify-content: flex-end;
    column-gap: 0.5rem;
}

.navbar .navbar-nav .nav-item {
    position: relative;
}

/* .navbar .navbar-nav .nav-item:has(.navbar-subnav) > .nav-link::after  {
    content: '\25BC';
    font-size: 0.625rem;
    margin-left: 0.25em;
    vertical-align: middle;
} */

.navbar .navbar-nav .nav-link {
    position: relative;
    color: var(--black);
    background-color: transparent;
    /* font-size: 1.125rem; */
    font-size: 1rem;
    font-weight: 500;
    border: none;
    border-radius: 0.5em;
    padding: 0.5em 1em;
}

.navbar .navbar-nav .nav-link:hover {
    background-color: var(--grey);
}

.navbar .navbar-nav .nav-link.active {
    background-color: var(--aqua);
}

.navbar .navbar-nav .nav-item .navbar-subnav {
    position: absolute;
    top: calc( 100% + 2px );
    left: 0;
    display: none;
    width: max-content;
    height: auto;
    background-color: var(--aqua);
    border-radius: 1em;
    margin: 0;
    padding: 0.75rem 1.5rem;
    z-index: 2;
}

.navbar .navbar-nav .nav-item:hover .navbar-subnav {
    display: block;
}

.navbar .navbar-nav .nav-item .navbar-subnav .subnav-item {
    list-style: none;
    padding: 0.25em 0;
}

.navbar .navbar-nav .nav-item .navbar-subnav .subnav-item .nav-link {
    color: var(--grey);
    font-size: 1rem;
    font-weight: 400;
    text-transform: uppercase;
    border: none;
    padding: 0;
}

.navbar .navbar-toggler {
    border: none;
}

.navbar .navbar-toggler:hover,
.navbar .navbar-toggler:active {
    border: none;
    outline: none;
    box-shadow: none;
}

.navbar .navbar-no-collapse {
    display: flex !important;
    flex-basis: auto;
    flex-grow: 1;
    align-items: center;
}



/* slider section */
.slider {
    position: relative;
}

.slider .slick-dotted.slick-slider {
    margin: 0;
}

.slider .slider-list {
    
}

.slider .slider-list .item {
    position: relative;
    display: flex;
    flex-direction: row;
    aspect-ratio: 2.5 / 1;
    border-radius: var(--border-radius);
    overflow: hidden;
}

.slider .slider-list .item.cropped:nth-child(3n+1) {
    background: url('/vendor/img/sinus.png'), var(--aqua);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.slider .slider-list .item.cropped:nth-child(3n+2) {
    background: url('/vendor/img/bubbles.png'), var(--aqua);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.slider .slider-list .item.cropped:nth-child(3n) {
    background: url('/vendor/img/roulette.png'), var(--aqua);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.slider .slider-list .item.cropped .caption {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 50%;
    transform: translateY(-50%);
    padding: 0 5rem;
}

.slider .slider-list .item.cropped .caption .slider-title {
    display: block;
    color: var(--black);
    font-size: clamp(1.5rem, 2.5vw, 3rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 0.5em;
}

.slider .slider-list .item.cropped .caption .slider-text {
    display: block;
    color: var(--black);
    font-size: 1.25rem;
}

.slider .slider-list .item.full .caption .btn-neg,
.slider .slider-list .item.full .caption .btn-prim,
.slider .slider-list .item.cropped .caption .btn-neg,
.slider .slider-list .item.cropped .caption .btn-prim {
    margin-top: 3rem;
    width: max-content;
}

.slider .slider-list .item.cropped .slider-image {
    position: absolute;
    top: 50%;
    right: 0;
    display: block;
    width: 50%;
    height: auto;
    transform: translateY(-50%);
    padding-right: 5rem;
}

.slider .slider-list .item.full::after {
    content: '';
    position: absolute;
    inset: 0;
    display: block;
    background-image: linear-gradient(0deg, var(--aqua) 0%, var(--aqua-deep) 100%);
    z-index: 7;
    opacity: 0.35;
}

.slider .slider-list .item.full .caption {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 40%;
    transform: translateY(-50%);
    margin: 0 0 5rem 2.5rem;
    padding: 2.5rem;
    background: white;
    border-radius: var(--border-radius);
    overflow: hidden;
    z-index: 10;
    opacity: 0.9;
}

.slider .slider-list .item.full .caption .slider-title {
    display: block;
    color: var(--black);
    font-size: 4.175vw;
    font-size: clamp(1.5rem, 2.5vw, 3rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 0.5em;
}

.slider .slider-list .item.full .caption .slider-text {
    display: block;
    color: var(--black);
    font-size: 1.25rem;
}

.slider .slider-list .item.full .slider-image {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
    z-index: 5;
    
    /* filter: grayscale(50%) brightness(125%);
    -webkit-filter: grayscale(50%) brightness(125%);
    -moz-filter: grayscale(50%) brightness(125%); */
}

/* slick slider */
.slick-slider .slick-list {
    margin: 0 -0.75rem;
}

.slick-slider .slick-list .slick-slide {
    margin: 0 0.75rem;
}

.slick-dots {
    left: 0;
    bottom: -3rem;
    z-index: 1000;
}

.slick-dots li {
    margin: 0;
}

.slick-dots li:only-of-type {
    display: none;
}

.slick-dots li button::before {
    color: var(--aqua-deep);
    font-size: 0.5rem;
    opacity: .5;
}

.slick-dots li.slick-active button::before {
    color: var(--aqua-deep);
    opacity: 1;
}

.slick-prev,
.slick-next {
    width: 3rem;
    height: 3rem;
    background-color: var(--white);
    border-radius: 50%;
}

.slick-prev {
    left: -5%;
}

.slick-next {
    right: -5%;
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus{
    background-color: var(--orange);
}

.slick-prev::before,
.slick-next::before {
    color: var(--orange);
    font-family: 'stirka';
    font-size: 1.5rem;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-prev::before {
    content: '\f104';
}

.slick-next::before {
    content: '\f105';
}

.slick-prev:hover::before,
.slick-prev:focus::before,
.slick-next:hover::before,
.slick-next:focus::before{
    color: var(--white);
}


/* breadcrumbs */
.slider #breadcrumb {
    position: absolute;
    top: 2.75rem;
    left: 2.75rem;
}

.breadcrumb-page {
    display: block;
    padding: 3rem 0;
}

#breadcrumb {
    display: inline-block;
    list-style-type: none;
    padding: 0;
    margin: 0;
}

#breadcrumb li {
    display: inline;
    color: var(--aqua-deep);
    font-size: 1rem;
}

#breadcrumb li a {
    color: var(--aqua-deep);
}

#breadcrumb li:hover a {
    color: var(--black);
}

#breadcrumb li + li:before {
    content:  '|';
    margin: 0 1em;
    opacity: 0.5;
}

/* page title */
.page-title .title {
    display: block;
    color: var(--black);
    font-size: 2.5rem;
    font-weight: 600;
    line-height: 1.2;
    word-break: break-word;
    margin: 0 0 1em;
}

/* sections */
section {
    display: block;
    padding-top: 0;
    margin-left: var(--container-padding);
    margin-right: var(--container-padding);
    padding-bottom: 7.5rem;
    overflow: hidden;
}

#price-page section.page-content {
    padding-bottom: 1.5rem;
}

section .title {
    display: block;
    color: var(--black);
    font-size: 2.5rem;
    font-weight: 600;
    line-height: 1.2;
    word-break: break-word;
    margin: 0 0 1em;
}

section:has(.sub-title) .title {
    margin: 0 0 0.5em;
}

section .sub-title {
    display: block;
    color: var(--black);
    font-size: 1.125rem;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 2em;
}

section .title span {
    color: var(--orange);
}

section .hd-wrap {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    align-items: center;
}

section .hd-wrap .title {
    line-height: 1;
    flex-grow: 1;
}

/* about */
.about {
    position: relative;
}

.about .text {
    display: block;
    color: var(--black);
    font-size: 1rem;
}

.about .text ul li {
    padding-bottom: 0.5em;
}

/* advants */
.advants .advants-facts-list {
    margin-top: 3rem;
}

.advants .advants-facts-list .item {
    display: block;
    color: var(--black);
    background-color: var(--aqua);
    border-radius: var(--border-radius);
    padding: 2.75rem;
}

.advants .advants-facts-list .container .row > div:nth-child(3n+1) .item {
    background: url('/vendor/img/sinus.png'), var(--aqua);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.advants .advants-facts-list .container .row > div:nth-child(3n+2) .item {
    background: url('/vendor/img/bubbles.png'), var(--aqua);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.advants .advants-facts-list .container .row > div:nth-child(3n) .item {
    background: url('/vendor/img/roulette.png'), var(--aqua);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.advants .advants-facts-list .item h3 {
    display: block;
    font-size: 1.5rem;
    font-weight: 500;
    margin-bottom: 0.5em;
}

.advants .advants-facts-list .item h3 i {
    color: var(--aqua-deep);
}

.advants .advants-facts-list .item span {
    display: block;
    font-size: 1.125rem;
}


/* tables */
table {
    width: 100%;
    margin-bottom: 1rem;
}

table thead tr {
    background-color: var(--grey);
    font-weight: 600;
}

table td {
    padding: 0.25em 0.5em;
}

/* video section */
.video {
    
}

.video iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    border-radius: var(--border-radius);
}

/* seo section */
.seo {

}

.seo .content {
    display: block;
    color: var(--black);
    font-size: 1rem;
}

.seo .content p {
    break-inside: avoid-column;
}

.seo .content ul {
    list-style: none;
    padding: 0;
}

.seo .content ul li {
    padding-bottom: 0.5em;
}

.seo .content ul li::before {
    content: '\e800';
    display: inline-block;
    color: var(--aqua-deep);
    width: 1em;
    font-family: "stirka";
    font-style: normal;
    font-weight: normal;
    line-height: 1em;
    text-align: center;
    font-variant: normal;
    text-decoration: inherit;
    text-transform: none;
    speak: never;
    margin-right: .5em;
    margin-left: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


/* page content */
.page-content,
.page-content-image,
.page-content-map {
    
}

.page-content-image .image-wrap {
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--border-radius);
    aspect-ratio: 3 / 2;
    margin-bottom: 1.25rem;
    overflow: hidden;
}

.page-content-image .image-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.page-content-map .map-wrap {
    height: 510px;
    border-radius: var(--border-radius);
    overflow: hidden;
}

.page-content-map .contacts-wrap {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.page-content-map .contacts-wrap .tel,
.page-content-map .contacts-wrap .address,
.page-content-map .contacts-wrap .schedule {
    display: inline-block;
    color: var(--black);
    font-size: 1.125rem;
}

.page-content-map .contacts-wrap > span i {
    font-size: 1.125em;
    color: var(--aqua-deep);
}

.page-content .content,
.page-content-image .content,
.page-content-map .content {
    font-size: 1rem;
}

.page-content .content p:last-of-type,
.page-content-image .content p:last-of-type,
.page-content-map .content p:last-of-type {
    margin: 0;
}

.page-content .content a,
.page-content-image .content a,
.page-content-map .content a {
    color: var(--back);
    text-decoration: underline;
}

.page-content .content a:hover,
.page-content-image .content a:hover,
.page-content-map .content a:hover {
    color: var(--orange);
    text-decoration: underline;
}

.page-content .content ul {
    font-size: 1rem;
    list-style: none;
    columns: 3;
    column-gap: 2em;
    padding: 0;
    margin: 2em 0;
}

.page-content .content ul > li {
    padding-bottom: 0.5em;
    break-inside: avoid-column;
}

.page-content .content ul > li::before {
    content: '\e800';
    display: inline-block;
    color: var(--aqua-deep);
    width: 1em;
    font-family: "stirka";
    font-style: normal;
    font-weight: normal;
    line-height: 1em;
    text-align: center;
    font-variant: normal;
    text-decoration: inherit;
    text-transform: none;
    speak: never;
    margin-right: .5em;
    margin-left: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* promotions & posts*/
.promotions,
.posts {
    
}

.promotions-list,
.posts-list {
    
}

.promotions .item,
.posts .item {
    display: block;
    height: 100%;
    border: 1px solid var(--grey);
    border-radius: var(--border-radius);
    overflow: hidden;
    -webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
    transition: all .2s ease;
}

.promotions .item:hover,
.posts .item:hover {
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1);
    border: 1px solid transparent;
}

.promotions .item .image-wrap,
.posts .item .image-wrap {
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--border-radius);
    aspect-ratio: 3 / 2;
    overflow: hidden;
}

.promotions .item .image-wrap img,
.posts .item .image-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    -webkit-transition: all .1s ease;
    -moz-transition: all .1s ease;
    transition: all .1s ease;
}

.promotions .item .text-wrap,
.posts .item .text-wrap {
    padding: 2rem;
}

.promotions .item .text-wrap .title,
.posts .item .text-wrap .title {
    display: inline-block;
    color: var(--black);
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 0.5em;
}

.promotions .item .text-wrap .caption,
.posts .item .text-wrap .caption {
    display: inline-block;
    color: var(--black);
    font-size: 1rem;
}

/* main map */
.main-map {
    overflow: unset;
}

.main-map .map-wrap {
    width: 100%;
    height: 720px;
    border-radius: var(--border-radius);
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

/* form contact */
.form-contact {
    background: linear-gradient(0deg, #e4843fF2 0%, #e4843fF2 100%),
                url(/vendor/img/form-contact-back.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: var(--border-radius);
    padding-top: 3.625rem;
    padding-bottom: 3.625rem;
    margin-bottom: 7.5rem;
}

.form-contact .title {
    color: var(--white);
    margin-bottom: 0.25em;
}

.form-contact .capt {
    display: block;
    color: var(--white);
    font-size: 1.125rem;
    margin-bottom: 2em;
}

.form-contact form .btn-prim {
    width: 100%;
}

.form-contact label {
    display: inline;
    color: var(--white);
    font-size: 0.875rem;
    font-weight: 300;
}

.form-contact label a {
    display: inline;
    color: var(--white);
    text-decoration: underline;
}

/* services & technologies cards */
.services .item,
.technologies .item,
.services-icons .item,
.technologies-icons .item {
    --padd: 0.5rem;
    --back: var(--white);
    display: block;
    height: 100%;
    background-color: var(--white);
    border-radius: var(--border-radius);
    border: 2px solid var(--grey);
    padding: var(--padd);
    overflow: hidden;
}

.services .item:hover,
.technologies .item:hover,
.services-icons .item:hover,
.technologies-icons .item:hover {
    border: 2px solid var(--orange);
}

.services .item .image-wrap,
.technologies .item .image-wrap,
.services-icons .item .image-wrap,
.technologies-icons .item .image-wrap {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    border-radius: calc( var(--border-radius) - var(--padd) );
    margin-bottom: 1rem;
    overflow: hidden;
}

.services .item .image-wrap img,
.technologies .item .image-wrap img,
.services-icons .item .image-wrap img,
.technologies-icons .item .image-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.services .item .hd,
.technologies .item .hd,
.services-icons .item .hd,
.technologies-icons .item .hd {
    display: block;
    width: 100%;
    color: var(--black);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.5;
    padding: 0 1rem calc(1rem - var(--padd));
    opacity: 0.8;
}

.services .item:hover .hd,
.technologies .item:hover .hd,
.services-icons .item:hover .hd,
.technologies-icons .item:hover .hd {
    opacity: 1;
}

/* services & technologies icons */
.services-icons,
.technologies-icons {
    background-color: var(--grey);
    border-radius: var(--border-radius);
    padding-top: 5rem;
    padding-bottom: 5rem;
    margin-bottom: 7.5rem;
}

/* objects */
.objects .item {
    --padd: 0.5rem;
    display: block;
    height: 100%;
    background-color: var(--grey);
    border: 2px solid var(--grey);
    border-radius: var(--border-radius);
    overflow: hidden;
}

.objects .item:hover,
.objects .item:focus {
    border: 2px solid var(--orange);
}

.objects .item .text-wrap {
    display: flex;
    flex-direction: column;
    padding: 2rem;
}

.objects .item .text-wrap .title {
    display: inline-block;
    color: var(--black);
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 1em;
}

.objects .item .text-wrap .tel,
.objects .item .text-wrap .address,
.objects .item .text-wrap .schedule {
    display: inline-block;
    color: var(--black);
    font-size: 1rem;
    margin-bottom: 0.125em;
}

.objects .item .text-wrap > span i {
    font-size: 1.125em;
    color: var(--aqua-deep);
}

.objects .item .image-wrap {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    padding: var(--padd);
    overflow: hidden;
}

.objects .item .image-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: calc( var(--border-radius) - var(--padd) );
}

/* express */
.objects.express .item {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
}

.objects.express .item .image-wrap {
    display: flex;
    width: 30%;
    height: auto;
    aspect-ratio: 1 !important;
    flex-shrink: 0;
    overflow: hidden;
}

.objects.express .item .text-wrap {
    justify-content: space-between;
    width: 100%;
    height: 100%;
    padding: 1rem;
}

.objects.express .item .text-wrap .address {
    font-weight: 500;
}

.objects.express .mrkt-wrap {
    display: flex;
    flex-direction: row;
    gap: 5px;
    justify-content: flex-end;
    -webkit-filter: grayscale(100%);
    -moz-filter: grayscale(100%);
    -o-filter: grayscale(100%);
    -ms-filter: grayscale(100%);
    filter: grayscale(100%);
    -webkit-transition: filter .2s ease;
	-moz-transition: filter .2s ease;
    transition: filter .2s ease;
}

.objects.express .item:hover .mrkt-wrap {
    -webkit-filter: grayscale(0%);
    -moz-filter: grayscale(0%);
    -o-filter: grayscale(0%);
    -ms-filter: grayscale(0%);
    filter: grayscale(0%);
}

.objects.express .mrkt-wrap img {
    display: block;
    width: 27px;
    height: 27px;
}

.objects .nav {
    gap: 1rem;
    margin-bottom: 2rem;
}


.objects .nav .nav-link {
    position: relative;
    color: var(--black);
    background-color: transparent;
    font-size: 1rem;
    font-weight: 500;
    border: none;
    border-radius: 0.5em;
    padding: 0.5em 1em;
}

.objects .nav .nav-link:hover {
    background-color: var(--grey);
}

.objects .nav .nav-link.active {
    background-color: var(--aqua);
}

/* price list search */
.price-search {
    
}

.price-search input[type="text"] {
    border: 2px solid var(--black);
    margin-bottom: 2rem;
}

.price-search .text {
    padding: 1rem 0;
}

.price-search .text p:last-of-type {
    margin: 0;
}

.price-search .price-cat-item {
    display: none;
    padding-bottom: 2rem;
}

.price-search .price-cat-item.show {
    display: block;
}

.price-search .price-cat-item h2 {
    font-size: 1.625rem;
}

.price-search .price-list {
    display: flex;
    flex-direction: column;
    row-gap: 1rem;
}

.price-search .price-list .price-item {
    display: none;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    gap: 2rem;
    background-color: var(--grey);
    border-radius: var(--border-radius);
    padding: 1rem 2rem;
    overflow: hidden;
}

.price-search .price-list .price-item.show {
    display: flex;
}

.price-search .price-list .price-item .name {
    
}

.price-search .price-list .price-item .price {
    flex-shrink: 0;
}

.price-search #no-results {
    display: none;
    color: red;
}

/* corporative customers */
.corp-customers {
    background: var(--grey);
    border-radius: var(--border-radius);
    padding-top: 5rem;
    padding-bottom: 5rem;
    margin-bottom: 10rem;
}

.corp-customers .corp-customers-list {
    
}

.corp-customers .corp-customers-list .item {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    border-radius: var(--border-radius);
    overflow: hidden;
}

.corp-customers .corp-customers-list .item img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
}

/* banner */
.banner {
    padding-top: 1rem;
}

.banner .img-wrap {
    display: block;
    border-radius: var(--border-radius);
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.banner .img-wrap img {
    display: block;
    width: 100%;
    height: 100%;
}

/* footer */
.site-footer {
    display: block;
    background-color: var(--grey);
    border-radius: var(--border-radius) var(--border-radius) 0 0;
    padding: 2rem 0 1rem;
    margin: 0 var(--container-padding);
}

.site-footer .links {
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    column-gap: 2rem;
    row-gap: 0.5rem;
    list-style: none;
    margin: 0 0 1rem;
    padding: 0 0 1rem;
}

.site-footer .links:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    width: 100%;
    height: 2px;
    background-color: #fff;
    border-top: 1px solid #ccc;
    opacity: 0.5;
}

.site-footer .links li {
    margin: 0;
    padding: 0;
}

.site-footer .links li a {
    color: var(--black);
    opacity: 0.8;
}

.site-footer .links li a:hover {
    opacity: 1;
}

.site-footer .copyright {
    font-size: 0.875rem;
    opacity: 0.8;
}

.site-footer .copyright p {
    margin: 0;
}

/* modal form */
.modal .modal-cst {
    max-width: 720px;
}

.modal .modal-cst .modal-content {
    position: relative;
    border: none;
    border-radius: var(--border-radius);
    padding: 3rem;
}

.modal .modal-cst .btn-close {
    position: absolute;
    right: 0;
    top: 0;
    color: var(--aqua);
    font-size: 1rem;
}

.modal .modal-cst .modal-title {
    display: block;
    color: var(--orange);
    font-size: 3rem;
    font-weight: 400;
    text-transform: uppercase;
    margin-bottom: 0.5em;
}

.modal .modal-cst .modal-text {
    display: inline-block;
    color: var(--black);
    font-size: 1.25rem;
    font-weight: 300;
    border-top: 1px solid var(--aqua);
    border-bottom: 1px solid var(--aqua);
    padding: 1em 0;
    margin-bottom: 2em;
}

.modal .modal-cst form label {
    display: inline;
    color: var(--black);
    font-size: 0.875rem;
}

.modal .modal-cst form label a {
    display: inline;
    color: var(--black);
    text-decoration: underline;
}

.modal .modal-cst .btn-prim {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1rem;
}

.modal-open .container {
    -webkit-filter: blur(5px);
    -moz-filter: blur(5px);
    -o-filter: blur(5px);
    -ms-filter: blur(5px);
    filter: blur(5px);
}

/* animations */
.lazyload {
    opacity: 0;
    transform: translateY(30px);
    -webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
    transition: all .2s ease;
}

.lazyload.doit {
    opacity: 1;
    transform: translateY(0);
}

.appear-top {
    opacity: 0;
    transform: translateY(50%);
    -webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
    transition: all .2s ease;
}

.appear-top.doit {
    opacity: 1;
    transform: translateY(0);
}

.appear-left {
    opacity: 0;
    transform: translateX(50%);
    -webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
    transition: all .2s ease;
}

.appear-left.doit {
    opacity: 1;
    transform: translateX(0);
}


@media (max-width: 1399.98px) {
    .navbar .cont-wrap {
        display: none;
    }
}

@media (max-width: 1199.98px) {

}

@media (max-width: 991.98px) {
    .navbar {
        min-height: unset;
        padding: 10px 0!important;
    }
    .slider .slider-list {
        border-radius: 0;
    }
    .slider .slider-list .item {
        aspect-ratio: 3 / 2;
    }
    .slider .slider-list .item .slider-title {
        font-size: 2.5rem;
    }
    .slider .slider-list .item.cropped .caption {
        width: 100%;
    }
    .slider .slider-list .item.cropped .caption .slider-text {
        font-size: 1rem;
    }
    .slider .slider-list .item.cropped .slider-image {
        display: none;
    }
    .slider .slider-list .item.full .caption {
        width: 100%;
        padding: 2.5rem 5rem;
        margin: 0;
    }
    .slider .slider-list .item.full .caption .slider-text {
        font-size: 1rem;
    }
    .navbar .navbar-nav {
        margin: 1rem 0 0;
    }
    .navbar .navbar-nav .nav-link {
        text-align: center;
    }
    .seo .content {
        column-count: unset;
    }
    section,
    .site-footer .bottom {
        border-radius: 0!important;
        margin-left: 0!important;
        margin-right: 0!important;
    }
    .page-content .content ul {
        columns: 2;
    }
    .site-footer {
        border-radius: 0;
        margin: 0;
    }
    .site-footer .links {
        flex-direction: column;
    }
}

@media (max-width: 767.98px) {
    h1,
    .page-title .title,
    section .title {
        font-size: 1.75rem;
    }
    
    h2 {
        font-size: 1.5rem;
    }
    
    h3 {
        font-size: 1.25rem;
    }
    
    h4 {
        font-size: 1rem;
    }
    .breadcrumb-page {
        padding: 1rem 0;
    }
    .page-content .content ul {
        columns: 1;
    }
    .site-footer .bottom .links {
        flex-direction: column;
    }
}
