@import url("../bootstrap/bootstrap.min.css");
@import url("../jquery/jquery-ui/jquery-ui.css");
@import url("../owlcarousel/owl.carousel.min.css");
@import url("../fancybox/jquery.fancybox.min.css");
/*
* ----------------------------------------------------------------------------------------
* Fonts
* ----------------------------------------------------------------------------------------
*/
@import url("../fonts/fontawesome-free-6.7.2-web/css/all.min.css");
@import url("../fonts/bootstrap-icons-1.11.3/font/bootstrap-icons.min.css");
/*
* ----------------------------------------------------------------------------------------
* General
* ----------------------------------------------------------------------------------------
*/
*, *::before, *::after {
	box-sizing: border-box;
}
body {
	font-size: 1rem;
	font-weight: 400;
	font-family: "Inter", "Roboto", sans-serif;
	color: var(--bs-dark);
	line-height: 1.5;
	margin: 0;
}
html {
	scrollbar-gutter: stable;
	overflow-y: scroll;
}
a {
	color: inherit;
	text-decoration: none;
	transition: color 0.3s ease, background-color 0.3s ease;
}
a:hover {
	color: var(--bs-danger);
}
a:focus {
	outline: none !important;
}
:focus {
	outline: 0 !important;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
h1, h2, h3, h4, h5, h6 {
	font-weight: 700;
	line-height: 1.2;
	margin-top: 0;
	margin-bottom: 0.5rem;
}
ul {
	padding: 0;
	margin: 0;
	list-style: none;
}
.flex {
	display: flex;
	flex-wrap: wrap;
}
.flex-item {
	flex: 1 1 0;
	min-width: 0;
}
/*
* ----------------------------------------------------------------------------------------
* OffCanvas
* ----------------------------------------------------------------------------------------
*/
.offcanvas {
 --oc-primary: #2a5e51;
 --oc-white: #ffffff;
 --oc-bg-glass: rgba(240, 242, 245, 0.8);
 --oc-danger: #dc3545;
 --oc-shadow-btn: rgba(0, 0, 0, 0.2);
 --oc-shadow-hover: rgba(220, 53, 69, 0.4);
 --oc-border-white: rgba(255, 255, 255, 0.4);
}
.offcanvas .offcanvas-header {
	background: var(--oc-bg-glass) !important;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid rgba(0,0,0,0.05);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	z-index: 10;
}
.offcanvas .offcanvas-body {
	padding-top: 15px !important;
	padding-bottom: 20px !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.offcanvas .btn-close {
	background: var(--oc-primary) !important;
	mask-image: none !important;
	-webkit-mask-image: none !important;
	opacity: 1 !important;
	width: 0.75rem !important;
	height: 0.75rem !important;
	font-size: 1rem !important;
	border-radius: 50% !important;
	position: absolute !important;
	top: 20px;
	right: 15px;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	border: 2px solid var(--oc-border-white) !important;
	box-shadow: 0 4px 15px var(--oc-shadow-btn) !important;
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
	z-index: 1100;
}
.offcanvas .btn-close::before {
	content: "\f659" !important;
	font-family: "bootstrap-icons" !important;
	color: var(--oc-white) !important;
	font-size: 1rem !important;
	line-height: 1 !important;
	display: block !important;
}
.offcanvas .btn-close:hover {
	background-color: var(--oc-danger) !important;
	transform: rotate(180deg) scale(1.1) !important;
	box-shadow: 0 6px 20px var(--oc-shadow-hover) !important;
}
.offcanvas.show .btn-close {
	animation: bounceInClose 0.6s ease-out;
}
 @keyframes bounceInClose {
 0% {
 transform: scale(0) rotate(-180deg);
 opacity: 0;
}
 70% {
 transform: scale(1.1) rotate(20deg);
}
 100% {
 transform: scale(1) rotate(0);
 opacity: 1;
}
}
/*
* ----------------------------------------------------------------------------------------
* Header
* ----------------------------------------------------------------------------------------
*/

#main-header {
 --h-primary: #2a5e51;
 --h-bg-menu: rgba(240, 242, 245, 0.85);
 --h-border: rgba(0, 0, 0, 0.05);
 --h-white: #ffffff;
 --h-dark: #000000;
	transition: all 0.4s ease;
	z-index: 1030;
}
#main-header .header-top-info {
	background-color: var(--h-primary);
	transition: transform 0.4s ease;
	position: relative;
	z-index: 1;
}
#main-header .navbar {
	background-color: var(--h-bg-menu) !important;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--h-border);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	transition: all 0.4s ease;
	z-index: 2;
}
#main-header .logo-container {
	position: relative;
	z-index: 1070;
	margin: 0 15px;
}
#main-header .header-logo-img {
	margin-top: -40px;
	margin-bottom: -12px;
	background: var(--h-white);
	padding: 10px;
	border-radius: 0 0 15px 15px;
	border: 1px solid var(--h-border);
	border-top: none;
	box-shadow: 0 8px 15px rgba(0,0,0,0.1);
	transition: all 0.4s ease;
	position: relative;
	z-index: 9999;
}
#main-header .menu-toggle-btn {
	width: 42px;
	height: 42px;
	background: rgba(42, 94, 81, 0.1) !important;
	backdrop-filter: blur(5px);
	-webkit-backdrop-filter: blur(5px);
	border: 1px solid rgba(42, 94, 81, 0.2);
	border-radius: 0 !important;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	transition: all 0.3s ease;
	cursor: pointer;
	z-index: 1090;
	padding: 0;
}
#main-header .menu-toggle-btn span {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--h-primary);
	margin: 3px 0;
	transition: all 0.3s ease-in-out;
	position: relative;
}
#main-header .menu-toggle-btn.active span:nth-child(1) {
	transform: translateY(8px) rotate(45deg);
}
#main-header .menu-toggle-btn.active span:nth-child(2) {
	opacity: 0;
	transform: translateX(-10px);
}
#main-header .menu-toggle-btn.active span:nth-child(3) {
	transform: translateY(-8px) rotate(-45deg);
}
#main-header .nav-link {
	font-weight: 700;
	color: var(--h-dark) !important;
	text-transform: uppercase;
	font-size: 13px;
	padding: 10px 18px !important;
	margin: 10px 4px;
	position: relative;
	z-index: 1;
}
#main-header .nav-link::before {
	content: '';
	position: absolute;
	top: 5px;
	left: 0;
	right: 0;
	bottom: 5px;
	background: var(--h-primary);
	opacity: 0;
	z-index: -1;
	clip-path: polygon(2% 15%, 95% 7%, 98% 85%, 5% 92%);
	transition: 0.3s;
	transform: scaleX(0.8);
}
#main-header .nav-link:hover::before, #main-header .nav-link.active-page::before {
	opacity: 0.12;
	transform: scaleX(1);
}
#main-header .dropdown-toggle::after {
	transition: transform 0.3s ease;
}
#main-header .dropdown:hover .dropdown-toggle::after {
	transform: rotate(180deg);
}
#main-header.scrolled .header-top-info {
	transform: translateY(-100%);
}
#main-header.scrolled .navbar {
	margin-top: -5px;
	transform: translateY(-38px);
	box-shadow: 0 5px 15px rgba(0,0,0,0.1) !important;
}
#main-header.scrolled .header-logo-img {
	width: 100px;
	margin-top: -5px;
	margin-bottom: 0;
}
/* 
* ----------------------------------------------------------------------------------------
* Desktop Dropdown 
* ----------------------------------------------------------------------------------------
*/

