@media (min-width: 1200px) {
	.transfer-form .form-row {
		flex-wrap: nowrap;
	}
}


@media (max-width: 1199px) {
	.hero {
		padding: 3rem 0;
	}
	#header {
		height: 80px;
	}
	
	#header .container {
		padding: 0 1rem;
	}
	
	#header .header-inner {
		gap: 1rem;
		min-width: 0;
		max-width: 100%;
		width: 100%;
		overflow-x: hidden;
		overflow-y: hidden;
		box-sizing: border-box;
	}
	
	#header .logo {
		flex-shrink: 1;
		min-width: 0;
	}
	
	#header .logo a {
		gap: 0.6rem;
	}
	
	#header .logo-icon {
		width: 42px;
		height: 42px;
		font-size: 1.3rem;
		flex-shrink: 0;
	}
	
	#header .logo-text {
		min-width: 0;
	}
	
	#header .logo-top {
		font-size: 0.65rem;
	}
	
	#header .logo-bottom {
		font-size: 1rem;
	}
	
	#header .header-nav {
		display: none;
	}
	
	#header .header-actions {
		padding-left: 0.75rem;
		gap: 0.5rem;
		border-left: none;
		flex-shrink: 0;
		min-width: 0;
		max-width: 100%;
	}
	
	#header .header-actions .header-lang {
		padding-left: 0;
	}
	
	#header .mobile-menu-toggle {
		display: flex;
	}
	
	#header {
		top: 0;
		max-width: 100%;
		width: 100%;
	}
	
	#header .container {
		position: relative;
	}
	
	#header .mobile-menu {
		display: block !important;
		position: fixed;
		top: 80px;
		left: 0;
		right: 0;
		z-index: 1001;
		width: 100%;
		max-width: 100vw;
	}
	
	#header .mobile-menu.active {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		max-height: 500px !important;
	}
	
	#header .header-lang {
		position: relative;
		overflow: visible;
		z-index: 1001;
	}
	
	#header .lang-dropdown {
		position: fixed;
		z-index: 10001;
		overflow: visible;
	}
	
	#header .header-lang .lang-btn {
		width: 44px;
		height: 44px;
		padding: 0;
		border-radius: 8px;
		font-size: 0.9rem;
		border: none;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: all 0.2s ease;
	}
	
	#header .header-lang .flag-icon {
		max-width: 20px;
		max-height: 20px;
		width: auto;
		height: auto;
	}
	
	#header .header-lang .lang-btn:hover {
		border-color: #e53935;
		color: #e53935;
		background: rgba(229, 57, 53, 0.08);
	}
	
	#header .header-lang .lang-btn span {
		display: none;
	}
	
	#header .header-lang .flag-icon {
		width: 20px;
		height: 20px;
		margin: 0;
	}
	
	#header .btn-register,
	#header .btn-login {
		width: 44px;
		height: 44px;
		padding: 0;
		border-radius: 8px;
		background-color: transparent !important;
		border: none !important;
		font-size: 1.1rem;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: all 0.2s ease;
	}
	
	#header .btn-register:hover,
	#header .btn-login:hover {
		border-color: #e53935;
		color: #e53935;
		background: rgba(229, 57, 53, 0.08);
	}
	
	#header .btn-register span,
	#header .btn-login span {
		display: none;
	}
	
	#header .btn-register i,
	#header .btn-login i {
		font-size: 1.2rem;
		margin: 0;
	}
	
	#header .mobile-menu-toggle {
		width: 44px;
		height: 44px;
		font-size: 1.35rem;
		margin-left: 0 !important;
	}
	
	.hero-content {
		padding: 0 1.5rem;
	}
	
	.hero-title {
		font-size: 2.5rem;
		line-height: 1.3;
	}
	
	.testimonials .container {
		padding: 0 1.5rem;
	}
	
	.tours .container {
		padding: 0 1.5rem;
	}
	
	.tours-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.25rem;
	}
	
	.tour-date {
		top: 0.65rem;
		right: 0.65rem;
		font-size: 0.72rem;
		padding: 0.35rem 0.7rem;
	}
	
	.stats-section .container {
		padding: 2.5rem 1.5rem;
	}
	
	.top-footer .container {
		padding: 0 1.5rem;
	}
	
	.middle-footer .container {
		padding: 0 1.5rem;
	}
	
	.bottom-footer .container {
		padding: 0 1.5rem;
	}
	
	#testimonialSlider .splide__arrow--prev {
		left: 0;
	}
	
	#testimonialSlider .splide__arrow--next {
		right: 0;
	}
}

@media (max-width: 992px) {
	.hero {
		height: calc(100vh - 80px);
		min-height: 450px;
	}
	
	.hero-content {
		padding: 0 1rem;
	}
	
	.testimonials .container {
		padding: 0 1rem;
	}
	
	.tours .container {
		padding: 0 1rem;
	}
	
	.stats-section .container {
		padding: 2rem 1rem;
	}
	
	.stats-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}
	
	.top-footer .container {
		padding: 0 1rem;
	}
	
	.middle-footer .container {
		padding: 0 1rem;
	}
	
	.middle-footer .row {
		row-gap: 2.5rem;
	}
	
	.bottom-footer .container {
		padding: 0 1rem;
	}
}

