@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  font-weight: 100 700; /* Variable font weight range */
  src: url('/assets/css/material-symbols-outlined-latin-400-normal.ttf') format('truetype');
}

@font-face {
  font-family: 'exo2';
  src: url('/assets/css/exo2.ttf') format('truetype');
}

h1, h2, h3 { font-family: 'exo2', sans-serif; font-weight: bold; }
h1 { padding-bottom: 15px; }
body { overflow-x: hidden; }

.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;      /* Default icon size */
  display: inline-block;
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;

  /* Support for all WebKit browsers */
  -webkit-font-smoothing: antialiased;
  /* Support for Safari and Chrome */
  text-rendering: optimizeLegibility;
  /* Support for Firefox */
  -moz-osx-font-smoothing: grayscale;
  /* Support for IE */
  font-feature-settings: 'liga';
}

@font-face {
  font-family: 'nokiakokia';
  src: url('/assets/css/nokiakokia(rys-by-lyajka).ttf') format('truetype');
}

.row-bg { position: relative; overflow: visible; width: 100%; height: 100%; }
.row-bg::before {
  content: "";
  position: absolute;
  top: -200px; 
  left: -350px;
  width: calc(100% + 700px); 
  height: calc(100% + 400px);
  background-image: url('/assets/img/main-bg-top2.png');
  background-size: cover;
  z-index: -20; /* Keep image behind parent content */
}

