


html {
	overflow-x:hidden;
}
.wrapper {
	width:100%;
	margin:0 auto;
	overflow-x:hidden;
	overflow-y:hidden;
	position:relative;
}
body {
	font-size:16px;
	color:#000000;
	font-family: 'Manrope';
    font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}
img {
	max-width:100%;
	height:auto;
}
.geologica-extralight {
  font-family: "Geologica", sans-serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal;
  font-variation-settings:
    "slnt" 0,
    "CRSV" 0,
    "SHRP" 0;
}
.geologica-medium {
  font-family: "Geologica", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-variation-settings:
    "slnt" 0,
    "CRSV" 0,
    "SHRP" 0;
}
.geologica-bold {
  font-family: "Geologica", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-variation-settings:
    "slnt" 0,
    "CRSV" 0,
    "SHRP" 0;
}

.manrope-regular {
  font-family: "Manrope", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.manrope-medium {
  font-family: "Manrope", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.manrope-semibold {
  font-family: "Manrope", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}
.manrope-bold {
  font-family: "Manrope", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.text-blue {
	color:#243e71;
}

h1, .h1 {
	font-family: "Geologica", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-variation-settings:
		"slnt" 0,
		"CRSV" 0,
		"SHRP" 0;
	font-size:80px;
}
h2, .h2 {
	font-family: "Geologica", sans-serif;
	font-optical-sizing: auto;
	font-weight: 500;
	font-style: normal;
	font-variation-settings:
		"slnt" 0,
		"CRSV" 0,
		"SHRP" 0;
	font-size:40px;
	margin-bottom:30px;
}
.btn-transparent, .navbar-lang .lang-swich {
	padding:10px 20px;
	font-weight: 600;
	font-size:16px;
	color:#243e71;
	border:1px solid #243e71;
	border-radius:10px;
	background:transparent;
	transition: all 0.3s ease;
}
.btn-transparent:hover, .navbar-lang .lang-swich:hover, .navbar-lang .lang-swich.active {
	color:#ffffff;
	background-color:#243e71;
}
.navbar-nav a {
	font-family: "Geologica", sans-serif;
	font-optical-sizing: auto;
	font-weight: 200;
	font-style: normal;
	font-variation-settings:
		"slnt" 0,
		"CRSV" 0,
		"SHRP" 0;
}
.navbar-nav a.active, .navbar-nav a:hover {
	text-decoration:underline !important;
	color:#243E71 !important;
}
.navbar-lang .lang-swich {
	padding:10px;
	text-decoration:none;
}


.banner-section {
	background:url(../img/banner-img.jpg) top center no-repeat;
	background-size:cover;
	background-attachment: fixed;
	height:750px;
	color:#ffffff;
	padding-top:200px;
}
.slogan-banner {
	font-size:24px;
	margin-top:15px;
}
.banner-next {
	margin-top:130px;
}
.banner-next a {
	color:#ffffff;
	font-size:14px;
	text-decoration:none;
}
.banner-next a svg {
	margin-top:5px;
}


.about-us-section {
	padding:80px 0 70px;
}

.why-choose-section {
	padding:50px 0 100px;
	color:#ffffff;
	background-color:#112750;
}
.why-choose-block {
	margin-bottom:50px;
	max-width:586px;
}
.why-choose-img {
	min-width:100px;
	height:100px;
	margin-right:30px;
}
.why-choose-title {
	font-size:24px;
	margin-bottom:8px;
}








/* slider */


.objects-slide-section {
    background-color: #F4F6FA;
    padding: 60px 0 105px;
    overflow-x: hidden;
}

/* --- СТИЛІ КАРТКИ (без змін) --- */
.custom-card {
    background: white;
    border: 1px solid #eef0f3;
    border-radius: 16px;
    padding: 2rem;
    height: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    width: 380px;
    display: flex;
    flex-direction: column;
}

.custom-card:hover {
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    transform: translateY(-5px);
}

.card-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 1.5rem;
    color: #3b5998;
}

.card-title {
    color: #2c3e50;
    font-weight: 600;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.card-text {
    color: #6c757d;
    font-size: 0.95rem;
    line-height: 1.6;
    flex-grow: 1;
    margin-bottom: 1.5rem;
}

.card-link {
    text-decoration: none;
    color: #3b5998;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: gap 0.2s;
}

.card-link:hover {
    gap: 12px;
}

/* --- СЛАЙДЕР ТА МАСКА --- */
.overflow-slider-section {
    position: relative; /* Важливо для позиціювання маски */
	padding-top:50px;
}

.slider-nav-buttons {
    display: flex;
    gap: 15px;
    margin-bottom: 30px;
}

.swiper-btn-prev, .swiper-btn-next {
    cursor: pointer;
    width: 40px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.3s;
}
.swiper-btn-prev svg path, .swiper-btn-next svg path {
	fill:#2357BE;
}
.swiper-btn-prev:hover svg path, .swiper-btn-next:hover svg path {
	fill:#8E90B2;
}

/* Налаштування Swiper */
.swiper-container-left {
    width: 100%;
    /* Задаємо паддінг, щоб активний слайд починався там де треба */
    padding-left: 0.75rem; 
    padding-right: 0.75rem;
}

.swiper-slide {
    width: auto;
    height: auto;
}

/* --- ЛОГІКА МАСКИ (ШТОРКИ) --- */
/* Цей блок перекриває слайди, що йдуть у "петлю" зліва */
.slider-left-mask {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background-color: #F4F6FA; /* Колір фону сайту */
    z-index: 10; /* Поверх слайдера */
    width: 0px; /* За замовчуванням на мобільному */
    pointer-events: none; /* Щоб крізь неї можна було скролити, якщо треба */
}

/* Медіа-запити: Синхронізуємо ширину маски та padding слайдера */

@media (min-width: 576px) {
    .swiper-container-left { padding-left: calc((100vw - 540px) / 2 + 0.75rem); }
    .slider-left-mask { width: calc((100vw - 540px) / 2 + 0.75rem); }
}
@media (min-width: 768px) {
    .swiper-container-left { padding-left: calc((100vw - 720px) / 2 + 0.75rem); }
    .slider-left-mask { width: calc((100vw - 720px) / 2 + 0.75rem); }
}
@media (min-width: 992px) {
    .swiper-container-left { padding-left: calc((100vw - 960px) / 2 + 0.75rem); }
    .slider-left-mask { width: calc((100vw - 960px) / 2 + 0.75rem); }
}
@media (min-width: 1200px) {
    .swiper-container-left { padding-left: calc((100vw - 1140px) / 2 + 0.75rem); }
    .slider-left-mask { width: calc((100vw - 1140px) / 2 + 0.75rem); }
}
@media (min-width: 1400px) {
    .swiper-container-left { padding-left: calc((100vw - 1320px) / 2 + 0.75rem); }
    .slider-left-mask { width: calc((100vw - 1320px) / 2 + 0.75rem); }
}

.how-it-work-section {
	padding:150px 0 160px;
}


.stats-section {
    position: relative;
    background-image: url('../img/count-section-bg.jpg');
    background-size: cover;
    background-position: center;
    background-attachment: fixed; /* Паралакс ефект (за бажанням) */
    color: white;
    padding: 150px 0;
    overflow: hidden;
}




/* --- СТИЛІ ЛІЧИЛЬНИКІВ --- */
.stat-item {
    text-align: center;
    position: relative;
    padding: 20px 0;
}

.stat-number {
    font-size: 96px; 
    font-weight: 700;
    line-height: 1;
    margin-bottom: 15px;
    display: inline-block;
    color: #ffffff;
}

/* Символ "+" або інші суфікси */
.stat-symbol {
    font-size: 96px;
    font-weight: 700;
    vertical-align: top;
	line-height: 1;
}

.stat-label {
    color:#ffffff; 
    font-weight: 400;
    max-width: 200px;
    margin: 0 auto;
}



.articles-slider-section {
	padding:140px 0;
}

/* -- СЛАЙДЕР НОВИН --*/
/* --- НАВІГАЦІЯ --- */
.slider-header {
    display: flex;
    align-items: center;
    justify-content: flex-start; /* Стрілки зліва, як на макеті */
    gap: 20px;
    margin-bottom: 30px;
}

.swiper-btn-prev, .swiper-btn-next {
    cursor: pointer;
    width: 40px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.3s;
}

.swiper-btn-prev:hover, .swiper-btn-next:hover {
    opacity: 0.7;
}

/* --- КАРТКА НОВИНИ --- */
.news-card {
    background: #fff;
    border: 1px solid #eaecf0;
    border-radius: 12px;
    overflow: hidden; /* Щоб картинка не вилазила за радіус */
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s, box-shadow 0.3s;
}

.news-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 24px -10px rgba(0, 0, 0, 0.1);
}

.card-img-wrapper {
    padding: 30px 30px 0 30px; /* Відступ картинки всередині картки (якщо треба) */
}

.news-img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    border-radius: 10px; /* Закруглення самої картинки */
}

.card-body {
    padding: 30px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.news-title {
    font-size: 20px;
    font-weight: 600;
    color: #243E71;
    margin-bottom: 12px;
}

.news-date {
    margin-bottom: 12px;
}

.news-text {
    margin-bottom: 12px;
    flex-grow: 1; /* Текст займає вільний простір, притискаючи кнопку вниз */
}

.read-more {
    text-decoration: none;
    color: #2357BE;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: gap 0.2s;
}
.read-more:hover {
    gap: 10px;
}

.swiper-slide {
    height: auto; 
}

/* --- ГОЛОВНА СЕКЦІЯ --- */
.contacts-section {
    overflow-x: hidden;
}
.contacts-text {
	font-size:20px;
}

/* Таблиця контактів (Flexbox row) */
.contact-info-list {
	margin:45px auto 70px;
}
.contact-row {
    display: flex;
    margin-bottom: 10px;
	justify-content: space-between;
}
.contact-label {
    width: 220px; 
    color: #243e71;
    font-weight: 600;
    flex-shrink: 0;
}


/* --- ПРАВА ЧАСТИНА (ФОРМА З ФОНОМ) --- */
.form-wrapper {
    position: relative;
    padding: 70px 140px; 
    height: 100%;
}
.form-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100vw; 
    background-color: #f2f5fa; 
    border-top-left-radius: 50px; 
    z-index: -1; 
}
.form-title {
    font-size: 24px;
}
.form-control {
    border: 1px solid #C9CDD8;
    border-radius: 10px;
    padding: 10px 20x;
    margin-bottom: 12px;
    width: 100%;
    outline: none;
    transition: border-color 0.2s;
}
.form-control:focus {
    border-color: #243e71;
    box-shadow: 0 0 0 3px rgba(36, 62, 113, 0.1);
}
.btn-submit {
    background-color: #243e71;
    color:#ffffff;
    width: 100%;
    padding: 10px 20px;
    border-radius: 10px;
    font-weight: 600;
    border:1px solid #243e71;
    transition: all 0.3s ease;
}
.btn-submit:hover {
    background-color: #ffffff;
	color:#243e71;
	border:1px solid #243e71;
}

/* Адаптивність для мобільних */
@media (max-width: 991px) {
    .form-wrapper {
        padding: 40px 20px;
        margin-top: 40px;
    }
    /* На мобільному прибираємо скруглення або робимо його меншим, якщо треба */
    .form-wrapper::before {
        border-top-left-radius: 20px;
        border-top-right-radius: 20px; /* На мобільному краще симетрично */
        left: 50%;
        transform: translateX(-50%); /* Центруємо фон */
    }
}

.footer-section {
	background-color:#202F4B;
	padding:31px 0;
	color:#ffffff;
}
.footer-top {
	padding-bottom:60px;
}
.menu-footer li {
	margin-bottom:10px;
}
.menu-footer a, a.politics {
	color:#ffffff;
	text-decoration:none;
}
.menu-footer a.active {
	font-weight:600;
}
.menu-footer a:hover, a.politics:hover {
	color:#ffffff;
	text-decoration:underline;
}
.address-footer p {
	margin-bottom:10px;
}
.footer-bottom {
	border-top:1px solid #ffffff;
	padding-top:22px;
}