@media (max-width: 991px) {
	#reservationTabs {
		width: 100%;
		display: flex;
		justify-content: stretch;
		padding: 0.5rem;
		gap: 0.5rem;
	}
	
	#reservationTabs::before {
		display: none;
	}
	
	#reservationTabs .nav-item {
		flex: 1 1 0;
		min-width: 0;
	}
	
	#reservationTabs .nav-link {
		width: 100%;
		flex: 1 1 0;
		justify-content: center;
		padding: 0.75rem 0.5rem;
		font-size: 0.9rem;
		position: relative;
	}
	
	#reservationTabs .nav-link.active {
		background: #e53935;
		color: #fff;
	}
	
	#reservationTabs .nav-link.active::before {
		display: none;
	}
	
	#reservationTabContent {
		padding: 1.5rem 1rem;
		border-radius: 0 0 12px 12px;
		overflow: visible;
		position: relative;
	}
	
	.transfer-form .form-row {
		flex-wrap: wrap;
		gap: 0.75rem;
		overflow: visible;
		position: relative;
	}
	
	.transfer-form .form-group {
		flex: 1 1 100% !important;
		height: 70px;
		min-width: 100%;
		overflow: visible;
		position: relative;
	}
	
	.transfer-form .location-from {
		order: 1;
	}
	
	.btn-swap {
		order: 2;
		align-self: center;
		margin: 0 auto;
		height: 70px;
		width: 100%;
		flex: 0 0 100%;
	}
	
	.transfer-form .location-to {
		order: 3;
	}
	
	.transfer-form .date-time {
		order: 4;
	}
	
	.transfer-form .trip-type {
		order: 5;
		flex-direction: column;
		justify-content: center;
		align-items: flex-start;
	}
	
	.transfer-form .passenger-count {
		order: 6;
	}
	
	.btn-search {
		order: 7;
		width: 100%;
		height: 70px;
	}
	
	.modal-dialog {
		margin: 0.5rem;
		max-width: calc(100% - 1rem);
	}
	
	.auth-modal {
		border-radius: 12px;
	}
	
	.auth-modal-close {
		top: 0.75rem;
		right: 0.75rem;
		width: 36px;
		height: 36px;
		font-size: 1rem;
	}
	
	.auth-modal .row {
		margin: 0;
	}
	
	.auth-modal .row > [class*="col-"] {
		padding: 0;
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
	}
	
	.auth-modal-visual {
		display: none;
	}
	
	.auth-modal-form {
		padding: 2rem;
		width: 100%;
		max-width: 100%;
	}
	
	.auth-modal-header {
		margin-bottom: 1.5rem;
	}
	
	.auth-modal-header h4 {
		font-size: 1.35rem;
	}
	
	.auth-modal-header p {
		font-size: 0.85rem;
	}
	
	.auth-form-row {
		flex-direction: column;
		gap: 0.75rem;
	}
	
	.auth-form-row .auth-form-group {
		flex: 1 1 100%;
	}
	
	.auth-phone-wrapper {
		flex-direction: row;
		gap: 0.5rem;
		position: relative;
		flex-wrap: nowrap;
	}
	
	.auth-phone-wrapper > i {
		position: absolute;
		left: 1rem;
		top: 50%;
		transform: translateY(-50%);
		z-index: 2;
		pointer-events: none;
	}
	
	.auth-country-code {
		width: auto;
		min-width: 120px;
		flex-shrink: 0;
		padding-left: 2.75rem;
		padding-right: 1.5rem;
	}
	
	.auth-phone-wrapper input {
		padding-left: 1rem;
		flex: 1;
		min-width: 0;
	}
	
	.auth-social {
		flex-direction: column;
		gap: 0.625rem;
	}
	
	.auth-social-btn {
		width: 100%;
		padding: 0.7rem 0.875rem;
	}
	
	.auth-divider {
		margin: 1.25rem 0;
	}
	
	.auth-divider span {
		font-size: 0.75rem;
		padding: 0 0.75rem;
	}
}