#main-header .dropdown-menu {
	background-color: rgba(255, 255, 255, 0.9) !important;
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
	border: 1px solid var(--h-border) !important;
	border-top: 3px solid var(--h-primary) !important;
	border-radius: 0 0 10px 10px !important;
	box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1) !important;
	padding: 10px 0 !important;
	margin-top: 0 !important;
	min-width: 220px;
}
#main-header .dropdown-item {
	font-size: 13px;
	font-weight: 600;
	color: var(--h-dark);
	text-transform: uppercase;
	padding: 10px 20px !important;
	letter-spacing: 0.5px;
	transition: all 0.3s ease;
	position: relative;
}
#main-header .dropdown-item:hover {
	background-color: rgba(42, 94, 81, 0.05) !important;
	color: var(--h-primary) !important;
	padding-left: 25px !important;
}
#main-header .dropdown-item::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 0;
	background-color: var(--h-primary);
	transition: height 0.3s ease;
}
#main-header .dropdown-item:hover::before {
	height: 70%;
}

@media (min-width: 992px) {
#main-header .dropdown-menu.show {
	animation: dropdownAppear 0.4s ease-out forwards;
}
}
 @keyframes dropdownAppear {
 0% {
 opacity: 0;
 transform: translateY(15px);
}
 100% {
 opacity: 1;
 transform: translateY(0);
}
}
/* 
* ----------------------------------------------------------------------------------------
* OffCanvas Navigation
* ----------------------------------------------------------------------------------------
*/
#main-header .offcanvas .nav-link {
	color: var(--h-dark) !important;
	padding: 0.8rem 1.35rem !important;
	margin: 0 !important;
	font-weight: 600;
	font-size: 15px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	transition: all 0.2s ease;
	position: relative;
	border: none !important;
}
#main-header .offcanvas .nav-link::before {
	display: none !important;
}
#main-header .offcanvas .nav-link:hover, #main-header .offcanvas .nav-link[aria-expanded="true"] {
	background-color: rgba(42, 94, 81, 0.08) !important;
	color: var(--h-primary) !important;
	border: none !important;
}
#main-header .offcanvas .nav-link i.bi-plus-lg {
	transition: transform 0.3s ease;
}
#main-header .offcanvas .nav-link[aria-expanded="true"] i.bi-plus-lg {
	transform: rotate(45deg);
}
#main-header .offcanvas .collapse {
	background: #f1f3f5 !important;
}
#main-header .offcanvas .collapse ul {
	padding-top: 5px !important;
	padding-bottom: 10px !important;
	margin: 0 !important;
}
#main-header .offcanvas .collapse .nav-link {
	padding-top: 5px !important;
	padding-bottom: 5px !important;
	padding-left: 2.8rem !important;
	font-size: 14px;
	font-weight: 500;
}
#main-header .offcanvas .collapse .nav-link:hover {
	background-color: rgba(0, 0, 0, 0.04) !important;
}
/* 
* ----------------------------------------------------------------------------------------
* Promo
* ----------------------------------------------------------------------------------------
*/