.img-20 { position: relative; overflow: visible; }
.img-20::before {
    content: "";
    position: absolute;
    top: 25px; 
    left: 0px;
    width: 100%;
    height: 100%;
    background-image: url('/assets/img/ellipse.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: left bottom;
    z-index: -10; /* Keep image behind parent content */
} 

.fwidth_1 { position: absolute; height: 100%; background-color: #eeeff3; box-shadow: 0 0 0 100vmax #eeeff3; clip-path: inset(0 -100vmax); z-index: -30;}


#breadcrumb { list-style: none; padding: 0; margin: 0; }
#breadcrumb a { color: #464747; text-decoration: none; }
#breadcrumb a::after {
  content: "";
  position: absolute;
  right: 16px; /* Adjust based on size */
  top: 40%;
  transform: translateY(-50%);
  /* Triangle logic: set side borders to transparent */
  border: solid #464747;
  border-width: 0 2px 2px 0;
  display: inline-block;
  padding: 2px;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}

#breadcrumb li { display: inline; padding-right: 38px; position: relative;  display: inline-block; }
#breadcrumb li:not(:has(a)) {  color: #464747; opacity: 0.7;}

.page-404 { font-size: 60px; }

a { text-decoration: none; }
.container-fluid { max-width: 1400px; }
.header { background: white; }
.header-wrap { box-shadow: 0px 20px 11px -10px rgba(182, 182, 182, 0.2); height: 62px;}
.fancybox__caption { text-align: center; padding: 15px 40px 15px 40px !important;}
.text-info { color: #464747 !important; opacity: 0.5; }

.btn { position: relative; padding: 12px 17px 12px 17px; font-weight: normal !important; font-size: 16px; line-height: 100%; letter-spacing: 0%; text-align: center; text-transform: uppercase; }
.btn:hover { opacity: 0.9; }
.btn>span { position: absolute; top: 8px; right: 10px; }
.btn:has(span) { padding-right: 40px; }
.btn-info { bodrer: 0px !important; border-radius: 7px; width: max-content; background: linear-gradient(90deg, #0070B2 0%, #00A0B2 100%); box-shadow: 0px 14px 9px -10px #0187B280; }
.btn-info-reverse { color: white !important; border: 0px !important; background: linear-gradient(90deg, #E6711E 0%, #E6BA28 100%); box-shadow: 0px 19px 14px -10px #E88E2280; }


.btn-info-reverse:hover { background-color: #065e8d !important; color: white !important; } 

header .title { font-size: 18px; }
header .title a { color: #0070B2; text-decoration: none; font-family: 'nokiakokia', sans-serif; }
header .title a span { color: black; }
header .sub_t1  { font-size: 13px; color: #464747; text-transform: uppercase; letter-spacing: 32%; opacity: 0.9; }
header .sub_t2  { font-size: 13px; color: #464747; }
header .menu1 { position: relative;  } 
header .navbar-nav { display: block; }
header .menu1 nav>ul>li { display: inline-block; float: left; padding: 5px 0px 0px 0px; margin-right: 35px; text-transform: uppercase; } 
header .menu1 nav li.active>a { border-bottom: 2px solid; border-image: linear-gradient(to right, #E6711E, #E6BA28) 1;  } 

header .menu1 nav a { color: #464747; font-weight: bold; } 

.header-row { max-width: 1360px; } 
main { margin-top: 215px; }
.main_page { margin-top: 150px; }
.model-row h3 { font-size: 18px; color: #464747; text-transform: uppercase; letter-spacing: 4px; }
.mmt { font-size: 15px; }
.mmt img { max-width: 190px; }
.mmt a { color: black; text-decoration: none;  font-family: 'nokiakokia', sans-serif; }

a.serv1_card1 { background-color: white; border-radius: 10px; font-size: 18px; text-decoration: none; color: #464747; font-weight: bold; text-transform: uppercase; height: 190px; }
a.serv1_card1:hover { color: #065e8d; box-shadow: 0px 8px 14px 0px rgba(34, 60, 80, 0.2); }
a.serv1_card2 { background: linear-gradient(90deg, #0070B2 0%, #00A0B2 100%); border-radius: 10px; font-size: 18px; text-decoration: none; color: white; font-weight: bold; text-transform: uppercase; min-height: 180px; }
a.serv1_card2:hover { opacity: 0.8; }
.servp a.serv1_card1 { background-color: white; color: white; border: 1px solid #065e8d; color: black; }

.offer .card1 { color: black; border-radius: 10px; height: 280px; padding: 35px; position: relative; overflow: hidden;  }
.offer .card1 .material-symbols-outlined { font-size: 11px; color: orange; } 
.offer .card1 .l2 { position: absolute; bottom: 20px; right: -40px; transform: rotate(-43deg); font-size: 140px; color: white; z-index: -1; font-weight: bold; }
.offer .card1::before { content: ""; position: absolute; top: -80px; left: -80px; width: 150%; height: 150%; background-image: url('/assets/img/bg-special-offer.jpg');
  background-size: contain;
  z-index: -1; /* Places image behind content */
  transform: rotate(-23deg); /* Desired rotation */
}

.promo_t { font-size: 40px; font-weight: bold; line-height: 42px; }
.promo_r { background-color: white; font-size: 19px; font-weight: bold; border-radius: 8px; padding: 20px 25px 20px 78px; position: relative; margin-top: 17px; }
.promo_r img { max-height: 35px; position: absolute; left: 20px; top: 18px; }
.promo_c {
    color: white;
    padding: 40px 140px 40px 50px;
    border-radius: 8px;
  background-image: 
    url('/assets/img/bg-master.png'),
    linear-gradient(to right, rgba(0, 112, 178, 1), rgba(0, 160, 178, 1));
    background-size: contain;
    background-position: right;
    background-repeat: no-repeat;
}

.promo_c .pct { text-transform: uppercase; font-size: 30px; font-weight: bold;  line-height: 31px; }
.promo_c .pcb { font-size: 18px; padding: 25px 0 25px 0; line-height: 25px; }

.offer .card1:hover { box-shadow: 0px 8px 14px 0px rgba(34, 60, 80, 0.2); }
.offer .card1 .intro { background-color: white; color: black; border-radius: 10px; width: fit-content; padding: 2px 10px; text-transform: uppercase; font-weight: bold; }
.offer .card1 .title { font-size: 29px; font-weight: bold; padding: 15px 0; }
.offer .card1 a { color: #065e8d; text-decoration: none;}
.offer .card1 a:hover { color: white; }
.offer .card1.cnt2 { background-color: #e2dfde; color: black; border: 1px solid #f3f3f3; }
.offer .card1.cnt2 .intro { background-color: #065e8d; color: white; }
.offer .card1.cnt3 { background-color: #f3f3f3; color: black; border: 1px solid #f3f3f3; }
.offer .card1.cnt3 .intro { background-color: black; color: white; }

.tprice li a.nav-link { display: block; font-size: 12px; color: black; margin: 0 20px 20px 0px; text-transform: uppercase; font-family: 'nokiakokia', sans-serif; } 
.tprice li a.nav-link:hover { border-bottom: 2px solid; border-image: linear-gradient(to right, #E6711E, #E6BA28) 1; } 
.tprice li a.nav-link.active { border-bottom: 2px solid; border-image: linear-gradient(to right, #E6711E, #E6BA28) 1; } 


.tprice tr td { padding: 20px; font-size: 20px; font-weight: bold; }
.tprice tr td:nth-child(1) { color: #d5d8de; }  

.addr-card { position: relative; max-width: 260px; padding: 8px 5px 8px 25px; display: inline-block; float: left; }
.addr-card { margin-left: 25px; }
.addr-card>span:nth-child(1) { position: absolute; left: 0px; top: 12px; font-size: 22px; }
.addr-card>span:nth-child(2) { position: absolute; left: 0px; top: 48px; font-size: 16px; }
.addr-card a {text-decoration: none;}
.addr-card a .c_region { font-size: 19px; color: black; font-weight: bold; }
.addr-card a .c_address { font-size: 14px; color: #464747; margin-top: -5px; letter-spacing: -0.2px; }
.addr-card a.c_phone { font-size: 13px; color: black; font-weight: bold; }

.addr_list>div:nth-child(2n+1) { padding-bottom: 15px; } 
.addr_list>div:nth-child(2n) { padding-top: 15px; } 
.addr-card2 { position: relative; width: 100%; height: 100%; }
.addr-card2 span { margin: 0 10px 0 0; }
.addr-card2 .material-symbols-outlined { font-size: 20px; }
.addr-card2 a {text-decoration: none;}
.addr-card2 .c_region a { font-size: 26px; color: black; font-weight: bold; }
.addr-card2 .c_region>div { margin: -10px 0px 5px 0px; }
.addr-card2 .c_region>div a { font-size: 20px; color: #464747; font-weight: normal; padding-left: 35px; }
.addr-card2 .c_address a { font-size: 20px; color: #464747; padding-left: 5px; }
.addr-card2 .c_phone a { font-size: 22px; color: #464747; padding-left: 5px; }
.border-info { border-color: #eaeaea !important; }

.footer .ftit1 { font-size: 16px; color: #464747; font-family: 'nokiakokia', sans-serif; }
.footer .ftit2 { font-size: 13px; color: #464747; text-transform: uppercase; letter-spacing: 3px; }
.footer .ftit3 { font-size: 12px; color: #464747; }

.main_title .mt1{ font-size: 70px; font-family: 'nokiakokia', sans-serif; line-height: 1; position: relative; z-index: 10; }
.main_title .mt1 span {  background-image: linear-gradient(to right, #0070B2, #00A0B2); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;  color: transparent; }
.main_title .mt2{ font-size: 24px; margin-top: 25px; display: block; }
.great3>span { color: #065e8d !important; }
.great1 { font-size: 19px; border: 1px solid #46474720; border-radius: 3px; }
.great1 span { font-size: 64px; color: #0070B2; padding: 10px; }
.main_title.to_page .mt1{ font-size: 40px; }

.big_map { position: relative; }
.big_map .map { border-radius: 20px; overflow: hidden; }

.dropdown { position: relative; }
.dropdown-menu  { display: none; }
.dropdown-menu:hover { display: block; }
.dropdown-menu1:hover .dropdown-menu { display: block; }
.dropdown-menu1:hover .dropdown-menu a { display: block; padding: 5px 10px; }
.dropdown-menu1:hover>.dropdown-menu { position: absolute; top: 40px; left: 0px; background: white; border: 1px solid #1a1c1c; border-radius: 5px; }

.dropdown-menu2 .dropdown-menu  { font-size: 12px; border: 0px; padding: 0px !important; }
.dropdown-menu2 .dropdown-menu a { display: block; padding: 0px 10px 0px 20px !important; margin: 0 0 5px 0;}


.feedback-blk { border: 1px solid #eeeff3; border-radius: 4px !important; padding: 25px 15px 0px 25px; height: 250px; height: var(--f-carousel-slide-height) !important; width: 48.8%; max-width: unset !important;}
.f-carousel__dots { bottom: calc(var(--f-carousel-dots-height) * -1.5) !important; }
.f-carousel__dot { color: #0070B2; }
.feedback-blk .fline >div { display: inline-block; float: left; text-align: left; }
.feedback-blk .fline .fl_circle { display: block; width: 70px; height: 70px; border-radius: 35px; background-color: #eeeff3; }
.feedback-blk .fline .fl_blk { margin-left: 25px; }
.feedback-blk .fline .fb_title { font-weight: bold; }
.feedback-blk .fline .fb_c { font-size: 12px; }
.feedback-blk .fline .fbs_d { margin-left: 115px; }
.feedback-blk .sline { display: inline-block; margin: 25px 0px; text-align: left; }
.star_row { position: relative; }
.star_row .fbs_grey { position: absolute; left: 0px; top: 5px; width: 100px; height: 15px; background-image: url(/assets/img/zvezda-32-grey.png); background-size: 20px; }
.star_row .fbs { position: absolute; left: 0px; top: 5px; width: calc(var(--feedback_stars) * 20px); height: 15px; background-image: url(/assets/img/zvezda-32-gold.png); background-size: 20px; }


.mobile-menu .dropdown-menu { padding: 0 20px; }
.mobile-menu .level2 { display: block; }

.f-html { max-width: 800px; position: relative; border-radius: 5px; }
.f-html .is-close-button { position: absolute; right: -30px; top: 0px; }
.assign-chk { float: left; box-sizing: border-box; padding: 0; }

.qa-block { border: 0px; border-top: 1px solid #EEF1F5; border-bottom: 1px solid #EEF1F5; border-radius: 0px;  padding-left: 0px !important; padding: 20px 0px !important; } 
.qa-block a { text-decoration: none; color: black; font-weight: bold;}
.qa-block:has(>div.answer.show) .down { transform: rotate(-135deg); -webkit-transform: rotate(-135deg); top: 30px; }
.card-body { position: relative; }
.card-body .qwes { position: absolute; left: 12px; top: 8px; font-size: 25px; }
.card-body i { position: absolute; right: 15px; top: 26px; border: solid black; border-width: 0 3px 3px 0; display: inline-block; padding: 3px; width: 6px; transform: rotate(45deg); -webkit-transform: rotate(45deg);}

.fb-carousel .f-carousel__slide { height: 300px; max-width: 480px; margin: 0 30px 0 0; border-radius: 20px; background-size: cover; background-position: center; background-repeat: no-repeat; }
.fb-carousel .f-button.is-prev, .fb-carousel-feedback .f-button.is-prev:hover {
    background: white;
    top: unset !important;
    bottom: 310px;
    border-radius: 5px;
    left: calc(100% - 100px) !important;
    color: black;
    border: 1px solid #EEF1F5;
}

.fb-carousel .f-button.is-next, .fb-carousel-feedback .f-button.is-next:hover {
    background: #EEF1F5;
    top: unset !important;
    bottom: 310px;
    border-radius: 5px;
    right: 0px !important;
    color: black;
    border: 1px solid #EEF1F5;
}

#spinner{ display: inline-block; visibility: hidden; width: 20px; height: 20px; border: 2px solid #f3f3f3; border-top:3px solid #f25a41; border-radius: 100%; animation: spin 1s infinite linear; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg);  } }
#spinner.show { visibility: visible; }

.writen-block2 input[type=text], .writen-block2 input[type=date], .writen-block2 select, .writen-block2 textarea {
    border: 1px solid light-dark(rgb(118, 118, 118), rgb(133, 133, 133));
    width: 100%;
    font-size: x-large;
    height: unset;
    min-height: 60px;
    padding: 10px;
    border-radius: 4px;
}
.writen-block2 .but-subs { border: 1px solid light-dark(rgb(118, 118, 118), rgb(133, 133, 133)); padding: 11px; border-radius: 5px; font-weight: bold; width: 100%; font-size: x-large; }

.addr_par .sqo { border: 1px solid #eeeff3; border-radius: 4px; text-align: center; padding: 20px; height: 165px; }
.addr_par .sqo img { height: 35px; margin: 10px; } 


@media (max-width: 992px) {
    .feedback-blk {  width: 99%; }
    .feedback-blk .fline .fbs_d { display: block; padding-top: 20px; margin-left: 0px; }
    h1 { padding-bottom: 10px; font-size: 2rem;}
    .mobile-menu { border-bottom: 1px solid #eaeaea; }
    main { margin-top: 72px !important; }
    .addr-card2 .c_region a { font-size: 15px; }
    .addr-card2 .c_address a { font-size: 17px; }
    .big_map iframe { max-height: 300px; } 
    .logo a { font-size: 14px; text-decoration: none; color: black; font-family: 'nokiakokia', sans-serif; color: #0070B2; }
    .logo a span { color: black; }
    #main_nav { position: fixed; top: 65px; left: 0px; width: 100%; background-color: white; padding: 0px 40px 20px; border-bottom: 1px solid #eaeaea; box-shadow: 0 5px 15px 0 rgba(0, 0, 0, 0.2); }
    .main_title { font-size: 30px; }
    .fb-carousel .f-carousel__slide { height: 220px; max-width: 340px; margin: 0 30px 0 0; border-radius: 15px; }
    .fb-carousel .f-button.is-prev, .fb-carousel-feedback .f-button.is-prev:hover { bottom: 220px; }
    .fb-carousel .f-button.is-next, .fb-carousel-feedback .f-button.is-next:hover { bottom: 220px; }
    .writen-block2 input[type=text], .writen-block2 input[type=date], .writen-block2 select, .writen-block2 textarea { min-height: 35px; padding: 3px; }
    .writen-block2 h1 { font-size: 30px; } 
    .f-html .is-close-button { right: 3px; top: 5px; color: black; }
    
    .tprice li a.nav-link { margin: 0 10px 10px 10px; } 
    .tprice tr td { padding: 5px; font-size: 14px; font-weight: bold; }
    .tprice tr td:nth-child(1) { display: none; } 
    .main_title .mt1 { font-size: 30px; }
    .main_title .mt1>span { margin-top: -20px; }
    .main_title.to_page .mt1 { font-size: 22px; }
    .row-bg::before { top: 0px; left: -50px; width: calc(100% + 100px); height: 120%; }
    .mmt img { max-width: 160px; }
    .addr-card2 .c_region>div a { font-size: 14px; }
    .container-fluid { overflow-x: hidden; }
    .promo_t { font-size: 26px; text-align: center; line-height: 34px; }
    .promo_r { font-size: 17px; }
    .promo_c { padding: 10px 65px 20px 20px; }
    .promo_c .pct { font-size: 21px; line-height: 23px; }
    .promo_c .pcb { font-size: 13px; padding: 10px 0 15px 0; line-height: 20px; }
    .addr-card { margin-left: 0px; }
}
    