@media (max-width: 768px) {
	.top-footer.footer-menu {
		margin-top: 1.5rem;
		margin-bottom: 1.5rem;
	}

	#header {
		height: 70px;
	}
	
	#header .mobile-menu {
		top: 70px;
	}
	
	#header .container {
		padding: 0 1rem;
	}
	
	#header .header-inner {
		gap: 0.75rem;
	}
	
	#header .logo {
		flex-shrink: 1;
		min-width: 0;
	}
	
	#header .logo a {
		gap: 0.5rem;
	}
	
	#header .logo-icon {
		width: 40px;
		height: 40px;
		font-size: 1.2rem;
		flex-shrink: 0;
	}
	
	#header .logo-text {
		min-width: 0;
	}
	
	#header .logo-top {
		font-size: 0.6rem;
	}
	
	#header .logo-bottom {
		font-size: 0.95rem;
	}
	
	#header .header-actions {
		gap: 0.4rem;
		padding-left: 0.5rem;
		border-left: none;
		flex-shrink: 0;
	}
	
	#header .header-lang .flag-icon {
		max-width: 18px;
		max-height: 18px;
		width: auto;
		height: auto;
	}
	
	#header .header-actions .header-lang {
		padding-left: 0;
	}
	
	#header .header-lang .lang-btn {
		width: 40px;
		height: 40px;
		padding: 0;
		border-radius: 8px;
		font-size: 0.85rem;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: all 0.2s ease;
	}
	
	#header .header-lang .lang-btn:hover {
		border-color: #e53935;
		color: #e53935;
		background: rgba(229, 57, 53, 0.08);
	}
	
	#header .header-lang .lang-btn span {
		display: none;
	}
	
	#header .header-lang .flag-icon {
		width: 18px;
		height: 18px;
		margin: 0;
	}
	
	#header .btn-register,
	#header .btn-login {
		width: 40px;
		height: 40px;
		padding: 0;
		border-radius: 8px;
		font-size: 1rem;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: all 0.2s ease;
	}
	
	#header .btn-register:hover,
	#header .btn-login:hover {
		border-color: #e53935;
		color: #e53935;
		background: rgba(229, 57, 53, 0.08);
	}
	
	#header .btn-register span,
	#header .btn-login span {
		display: none;
	}
	
	#header .btn-register i,
	#header .btn-login i {
		font-size: 1.1rem;
		margin: 0;
	}
	
	#header .mobile-menu-toggle {
		width: 40px;
		height: 40px;
		font-size: 1.25rem;
		margin-left: 0.5rem;
	}
	
	.hero {
		height: auto;
		min-height: 400px;
		padding: 2rem 0;
	}
	
	.hero-title {
		font-size: 1.75rem;
		margin-bottom: 2rem;
		line-height: 1.4;
	}
	
	.hero-content {
		padding: 0 1rem;
	}
	
	.top-footer .container {
		padding: 0 1rem;
	}
	
	.middle-footer .container {
		padding: 0 1rem;
	}



	.testimonials {
		padding: 3rem 0;
	}
	
	.testimonials .container {
		padding: 0 1rem;
	}
	
	.testimonial-card {
		padding: 1.5rem;
	}
	
	.testimonial-source img {
		height: 24px;
	}
	
	.testimonial-rating {
		margin-bottom: 0.875rem;
	}
	
	.testimonial-rating i {
		font-size: 1rem;
	}
	
	.testimonial-text {
		font-size: 0.9rem;
		margin-bottom: 1.25rem;
	}
	
	.testimonial-author {
		padding-top: 0.875rem;
	}
	
	.testimonial-avatar {
		width: 42px;
		height: 42px;
	}
	
	.testimonial-name {
		font-size: 0.9rem;
	}
	
	.testimonial-date {
		font-size: 0.75rem;
	}
	
	.tours {
		padding: 3rem 0;
	}
	
	.tours .container {
		padding: 0 1rem;
	}
	
	.section-header {
		margin-bottom: 2rem;
	}
	
	.section-header h2 {
		font-size: 1.75rem;
	}
	
	.section-header p {
		font-size: 1rem;
	}
	
	.section-desc {
		max-width: 100%;
	}
	
	#testimonialSlider {
		padding: 0.75rem 0 2.5rem;
	}
	
	#testimonialSlider .splide__arrow {
		width: 40px;
		height: 40px;
	}
	
	#testimonialSlider .splide__arrow svg {
		width: 16px;
		height: 16px;
	}
	
	.review-cta {
		flex-direction: column;
		gap: 0.75rem;
		margin-top: 2rem;
	}
	
	.review-btn {
		width: 100%;
		max-width: 100%;
		justify-content: center;
		padding: 0.75rem 1.25rem;
	}
	
	.review-btn img {
		width: 22px;
		height: 22px;
	}
	
	.stats-section {
		margin-bottom: 3rem;
	}
	
	.stats-section::before {
		opacity: 1 !important;
		z-index: 0;
	}
	
	.stats-section::after {
		opacity: 1 !important;
		z-index: 1;
		display: block;
	}
	
	.stats-section .container {
		padding: 2rem 1rem;
	}
	
	.stats-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
		margin-top: 1.5rem;
	}
	
	.stat-box {
		padding: 1.5rem 1rem;
	}
	
	.stat-icon {
		width: 50px;
		height: 50px;
		margin-bottom: 0.75rem;
	}
	
	.stat-icon i {
		font-size: 1.75rem;
	}
	
	.stat-number {
		font-size: 1.75rem;
	}
	
	.stat-label {
		font-size: 0.85rem;
	}
	
	.tour-image {
		height: 180px;
	}
	
	.tour-date {
		top: 0.6rem;
		right: 0.6rem;
		font-size: 0.7rem;
		padding: 0.35rem 0.65rem;
	}
	
	.tour-date i {
		font-size: 0.8rem;
	}
	
	.tour-hover {
		bottom: 0.75rem;
		left: 0.5rem;
		right: 0.5rem;
		padding: 0.75rem 0.875rem;
	}
	
	.tour-hover-title {
		font-size: 0.9rem;
		margin-bottom: 0.3rem;
	}
	
	.tour-hover p {
		font-size: 0.75rem;
		margin-bottom: 0.5rem;
	}
	
	.tour-hover-cta {
		padding: 0.45rem 0.5rem;
		font-size: 0.75rem;
	}
	
	.tour-hover-cta i {
		font-size: 1rem;
	}
	
	.tour-title {
		font-size: 1rem;
	}
	
	.tour-price {
		font-size: 1.1rem;
	}
	
	.tours-cta {
		margin-top: 2rem;
	}
	
	.btn-tours-all {
		padding: 0.875rem 1.5rem;
		font-size: 0.95rem;
		width: 100%;
		justify-content: center;
	}
	
	.tour-date {
		top: 0.6rem;
		right: 0.6rem;
		font-size: 0.7rem;
		padding: 0.35rem 0.65rem;
	}
	
	.tour-date i {
		font-size: 0.8rem;
	}
	
	.tour-hover {
		bottom: 0.75rem;
		left: 0.5rem;
		right: 0.5rem;
		padding: 0.75rem 0.875rem;
	}
	
	.tour-hover-title {
		font-size: 0.9rem;
		margin-bottom: 0.3rem;
	}
	
	.tour-hover p {
		font-size: 0.75rem;
		margin-bottom: 0.5rem;
	}
	
	.tour-hover-cta {
		padding: 0.45rem 0.5rem;
		font-size: 0.75rem;
	}
	
	.tour-hover-cta i {
		font-size: 1rem;
	}
	
	.testimonial-card {
		padding: 1.5rem;
	}
	
	.testimonial-text {
		font-size: 0.9rem;
	}
	
	.testimonial-name {
		font-size: 0.9rem;
	}
	
	.testimonial-date {
		font-size: 0.75rem;
	}
	
	.review-cta {
		flex-direction: column;
		gap: 0.75rem;
		margin-top: 2rem;
	}
	
	.review-btn {
		width: 100%;
		max-width: 100%;
		justify-content: center;
	}
	
	.top-footer {
		padding: 2.5rem 0;
	}
	
	.middle-footer {
		padding: 2.5rem 0;
	}
	
	.middle-footer .row {
		row-gap: 2rem;
	}
	
	.middle-footer .footer-title {
		font-size: 0.95rem;
		padding: 0.65rem 0;
	}
	
	.middle-footer .footer-title::after {
		font-size: 1.15rem;
	}
	
	.footer-social {
		gap: 0.5rem;
	}
	
	.social-link {
		width: 36px;
		height: 36px;
		font-size: 1.1rem;
	}
}