#promo {
 --promo-green: #2a5e51;
	/* Улучшенный фон с градиентом глубины */
	background: var(--promo-green) radial-gradient(circle at center, rgba(255,255,255,0.08) 0%, transparent 100%);
	padding: 120px 0 160px; /* Увеличили отступ снизу для дороги */
	overflow: hidden;
	color: #ffffff;
	position: relative;
}
/* 1. Верхний заголовок */
#promo .promo-title {
	font-family: "Montserrat", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: 30px;
	animation: fadeInUp 1s ease forwards;
	text-align: center;
}
 @keyframes fadeInUp {
 from {
opacity: 0;
transform: translateY(20px);
}
 to {
opacity: 1;
transform: translateY(0);
}
}
/* 2. Контейнер пути */
#promo .truck-path {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 25px;
	position: relative;
	z-index: 5;
}
/* 3. Анимация машинки */
#promo .truck-wrapper {
	position: relative;
	transform: scaleX(-1);
	animation: truck-drive 0.6s infinite ease-in-out;
}
 @keyframes truck-drive {
 0% {
transform: scaleX(-1) translateY(0) rotate(0deg);
}
 25% {
transform: scaleX(-1) translateY(-3px) rotate(-1deg);
}
 50% {
transform: scaleX(-1) translateY(0) rotate(0deg);
}
 75% {
transform: scaleX(-1) translateY(-1px) rotate(1deg);
}
 100% {
transform: scaleX(-1) translateY(0) rotate(0deg);
}
}
/* Тень под колесами (чтобы не висела в воздухе) */
#promo .truck-wrapper::before {
	content: "";
	position: absolute;
	bottom: 5px;
	left: 10%;
	width: 80%;
	height: 8px;
	background: rgba(0, 0, 0, 0.4);
	filter: blur(4px);
	border-radius: 50%;
	z-index: -1;
	transform: scaleX(-1); /* отмена разворота родителя для тени */
}
#promo .truck-icon {
	font-size: 4.5rem;
	color: #ffffff;
	filter: drop-shadow(-8px 8px 12px rgba(0,0,0,0.2));
}
/* 4. Дым */
.smoke-container {
	position: absolute;
	left: -5px;
	bottom: 40px;
	z-index: -1;
}
.smoke-container span {
	position: absolute;
	width: 8px;
	height: 8px;
	background: rgba(255, 255, 255, 0.4);
	border-radius: 50%;
	opacity: 0;
	filter: blur(2px);
	animation: smoke-drift 1.8s infinite linear;
}
.smoke-container .s-1 {
	animation-delay: 0s;
}
.smoke-container .s-2 {
	animation-delay: 0.6s;
}
.smoke-container .s-3 {
	animation-delay: 1.2s;
}
 @keyframes smoke-drift {
 0% {
transform: translate(0, 0) scale(1);
opacity: 0;
}
 15% {
opacity: 0.6;
}
 100% {
transform: translate(-70px, -40px) scale(4);
opacity: 0;
}
}
/* 5. Дорожная разметка (бегущая) */
#promo .promo-road {
	position: absolute;
	bottom: 115px; /* Регулируйте высоту под колеса машинки */
	left: 0;
	width: 200%;
	height: 3px;
	background: repeating-linear-gradient( 90deg, rgba(255, 255, 255, 0.15) 0px, rgba(255, 255, 255, 0.15) 40px, transparent 40px, transparent 80px );
	animation: road-move 1.5s linear infinite;
	z-index: 1;
}
 @keyframes road-move {
 from {
transform: translateX(0);
}
 to {
transform: translateX(-80px);
}
}
/* 6. Текст */
#promo .typed-box {
	font-size: 1.8rem;
	font-weight: 700;
	border-left: 4px solid #ffc107;
	padding: 5px 0 5px 25px;
	text-shadow: 0 2px 10px rgba(0,0,0,0.2);
	min-width: 300px;
}
#promo .typed-cursor {
	color: #ffc107;
}

/* Адаптив для мобилок */
@media (max-width: 768px) {
#promo .typed-box {
	font-size: 1.2rem;
	min-width: auto;
}
#promo .truck-icon {
	font-size: 3rem;
}
#promo .promo-road {
	bottom: 125px;
}
}
/* 
* ----------------------------------------------------------------------------------------
* About
* ----------------------------------------------------------------------------------------
*/

#about {
 --about-primary: #2a5e51;    /* Ваш фирменный зеленый */
 --about-text: #333333;       /* Основной текст */
 --about-muted: #666666;      /* Приглушенный текст */
 --about-bg: #ffffff;         /* Фон секции */
	position: relative;
	overflow: hidden;
	background-color: var(--about-bg);
	padding: 80px 0;
	font-family: "Inter", "Montserrat", sans-serif;
}
#about::after {
	content: "LOGISTICS";
	position: absolute;
	bottom: -20px;
	right: -5%;
	font-size: 12vw;
	font-weight: 900;
	color: rgba(42, 94, 81, 0.03);
	z-index: 0;
	pointer-events: none;
	letter-spacing: 1.5rem;
}
#about .container {
	position: relative;
	z-index: 2;
}
#about .about-content {
	display: flex;
	flex-direction: column;
	gap: 15px;
}
#about .section-title {
	font-size: 1.5rem;
	font-weight: 850;
	line-height: 1.1;
	color: var(--about-primary);
	margin-bottom: 20px;
	text-transform: uppercase;
}
#about .about-text-card {
	background: #ffffff;
	padding: 20px;
	border-radius: 12px;
	border: 1px solid rgba(0, 0, 0, 0.05);
	box-shadow: 4px 4px 20px rgba(0, 0, 0, 0.02);
	transition: all 0.3s ease;
	position: relative;
}
#about .about-text-card::after {
	content: "";
	position: absolute;
	left: 0;
	top: 20%;
	height: 60%;
	width: 3px;
	background: var(--about-primary);
	border-radius: 0 4px 4px 0;
	opacity: 0.5;
	transition: 0.3s;
}
#about .about-text-card:hover {
	transform: translateX(5px);
	box-shadow: 0 10px 30px rgba(42, 94, 81, 0.08);
	border-color: rgba(42, 94, 81, 0.2);
}
#about .about-text-card:hover::after {
	height: 80%;
	top: 10%;
	opacity: 1;
}
#about .about-quote {
	background: linear-gradient(135deg, #f8f9fa 0%, #edf2f4 100%);
	padding: 25px;
	border-radius: 15px;
	font-weight: 600;
	color: var(--about-primary);
	border-bottom: 3px solid var(--about-primary);
}
#about .collage-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-gap: 12px;
	transform: rotate(-3deg);
	transition: transform 0.4s ease;
}
#about .img-item {
	overflow: hidden;
	border-radius: 12px;
	box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}
#about .img-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.4s;
}
#about .img-item.main {
	grid-column: span 2;
	height: 220px;
}
#about .img-item:not(.main) {
	height: 140px;
}
#about .img-item:hover img {
	transform: scale(1.1);
}
#about .cta-box {
	background: linear-gradient(145deg, var(--about-primary), #1e453b);
	border-radius: 20px;
	padding: 30px 20px;
	margin-top: 30px;
	box-shadow: 0 15px 35px rgba(42, 94, 81, 0.25);
	text-align: center;
}
#about .cta-title {
	color: #fff;
	font-weight: 800;
	text-transform: uppercase;
	margin-bottom: 5px;
}
#about .cta-subtitle {
	color: rgba(255,255,255,0.7);
	font-size: 0.8rem;
	margin-bottom: 20px;
}
#about .btn-cta-action {
	background: #fff;
	color: var(--about-primary) !important;
	font-weight: 800;
	border-radius: 10px;
	animation: pulse-border 2s infinite;
}
 @keyframes pulse-border {
 0% {
box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.4);
}
 70% {
box-shadow: 0 0 0 10px rgba(255, 255, 255, 0);
}
 100% {
box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
}
}