@media (max-width: 576px) {
	#header .container {
		padding: 0 0.75rem;
	}
	
	#header .header-inner {
		gap: 0.5rem;
	}
	
	#header .logo {
		flex-shrink: 1;
		min-width: 0;
	}
	
	#header .logo a {
		gap: 0.4rem;
	}
	
	#header .logo-icon {
		width: 38px;
		height: 38px;
		font-size: 1.1rem;
		flex-shrink: 0;
	}
	
	#header .logo-text {
		min-width: 0;
	}
	
	#header .logo-top {
		font-size: 0.55rem;
	}
	
	#header .logo-bottom {
		font-size: 0.85rem;
	}
	
	#header .header-actions {
		flex-shrink: 0;
	}
	
	#header .header-lang .flag-icon {
		max-width: 18px;
		max-height: 18px;
		width: auto;
		height: auto;
	}
	
	.hero {
		min-height: 350px;
		padding: 1.5rem 0;
	}
	
	.hero-title {
		font-size: 1.5rem;
		margin-bottom: 1.5rem;
		line-height: 1.3;
	}
	
	.hero-content {
		padding: 0 0.75rem;
	}

	#reservationTabs .nav-link {
		padding: 0.75rem 0.5rem;
		font-size: 0.85rem;
		display: block;
		text-align: center;
		justify-content: center;
	}
	
	#reservationTabs .nav-link span {
		display: flex;
		justify-content: center;
	}
	
	#reservationTabs .nav-link i {
		font-size: 1.25rem;
		display: flex;
		justify-content: center;
	}

	#reservationTabContent {
		padding: 1.25rem 1rem;
	}

	.transfer-form .form-group {
		height: 65px;
	}

	.btn-swap {
		height: 65px;
	}

	.btn-search {
		height: 65px;
	}

	.review-cta {
		flex-direction: column;
		align-items: center;
		gap: 0.75rem;
		margin-top: 2rem;
	}
	
	.review-btn {
		width: 100%;
		max-width: 100%;
		justify-content: center;
		padding: 0.75rem 1.25rem;
	}
	
	.review-btn img {
		width: 22px;
		height: 22px;
	}
	
	.testimonial-card {
		padding: 1.5rem;
	}
	
	.testimonial-source img {
		height: 24px;
	}
	
	.testimonial-rating {
		margin-bottom: 0.875rem;
	}
	
	.testimonial-rating i {
		font-size: 1rem;
	}
	
	.testimonial-text {
		font-size: 0.9rem;
		margin-bottom: 1.25rem;
	}
	
	.testimonial-author {
		padding-top: 0.875rem;
	}
	
	.testimonial-avatar {
		width: 42px;
		height: 42px;
	}
	
	.testimonial-name {
		font-size: 0.9rem;
	}
	
	.testimonial-date {
		font-size: 0.75rem;
	}
	
	#testimonialSlider {
		padding: 0.75rem 0 2.5rem;
	}
	
	.tours-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.tour-image {
		height: 160px;
	}
	
	.stats-section {
		margin-bottom: 0 !important;
		border-radius: 24px 24px 0px 0px;
	}
	.stats-section::before {
		border-radius: 24px 24px 0px 0px;
	}
	
	.stats-section::after {
		border-radius: 24px 24px 0px 0px;
		opacity: 1 !important;
		z-index: 1;
	}
	
	.stats-section .container {
		padding: 1.5rem 0.75rem;
	}
	
	.stats-grid {
		gap: 0.75rem;
		margin-top: 1rem;
	}
	
	.stat-box {
		padding: 1.25rem 0.75rem;
	}
	
	.stat-icon {
		width: 45px;
		height: 45px;
		margin-bottom: 0.5rem;
	}
	
	.stat-icon i {
		font-size: 1.5rem;
	}
	
	.stat-number {
		font-size: 1.5rem;
		margin-bottom: 0.25rem;
	}
	
	.stat-label {
		font-size: 0.8rem;
	}
	
	.top-footer {
		padding: 2rem 0;
	}
	
	.middle-footer {
		padding: 3rem 0;
		overflow-x: hidden;
		max-width: 100%;
	}
	
	.middle-footer .container {
		overflow-x: hidden;
		max-width: 100%;
	}
	
	.middle-footer .row {
		row-gap: 2rem;
		overflow-x: hidden;
		max-width: 100%;
		margin: 0;
	}
	
	.middle-footer .row > [class*="col-"] {
		overflow-x: hidden;
		max-width: 100%;
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}
	
	.middle-footer .footer-menu {
		padding-left: 0;
		margin-top: 1.5rem;
	}
	
	.middle-footer .row > [class*="col-"]:first-child .footer-menu {
		margin-top: 0;
	}
	
	.middle-footer .footer-title {
		font-size: 1rem;
		margin-bottom: 0;
		cursor: pointer;
		user-select: none;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 0.75rem 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
		transition: color 0.2s ease;
	}
	
	.middle-footer .footer-title::after {
		content: '+';
		font-size: 1.25rem;
		font-weight: 300;
		transition: transform 0.3s ease;
		color: #e53935;
	}
	
	.middle-footer .footer-title.active::after {
		transform: rotate(45deg);
	}
	
	.middle-footer .footer-title:hover {
		color: #e53935;
	}
	
	.middle-footer .footer-links {
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease, opacity 0.3s ease;
		opacity: 0;
		margin-top: 0;
	}
	
	.middle-footer .footer-menu.active .footer-links {
		max-height: 500px;
		opacity: 1;
		margin-top: 0.5rem;
	}
	
	.footer-about {
		margin-top: 1.5rem;
	}
	
	.footer-desc {
		max-width: 100%;
		font-size: 0.8rem;
	}
	
	.top-footer .footer-title,
	.bottom-footer .footer-title {
		font-size: 1rem;
		margin-bottom: 1rem;
	}
	
	.footer-links li a {
		font-size: 0.85rem;
	}
	
	.contact-item {
		padding: 0.4rem 0;
	}
	
	.contact-icon {
		width: 32px;
		height: 32px;
	}
	
	.contact-icon i {
		font-size: 1rem;
	}
	
	.contact-label {
		font-size: 0.7rem;
	}
	
	.contact-value {
		font-size: 0.85rem;
	}
	
	.bottom-footer {
		padding: 1.25rem 0;
	}
	
	.bottom-footer .container {
		flex-direction: column;
		gap: 1rem;
		text-align: center;
		padding: 0 0.75rem;
	}
	
	.copyright {
		text-align: center;
	}
	
	.copyright p {
		font-size: 0.8rem;
	}
	
	.footer-image {
		text-align: center;
	}
	
	.bottom-footer .row {
		flex-direction: column;
		gap: 1rem;
		align-items: center;
		text-align: center;
	}
	
	.bottom-footer .row > [class*="col-"] {
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
		padding: 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	
	.bottom-footer .copyright {
		width: 100%;
	}
	
	.bottom-footer .footer-payment,
	.bottom-footer .footer-tursab {
		width: 100%;
		justify-content: center;
	}
	
	.tour-content {
		padding: 1rem 1.25rem;
	}
	
	.tour-title {
		font-size: 0.95rem;
		margin-bottom: 0.5rem;
	}
	
	.tour-price {
		font-size: 1rem;
	}
	
	.tour-person {
		font-size: 0.8rem;
	}
	
	.tour-date {
		top: 0.5rem;
		right: 0.5rem;
		font-size: 0.7rem;
		padding: 0.3rem 0.6rem;
	}
	
	.tour-date i {
		font-size: 0.75rem;
	}
	
	.tour-hover {
		bottom: 0.75rem;
		left: 0.5rem;
		right: 0.5rem;
		padding: 0.75rem 0.875rem;
	}
	
	.tour-hover-title {
		font-size: 0.9rem;
		margin-bottom: 0.3rem;
	}
	
	.tour-hover p {
		font-size: 0.75rem;
		margin-bottom: 0.5rem;
	}
	
	.tour-hover-cta {
		padding: 0.45rem 0.5rem;
		font-size: 0.75rem;
	}
	
	.tour-hover-cta i {
		font-size: 1rem;
	}
	
	.stats-section {
		margin-bottom: 2.5rem;
	}
	
	.stats-section::before {
		opacity: 1 !important;
		z-index: 0;
	}
	
	.stats-section::after {
		opacity: 1 !important;
		z-index: 1;
		display: block;
	}
	
	.stats-section .container {
		padding: 1.5rem 0.75rem;
	}
	
	.stats-grid {
		gap: 0.75rem;
		margin-top: 1rem;
	}
	
	.stat-box {
		padding: 1.25rem 0.75rem;
	}
	
	.stat-icon {
		width: 45px;
		height: 45px;
		margin-bottom: 0.5rem;
	}
	
	.stat-icon i {
		font-size: 1.5rem;
	}
	
	.stat-number {
		font-size: 1.5rem;
		margin-bottom: 0.25rem;
	}
	
	.stat-label {
		font-size: 0.8rem;
	}
	
	.top-footer {
		padding: 2.5rem 0;
	}
	
	.top-footer .container {
		padding: 0 0.75rem;
	}
	
	.middle-footer {
		padding: 3rem 0;
		overflow-x: hidden;
		max-width: 100%;
	}
	
	.middle-footer .container {
		padding: 0 0.75rem;
		overflow-x: hidden;
		max-width: 100%;
	}
	
	.middle-footer .row {
		row-gap: 0;
		overflow-x: hidden;
		max-width: 100%;
		margin: 0;
	}
	
	.middle-footer .row > [class*="col-"] {
		overflow-x: hidden;
		max-width: 100%;
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}
	
	.middle-footer .footer-menu {
		padding-left: 0;
		margin-top: 1.5rem;
	}
	
	.middle-footer .row > [class*="col-"]:first-child .footer-menu {
		margin-top: 0;
	}
	
	.middle-footer .footer-title {
		font-size: 1rem;
		margin-bottom: 0;
		cursor: pointer;
		user-select: none;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 0.75rem 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
		transition: color 0.2s ease;
	}
	
	.middle-footer .footer-title::after {
		content: '+';
		font-size: 1.25rem;
		font-weight: 300;
		transition: transform 0.3s ease;
		color: #e53935;
	}
	
	.middle-footer .footer-title.active::after {
		transform: rotate(45deg);
	}
	
	.middle-footer .footer-title:hover {
		color: #e53935;
	}
	
	.middle-footer .footer-links {
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease, opacity 0.3s ease;
		opacity: 0;
		margin-top: 0;
	}
	
	.middle-footer .footer-menu.active .footer-links {
		max-height: 500px;
		opacity: 1;
		margin-top: 0.5rem;
	}
	
	.footer-about {
		margin-top: 1.5rem;
	}
	
	.footer-desc {
		max-width: 100%;
		font-size: 0.8rem;
	}
	
	.top-footer .footer-title,
	.bottom-footer .footer-title {
		font-size: 1rem;
		margin-bottom: 1rem;
	}
	
	.footer-links li a {
		font-size: 0.85rem;
	}
	
	.contact-item {
		padding: 0.4rem 0;
	}
	
	.contact-icon {
		width: 32px;
		height: 32px;
	}
	
	.contact-icon i {
		font-size: 1rem;
	}
	
	.contact-label {
		font-size: 0.7rem;
	}
	
	.contact-value {
		font-size: 0.85rem;
	}
	
	.bottom-footer {
		padding: 1.25rem 0;
	}
	
	.bottom-footer .container {
		padding: 0 0.75rem;
	}
	
	.bottom-footer .row {
		flex-direction: column;
		gap: 1rem;
		align-items: center;
		text-align: center;
	}
	
	.bottom-footer .row > [class*="col-"] {
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
		padding: 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	
	.copyright {
		text-align: center;
		width: 100%;
	}
	
	.copyright p {
		font-size: 0.8rem;
		text-align: center;
	}
	
	.footer-image {
		text-align: center;
	}
	
	.footer-payment,
	.footer-tursab {
		justify-content: center;
		width: 100%;
	}
	
	.footer-payment img,
	.footer-tursab img {
		max-height: 36px;
		width: auto;
	}

	.floating-actions {
		right: 16px;
		bottom: 16px;
		gap: 10px;
	}

	.fab {
		width: 52px;
		height: 52px;
	}
	
	.auth-modal .row {
		margin: 0;
	}
	
	.auth-modal .row > [class*="col-"] {
		padding: 0;
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
	}
	
	.auth-modal-form {
		padding: 1.5rem;
		width: 100%;
		max-width: 100%;
	}
	
	.auth-modal-header {
		margin-bottom: 1.25rem;
	}
	
	.auth-modal-header h4 {
		font-size: 1.25rem;
	}
	
	.auth-modal-header p {
		font-size: 0.8rem;
	}
	
	.auth-form-group {
		margin-bottom: 0.875rem;
	}
	
	.auth-form-group label {
		font-size: 0.75rem;
		margin-bottom: 0.35rem;
	}
	
	.auth-input-wrapper input {
		padding: 0.65rem 0.875rem 0.65rem 2.5rem;
		font-size: 0.85rem;
	}
	
	.auth-input-wrapper > i {
		left: 0.875rem;
		font-size: 1rem;
	}
	
	.auth-password-toggle {
		right: 0.65rem;
		font-size: 1rem;
	}
	
	.auth-phone-wrapper {
		flex-direction: row;
		gap: 0.4rem;
		flex-wrap: nowrap;
	}
	
	.auth-phone-wrapper > i {
		left: 0.875rem;
		top: 50%;
		transform: translateY(-50%);
	}
	
	.auth-country-code {
		padding: 0.65rem 1.5rem 0.65rem 2.5rem;
		font-size: 0.8rem;
		width: auto;
		min-width: 110px;
		flex-shrink: 0;
	}
	
	.auth-phone-wrapper input {
		padding-left: 1rem;
		font-size: 0.85rem;
		flex: 1;
		min-width: 0;
	}
	
	.auth-checkbox {
		font-size: 0.8rem;
	}
	
	.auth-submit-btn {
		padding: 0.75rem;
		font-size: 0.9rem;
	}
	
	.auth-social-btn {
		padding: 0.65rem 0.875rem;
		font-size: 0.8rem;
	}
	
	.auth-switch {
		margin-top: 1.25rem;
		padding-top: 1.25rem;
	}
	
	.auth-switch span,
	.auth-switch button {
		font-size: 0.8rem;
	}
	
	.auth-modal-close {
		top: 0.5rem;
		right: 0.5rem;
		width: 32px;
		height: 32px;
		font-size: 0.9rem;
	}
}

@media (max-width: 480px) {
	#header .container {
		padding: 0 0.5rem;
	}
	
	#header .header-inner {
		gap: 0.4rem;
	}
	
	#header .logo {
		flex-shrink: 1;
		min-width: 0;
	}
	
	#header .logo a {
		gap: 0.35rem;
	}
	
	#header .logo-icon {
		width: 34px;
		height: 34px;
		font-size: 1rem;
		flex-shrink: 0;
	}
	
	#header .logo-text {
		min-width: 0;
	}
	
	#header .logo-top {
		font-size: 0.5rem;
	}
	
	#header .logo-bottom {
		font-size: 0.8rem;
	}
	
	#header .header-actions {
		padding-left: 0.4rem;
		gap: 0.3rem;
		border-left: none;
		flex-shrink: 0;
	}
	
	#header .header-lang .flag-icon {
		max-width: 16px;
		max-height: 16px;
		width: auto;
		height: auto;
	}
	
	#header .header-actions .header-lang {
		padding-left: 0;
	}
	
	#header .header-lang .lang-btn {
		width: 36px;
		height: 36px;
		padding: 0;
		border-radius: 8px;
		background: transparent;
		font-size: 0.8rem;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: all 0.2s ease;
	}
	
	#header .header-lang .lang-btn:hover {
		border-color: #e53935;
		color: #e53935;
		background: rgba(229, 57, 53, 0.08);
	}
	
	#header .header-lang .lang-btn span {
		display: none;
	}
	
	#header .header-lang .flag-icon {
		width: 16px;
		height: 16px;
		margin: 0;
	}
	
	#header .btn-register,
	#header .btn-login {
		width: 36px;
		height: 36px;
		padding: 0;
		border-radius: 8px;
		font-size: 0.9rem;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: all 0.2s ease;
	}
	
	#header .btn-register:hover,
	#header .btn-login:hover {
		border-color: #e53935;
		color: #e53935;
		background: rgba(229, 57, 53, 0.08);
	}
	
	#header .btn-register span,
	#header .btn-login span {
		display: none;
	}
	
	#header .btn-register i,
	#header .btn-login i {
		font-size: 1rem;
		margin: 0;
	}
	
	#header .mobile-menu-toggle {
		width: 36px;
		height: 36px;
		font-size: 1.15rem;
		margin-left: 0.4rem;
	}
	
	#header .mobile-menu ul li a {
		padding: 0.875rem 1rem;
		font-size: 0.9rem;
	}
	
	.hero {
		min-height: 320px;
		padding: 1.25rem 0;
	}
	
	.hero-title {
		margin-bottom: 1.25rem;
	}
	
	.hero-content {
		padding: 0 0.5rem;
	}
	
	#reservationTabs {
		padding: 0.4rem;
		gap: 0.4rem;
	}
	
	#reservationTabs .nav-link {
		padding: 0.65rem 0.4rem;
		font-size: 0.8rem;
	}
	
	#reservationTabContent {
		padding: 1rem 0.75rem;
		margin-top: -1px;
	}
	
	.transfer-form .form-group {
		padding: 2.5rem 1rem;
	}
	
	.transfer-form .form-group label {
		font-size: 0.7rem;
		margin-bottom: 0.4rem;
	}
	
	.transfer-form .form-group input,
	.transfer-form .form-group select {
		font-size: 0.85rem;
	}
	
	.btn-swap {
		height: 60px;
		width: 44px;
	}
	
	.btn-search {
		height: 60px;
		width: 100%;
		font-size: 1.35rem;
	}
	
	.testimonials {
		padding: 2rem 0;
	}
	
	.testimonials .container {
		padding: 0 0.5rem;
	}
	
	.section-header {
		margin-bottom: 1.25rem;
	}
	
	.section-header h2 {
		font-size: 1.35rem;
	}
	
	.section-header p {
		font-size: 0.875rem;
	}
	
	.testimonial-card {
		padding: 1.25rem;
	}
	
	.testimonial-text {
		font-size: 0.85rem;
	}
	
	.tours {
		padding: 2rem 0;
	}
	
	.tours .container {
		padding: 0 0.5rem;
	}
	
	.tour-image {
		height: 150px;
	}
	
	.tour-date {
		top: 0.4rem;
		right: 0.4rem;
		font-size: 0.65rem;
		padding: 0.25rem 0.5rem;
	}
	
	.tour-date i {
		font-size: 0.7rem;
	}
	
	.tour-content {
		padding: 0.875rem 1rem;
	}
	
	.tour-title {
		font-size: 0.9rem;
		margin-bottom: 0.4rem;
	}
	
	.tour-price {
		font-size: 0.95rem;
	}
	
	.tour-person {
		font-size: 0.75rem;
	}
	
	.tour-hover {
		bottom: 0.5rem;
		left: 0.4rem;
		right: 0.4rem;
		padding: 0.65rem 0.75rem;
	}
	
	.tour-hover-title {
		font-size: 0.85rem;
		margin-bottom: 0.25rem;
	}
	
	.tour-hover p {
		font-size: 0.7rem;
		margin-bottom: 0.4rem;
	}
	
	.tour-hover-cta {
		padding: 0.4rem 0.45rem;
		font-size: 0.7rem;
	}
	
	
	
	.stats-section::before {
		opacity: 1 !important;
		z-index: 0;
	}
	
	.stats-section::after {
		opacity: 1 !important;
		z-index: 1;
		display: block;
	}
	
	.stats-section .container {
		padding: 1.25rem 0.5rem;
	}
	
	.stat-box {
		padding: 1rem 0.5rem;
	}
	
	.stat-icon {
		width: 40px;
		height: 40px;
		margin-bottom: 0.4rem;
	}
	
	.stat-icon i {
		font-size: 1.35rem;
	}
	
	.stat-number {
		font-size: 1.35rem;
		margin-bottom: 0.2rem;
	}
	
	.stat-label {
		font-size: 0.75rem;
	}
	
	.top-footer {
		padding: 2rem 0;
	}
	
	.top-footer .container {
		padding: 0 0.5rem;
	}
	
	.middle-footer {
		padding: 1rem 0 2rem;
		overflow-x: hidden;
		max-width: 100%;
	}
	
	.middle-footer .container {
		padding: 0 0.5rem;
		overflow-x: hidden;
		max-width: 100%;
	}
	
	.middle-footer .row {
		overflow-x: hidden;
		max-width: 100%;
		margin: 0;
	}
	
	.middle-footer .row > [class*="col-"] {
		overflow-x: hidden;
		max-width: 100%;
		padding-left: 0.5rem;
		padding-right: 0.5rem;
	}
	
	.middle-footer .row > [class*="col-"]:first-child .footer-menu {
		margin-top: 0;
	}
	
	.middle-footer .footer-title {
		font-size: 0.9rem;
		padding: 0.6rem 0;
	}
	
	.middle-footer .footer-title::after {
		font-size: 1.1rem;
	}
	
	.top-footer .footer-title,
	.bottom-footer .footer-title {
		font-size: 0.9rem;
		margin-bottom: 0.875rem;
	}
	
	.footer-links li a {
		font-size: 0.8rem;
	}
	
	.footer-desc {
		font-size: 0.75rem;
	}
	
	.contact-icon {
		width: 28px;
		height: 28px;
	}
	
	.contact-icon i {
		font-size: 0.9rem;
	}
	
	.contact-label {
		font-size: 0.65rem;
	}
	
	.contact-value {
		font-size: 0.75rem;
	}
	
	.social-link {
		width: 32px;
		height: 32px;
		font-size: 1rem;
	}
	
	.bottom-footer {
		padding: 1rem 0;
	}
	
	.bottom-footer .container {
		padding: 0 0.5rem;
	}
	
	.bottom-footer .row {
		gap: 0.75rem;
	}
	
	.bottom-footer .row > [class*="col-"] {
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
		padding: 0;
	}
	
	.copyright {
		width: 100%;
	}
	
	.copyright p {
		font-size: 0.75rem;
		text-align: center;
	}
	
	.footer-payment,
	.footer-tursab {
		width: 100%;
		justify-content: center;
	}
	
	.footer-payment img,
	.footer-tursab img {
		max-height: 28px;
		width: auto;
	}
	
	.floating-actions {
		right: 12px;
		bottom: 12px;
		gap: 8px;
	}
	
	.fab {
		width: 48px;
		height: 48px;
		font-size: 1.4rem;
	}
	
	.auth-modal .row {
		margin: 0;
	}
	
	.auth-modal .row > [class*="col-"] {
		padding: 0;
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
	}
	
	.auth-modal-form {
		padding: 1.25rem;
		width: 100%;
		max-width: 100%;
	}
	
	.auth-modal-header h4 {
		font-size: 1.15rem;
	}
	
	.auth-modal-header p {
		font-size: 0.75rem;
	}
	
	.auth-input-wrapper input {
		padding: 0.6rem 0.75rem 0.6rem 2.25rem;
		font-size: 0.8rem;
	}
	
	.auth-input-wrapper > i {
		left: 0.75rem;
		font-size: 0.95rem;
	}
	
	.auth-phone-wrapper {
		flex-direction: row;
		gap: 0.35rem;
		flex-wrap: nowrap;
	}
	
	.auth-phone-wrapper > i {
		left: 0.75rem;
		top: 50%;
		transform: translateY(-50%);
	}
	
	.auth-country-code {
		padding: 0.6rem 1.25rem 0.6rem 2.25rem;
		font-size: 0.75rem;
		width: auto;
		min-width: 100px;
		flex-shrink: 0;
	}
	
	.auth-phone-wrapper input {
		padding-left: 1rem;
		flex: 1;
		min-width: 0;
		font-size: 0.8rem;
	}
	
	.auth-submit-btn {
		padding: 0.7rem;
		font-size: 0.85rem;
	}
	
	.auth-social-btn {
		padding: 0.6rem 0.75rem;
		font-size: 0.75rem;
	}
}