@media (max-width: 991px) {
#about .collage-grid {
	transform: none;
	margin: 30px 0;
}
#about .section-title {
	text-align: center;
}
#about::after {
	display: none;
}
}
#about .features-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
	margin-top: 15px;
}
#about .features-list li {
	display: flex;
	align-items: center;
	padding: 16px 20px;
	border-radius: 12px;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid rgba(42, 94, 81, 0.1);
	background: #ffffff;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
}
#about .features-list i {
	color: #ffffff;
	font-size: 1.3rem;
	margin-right: 18px;
	width: 46px;
	height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--about-primary), #3d8573);
	border-radius: 10px;
	flex-shrink: 0;
	box-shadow: 0 6px 15px rgba(42, 94, 81, 0.2);
}
#about .features-list strong {
	font-size: 1rem;
	color: var(--about-primary);
	margin-bottom: 2px;
	font-weight: 700;
}
#about .features-list div {
	font-size: 0.85rem;
	color: var(--about-text);
	line-height: 1.3;
}
#about .features-list li:hover {
	background-color: var(--about-primary) !important;
	border-color: var(--about-primary);
	transform: translateX(10px) translateY(-2px);
	box-shadow: 0 10px 25px rgba(42, 94, 81, 0.2);
}
#about .features-list li:hover strong, #about .features-list li:hover div {
	color: #ffffff !important;
}
#about .features-list li:hover i {
	background: #ffffff;
	color: var(--about-primary);
}
#about .cta-box {
	background: var(--about-primary);
	color: #ffffff;
	border-radius: 8px;
}
#about .cta-box .btn-cta-action {
	background-color: #ffffff;
	color: var(--about-primary) !important;
	border: none;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 1px;
	padding: 15px 30px;
	border-radius: 10px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	position: relative;
	overflow: hidden;
}
#about .cta-box .btn-cta-action:hover {
	background-color: #ffffff;
	transform: translateY(-5px) scale(1.03);
	box-shadow: 0 12px 25px rgba(0, 0, 0, 0.3), 0 0 20px rgba(255, 255, 255, 0.4);
	color: #000 !important;
}
#about .cta-box .btn-cta-action::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient( 120deg, transparent, rgba(255, 255, 255, 0.6), transparent );
	transition: all 0.6s;
}
#about .cta-box .btn-cta-action:hover::before {
	left: 100%;
}
 @keyframes pulse-white {
 0% {
box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.4);
}
 70% {
box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
}
 100% {
box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
}
}
#about .cta-box .btn-cta-action {
	animation: pulse-white 2s infinite;
}

@media (max-width: 991px) {
#about {
	padding: 50px 0;
}
#about::after {
	display: none;
}
#about .collage-grid {
	transform: none !important;
	margin-bottom: 35px;
	grid-gap: 10px;
}
#about .features-list li:hover {
	transform: none;
}
}
/* 
* ----------------------------------------------------------------------------------------
* Сalculator
* ----------------------------------------------------------------------------------------
*/
#calculator {
	background: #f2f2f2;
 --primary: #2a5e51;
 --accent: #ffc107;
}
#calculator .title-underline {
	width: 80px;
	height: 4px;
	background: var(--accent);
	border-radius: 2px;
	margin-top: 10px;
}
#calculator .calc-panel {
	background: var(--primary);
	border-radius: 20px;
	color: white;
}
#calculator .form-control-custom {
	width: 100%;
	padding: 12px 15px;
	border-radius: 10px;
	border: 2px solid rgba(255,255,255,0.1);
	background: rgba(255,255,255,0.1);
	color: white;
	transition: 0.3s;
}
#calculator .form-control-custom:focus {
	background: white;
	color: var(--primary);
	outline: none;
	border-color: var(--accent);
}
#calculator .input-group-custom label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	font-size: 0.9rem;
	color: rgba(255,255,255,0.8);
}
#calculator .distance-badge {
	background: var(--accent);
	color: #000;
	padding: 15px 20px;
	border-radius: 15px;
	box-shadow: 0 5px 15px rgba(255, 193, 7, 0.3);
	animation: fadeIn 0.5s ease;
}
#calculator .car-card {
	border: 1px solid rgba(0, 0, 0, 0.05) !important;
	background: #ffffff;
	border-radius: 16px;
	padding: 25px !important;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
	transition: all 0.3s ease;
	position: relative;
}
#calculator .car-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 4px;
	background: #ffc107;
	transition: 0.4s;
	border-radius: 16px 16px 0 0;
}
#calculator .car-card:hover {
	transform: translateY(-7px);
	box-shadow: 0 15px 35px rgba(42, 94, 81, 0.15);
	border-color: rgba(42, 94, 81, 0.1) !important;
}
#calculator .car-card:hover::before {
	width: 100%;
}
#calculator .car-card h5 {
	color: #2a5e51;
	font-weight: 800;
	font-size: 1.3rem;
	margin-bottom: 8px;
}
#calculator .total-price-wrap {
	border-left: 3px solid #ffc107;
	padding-left: 15px;
}
#calculator .total-price-wrap .amount {
	font-size: 1.8rem;
	font-weight: 950;
	color: #2a5e51;
	display: block;
	line-height: 1;
}
#calculator .btn-order {
	background: #2a5e51;
	color: #fff !important;
	border-radius: 8px;
	font-weight: 700;
	padding: 10px 20px;
	border: none;
	transition: 0.3s;
}
#calculator .btn-order:hover {
	background: #1e453b;
	box-shadow: 0 5px 15px rgba(42, 94, 81, 0.3);
}
#calculator .btn-calc-trigger {
	background: #ffc107;
	color: #212529;
	border: none;
	border-radius: 12px;
	box-shadow: 0 4px 15px rgba(255, 193, 7, 0.3);
	transition: all 0.3s ease;
}
#calculator .btn-calc-trigger:hover {
	background: #e5ad06;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(255, 193, 7, 0.4);
	color: #000;
}
#calculator .btn-calc-trigger:active {
	transform: translateY(0);
}
#calculator .spinner-border-sm {
	width: 1.2rem;
	height: 1.2rem;
	border-width: 0.15em;
}
#calculator .price-total {
	color: var(--primary);
	font-size: 1.8rem;
	font-weight: 900;
}
#calculator .btn-order {
	background: var(--primary);
	color: white !important;
	border-radius: 10px;
	font-weight: 700;
	padding: 10px 20px;
	transition: 0.3s;
}
#calculator .btn-order:hover {
	background: #1e453b;
	box-shadow: 0 5px 15px rgba(42, 94, 81, 0.3);
}
#calculator .map-wrapper {
	border-radius: 20px;
	overflow: hidden;
	border: 5px solid #f8f9fa;
}
#calculator .disclaimer {
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}
#calculator .disclaimer .rounded-4 {
	transition: transform 0.3s ease;
}
#calculator .blink-icon {
	animation: blinker 2s linear infinite;
}
 @keyframes blinker {
 50% {
opacity: 0.3;
}
}
#calculator .disclaimer strong {
	color: #dc3545;
	font-weight: 800;
}
#calculator .disclaimer:hover .rounded-4 {
	transform: scale(1.01);
	background-color: #fff0f0 !important;
}
#calculator #state-result {
	background: linear-gradient(135deg, #ffc107 0%, #ffb300 100%); /* Сочный желтый градиент */
	border-radius: 15px;
	padding: 20px !important;
	box-shadow: 0 10px 25px rgba(255, 193, 7, 0.3);
	border: 1px solid rgba(255, 255, 255, 0.2);
	position: relative;
	overflow: hidden;
}
#calculator #state-result::before {
	content: "";
	position: absolute;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%);
	pointer-events: none;
}
#calculator #state-result .small {
	color: rgba(0, 0, 0, 0.6);
	font-size: 0.75rem !important;
	letter-spacing: 1px;
}
#calculator #distance-val {
	color: #212529;
	font-weight: 900;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
}
#calculator #btn-reset {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #212529;
	color: #fff;
	border: none;
	border-radius: 50%;
	transition: all 0.3s ease;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}
#calculator #btn-reset:hover {
	background: #000;
	transform: rotate(90deg) scale(1.1);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.3);
}
#calculator #btn-reset i {
	font-size: 1.1rem;
	line-height: 1;
}
 @keyframes slideIn {
 from {
opacity: 0;
transform: translateY(10px);
}
 to {
opacity: 1;
transform: translateY(0);
}
}
#calculator #state-result[style*="display: block"] {
	animation: slideIn 0.4s ease forwards;
}
#calculator .car-card {
	border: none;
	background: #ffffff;
	border-radius: 12px;
	padding: 30px !important;
	position: relative;
	z-index: 1;
	overflow: hidden; 
	transition: 0.4s ease;
	box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}
#calculator .car-card::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: conic-gradient(transparent, #ffc107, transparent 30%);
	animation: rotate-border 4s linear infinite;
	opacity: 0;
	transition: opacity 0.3s;
}
#calculator .car-card::after {
	content: "";
	position: absolute;
	z-index: -1;
	inset: 2px;
	background: white;
	border-radius: 11px;
}
 @keyframes rotate-border {
 100% {
transform: rotate(360deg);
}
}
#calculator .car-card:hover::before {
	opacity: 1;
}
#calculator .car-card .corner-badge {
	position: absolute;
	top: 0;
	right: 0;
	width: 50px;
	height: 50px;
	background: #2a5e51;
	clip-path: polygon(0 0, 100% 0, 100% 100%);
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
	padding: 5px 8px;
	color: white;
	font-size: 0.8rem;
	transition: 0.3s;
}
#calculator .car-card:hover .corner-badge {
	background: #ffc107;
	transform: scale(1.1);
}
#calculator .car-icon-box {
	width: 60px;
	height: 60px;
	background: rgba(42, 94, 81, 0.05);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 15px;
	color: #2a5e51;
	font-size: 1.8rem;
	transition: 0.3s;
}
#calculator .car-card:hover .car-icon-box {
	background: #2a5e51;
	color: white;
	transform: rotateY(180deg);
}
#tariffs {
 --brand-green: #2a5e51;
}
/* 
* ----------------------------------------------------------------------------------------
* Tariffs
* ----------------------------------------------------------------------------------------
*/

#tariffs .nav-pills .nav-link {
	color: #2a5e51; 
	border: 1px solid #2a5e51;
	background-color: transparent;
	font-weight: 700;
	transition: all 0.3s ease;
	padding: 10px 25px;
}

#tariffs .nav-pills .nav-link:hover {
	background-color: rgba(42, 94, 81, 0.05);
	color: #2a5e51;
}

#tariffs .nav-pills .nav-link.active {
	background-color: #2a5e51 !important; 
	color: #ffffff !important; 
	border-color: #2a5e51 !important;
	box-shadow: 0 4px 12px rgba(42, 94, 81, 0.2);
}

#tariffs .tariff-card {
	background: #ffffff;
	border: 1px solid rgba(0,0,0,0.1);
	border-radius: 12px;
	padding: 25px;
	transition: 0.3s;
	height: 100%;
	display: flex;
	flex-direction: column;
}
#tariffs .tariff-card:hover {
	box-shadow: 0 10px 30px rgba(42,94,81,0.1);
	border-color: var(--brand-green);
}
#tariffs .spec-line {
	display: flex;
	justify-content: space-between;
	font-size: 0.9rem;
	padding: 5px 0;
	border-bottom: 1px solid #f0f0f0;
}
#tariffs .spec-line span {
	color: #666;
}
#tariffs .spec-line strong {
	color: #222;
}
#tariffs .price-main {
	font-size: 1.1rem;
	font-weight: 600;
	color: #222;
}
#tariffs .price-main span {
	font-size: 1.6rem;
	font-weight: 900;
	color: var(--brand-green);
}
#tariffs .btn-order {
	background-color: var(--brand-green);
	color: #fff;
	border-radius: 6px;
	transition: 0.3s;
}
#tariffs .btn-order:hover {
	background-color: #ffc107;
	color: #000;
}
#tariffs .btn {
	background-color: #2a5e51 !important;
	color: #ffffff !important;
	border: none;
	border-radius: 10px;
	padding: 12px 20px;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
#tariffs .btn:hover {
	background-color: #ffc107 !important;
	color: #212529 !important;
	transform: translateY(-3px);
	box-shadow: 0 8px 15px rgba(255, 193, 7, 0.4);
}
#tariffs .btn:active {
	transform: translateY(-1px);
}
/* 
* ----------------------------------------------------------------------------------------
* Thanks
* ----------------------------------------------------------------------------------------
*/



#thanks {
 --t-green: #2a5e51;
 --t-yellow: #ffc107;
	position: relative;
	padding: 80px 0;
	background: #ffffff;
}
#thanks .thanks-carousel {
	position: relative !important;
	padding: 0 70px;
}
#thanks .gramota-card {
	background: #ffffff;
	border: 2px solid rgba(42, 94, 81, 0.1);
	border-radius: 15px;
	padding: 10px;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	position: relative;
	overflow: hidden;
	height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
}
#thanks .gramota-img-container {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	position: relative;
	border-radius: 10px;
	background: #fff;
}
#thanks .gramota-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.5);
	opacity: 0;
	transition: opacity 0.4s ease;
	z-index: 1;
}
#thanks .gramota-img-container img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	transition: transform 0.5s ease;
}
#thanks .gramota-card:hover .gramota-overlay {
	opacity: 1;
}
#thanks .gramota-card:hover img {
	transform: scale(1.05);
}
#thanks .gramota-zoom-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) scale(0.8);
	width: 65px;
	height: 65px;
	background: rgba(42, 94, 81, 0.4);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.2);
	color: #ffffff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.6rem;
	opacity: 0;
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	z-index: 2;
}
#thanks .gramota-card:hover .gramota-zoom-icon {
	opacity: 1;
	transform: translate(-50%, -50%) scale(1);
}

#thanks .owl-nav {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	margin: 0 !important;
}
#thanks .owl-prev, #thanks .owl-next {
	position: absolute !important;
	top: -50px;
	width: 50px !important;
	height: 50px !important;
	background: var(--t-green) !important;
	color: #ffffff !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem !important;
	border: none !important;
	box-shadow: 0 4px 12px rgba(0,0,0,0.2);
	z-index: 100;
	transition: all 0.3s ease !important;
}
#thanks .owl-prev {
	left: 0 !important;
}
#thanks .owl-next {
	right: 0 !important;
}
#thanks .owl-prev:hover, #thanks .owl-next:hover {
	background: var(--t-yellow) !important;
	color: #212529 !important;
	transform: scale(1.1);
}
#thanks .owl-dots {
	text-align: center !important;
	margin-top: 30px !important;
	width: 100% !important;
	display: block !important;
}
#thanks .owl-dot {
	display: inline-block !important;
	outline: none !important;
}
#thanks .owl-dot span {
	width: 10px;
	height: 10px;
	background: #d1d1d1 !important;
	display: block;
	margin: 5px;
	border-radius: 50%;
	transition: 0.3s ease;
}
#thanks .owl-dot.active span {
	background: var(--t-green) !important;
	width: 25px !important;
	border-radius: 10px !important;
}

@media (max-width: 575px) {
    #thanks .item {
        width: 100% !important;
		margin: 0px !important;
		margin-left: 0px !important;
    }
    #thanks .gramota-card {
        width: 100%;
        max-width: 290px;
    }
}

/* 
* ----------------------------------------------------------------------------------------
* Thanks
* ----------------------------------------------------------------------------------------
*/
#footer {
	background: #0a0a0a;
	color: #ffffff;
 --accent: #2a5e51;
 --accent-light: #3d8573;
}
#footer .footer-title {
	font-size: 1.1rem;
	font-weight: 800;
	text-transform: uppercase;
	color: #fff;
	position: relative;
	padding-bottom: 10px;
}
#footer .footer-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 40px;
	height: 3px;
	background: var(--accent);
	box-shadow: 0 0 10px var(--accent);
}
#footer .footer-text {
	color: #b0b0b0;
	line-height: 1.8;
	font-size: 0.9rem;
}
#footer .text-accent {
	color: var(--accent-light);
}
#footer .footer-links a {
	color: #b0b0b0;
	text-decoration: none;
	font-size: 0.95rem;
	display: block;
	margin-bottom: 10px;
	transition: 0.3s;
}
#footer .footer-links a:hover {
	color: #fff;
	padding-left: 8px;
	border-left: 2px solid var(--accent);
}
#footer .contact-item {
	display: flex;
	align-items: center;
	color: #b0b0b0;
	font-size: 0.9rem;
}
#footer .contact-item i {
	color: var(--accent);
	margin-right: 15px;
	font-size: 1.1rem;
}
#footer .contact-item a {
	color: #fff;
	text-decoration: none;
	font-weight: 600;
}
#footer .share-grid {
	display: flex;
	gap: 12px;
}
#footer .share-link {
	width: 42px;
	height: 42px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #1a1a1a;
	color: #fff;
	font-size: 1.2rem;
	text-decoration: none;
	transition: 0.3s;
	border: 1px solid #333;
}
#footer .share-link:hover {
	background: var(--accent);
	border-color: var(--accent);
	transform: translateY(-5px);
	box-shadow: 0 5px 15px rgba(42, 94, 81, 0.4);
}
#footer .license-badge {
	display: inline-flex;
	align-items: center;
	padding: 8px 15px;
	background: rgba(42, 94, 81, 0.1);
	border: 1px solid var(--accent);
	border-radius: 8px;
	font-size: 11px;
	color: var(--accent-light);
	text-transform: uppercase;
}
#footer .counter-box {
	background: #1a1a1a;
	border: 1px solid #333;
	padding: 5px 10px;
	font-size: 11px;
	color: #666;
	border-radius: 5px;
}
#footer .counter-box span {
	color: var(--accent);
	font-weight: bold;
}
#footer .footer-hr {
	border-color: rgba(255,255,255,0.05);
}
#footer .copyright {
	font-size: 0.8rem;
	color: #555;
}
/*
* ----------------------------------------------------------------------------------------
* Button To Top
* ----------------------------------------------------------------------------------------
*/
#button-to-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	height: 50px;
	width: 50px;
	display: none;
	place-items: center;
	border-radius: 50%;
	cursor: pointer;
	z-index: 95;
}
#button-to-top-progress-value {
	height: calc(100% - 15px);
	width: calc(100% - 15px);
	background-color: var(--bs-white);
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-size: 1.5em;
	color: var(--bs-dark);
}