:root {
	/* X-Dynamics Color Palette */
	--x-dynamics-red: #b71234;
	--x-dynamics-red-hover: #8f0e28;
	--x-dynamics-black: #1a1a1a;
	--x-dynamics-gray: #f5f5f5;
	--x-dynamics-white: #ffffff;
}

/* Background Colors */
.bg-x-red {
	background-color: var(--x-dynamics-red) !important;
}

/* Tüm bg-x-red butonları için otomatik hover efekti */
:is(a, button).bg-x-red:hover {
	background-color: var(--x-dynamics-red-hover) !important;
}


.bg-x-black {
	background-color: var(--x-dynamics-black) !important;
}

.bg-x-gray {
	background-color: var(--x-dynamics-gray) !important;
}

.bg-x-white {
	background-color: var(--x-dynamics-white) !important;
}

/* Text Colors */
.text-x-red {
	color: var(--x-dynamics-red) !important;
}

.text-x-black {
	color: var(--x-dynamics-black) !important;
}

.text-x-white {
	color: var(--x-dynamics-white) !important;
}

/* Fill Colors (for SVG) */
.fill-x-red {
	fill: var(--x-dynamics-red) !important;
}

/* Background with Opacity */
.bg-x-red\/10 {
	background-color: rgba(255, 107, 53, 0.1);
}

/* Gradient Colors */
.from-x-red {
	--tw-gradient-from: var(--x-dynamics-red);
	--tw-gradient-to: transparent;
	--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

/* Hover States */
.hover\:bg-x-red-hover:hover {
	background-color: var(--x-dynamics-red-hover);
}

.hover\:bg-x-white:hover {
	background-color: var(--x-dynamics-white) !important;
}

.hover\:text-x-red:hover {
	color: var(--x-dynamics-red);
}

/* Button Transitions - Tüm butonlar için yavaş renk geçişi */
button,
a {
	transition: background-color 0.4s ease, color 0.3s ease, border-color 0.3s ease, opacity 0.3s ease;
}

/* Mega Menu Styles */
.mega-menu {
	position: absolute;
	left: 0;
	margin-top: 0.75rem;
	width: 600px;
	background-color: white;
	border-radius: 0.375rem;
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
	border: 1px solid #e5e7eb;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s, visibility 0.2s, width 0.2s;
	z-index: 50;
}

.mega-menu-group:hover .mega-menu {
	opacity: 1;
	visibility: visible;
}

.mega-menu-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 0;
	transition: grid-template-columns 0.2s;
}

.mega-menu-grid.expanded {
	grid-template-columns: repeat(8, minmax(0, 1fr));
}

.mega-menu-links {
	grid-column: span 2;
	padding: 1.5rem;
}

.mega-menu-links ul {
	display: flex;
	flex-direction: column;
	gap: 0;
	font-size: 15px;
}

.mega-menu-sub {
	grid-column: span 2;
	padding: 1.5rem;
	border-left: 1px solid #e5e7eb;
	display: none;
}

.mega-menu-sub ul {
	display: flex;
	flex-direction: column;
	gap: 0;
	font-size: 14px;
}

.mega-menu-sub a {
	display: block;
	padding: 0.75rem 1rem;
	border-radius: 0.375rem;
	transition: background-color 0.2s, color 0.2s;
	font-weight: 400;
	color: #4b5563;
}

.mega-menu-sub a:hover,
.mega-menu-sub a.active {
	background-color: #f9fafb;
	color: var(--x-dynamics-red);
}

.mega-menu-links a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.75rem 1rem;
	border-radius: 0.375rem;
	transition: background-color 0.2s, color 0.2s;
	font-weight: 600; /* üst seviye linkler daha belirgin */
	position: relative;
}

/* Alt menülerin (ikinci seviye) normal ağırlıkta görünmesi için */
.mega-menu-links ul ul a {
	font-weight: 400;
	padding-top: 0.3rem;
	padding-bottom: 0.3rem;
	padding-left: 0.5rem; /* içe doğru girinti - azaltıldı */
	font-size: 14px;
	color: #4b5563; /* daha gri ton, ana başlıktan ayrışsın */
}

/* Alt menülerde sağdaki ok ikonunu kaldır, daha sade görünüm */
.mega-menu-links ul ul a::after {
	content: none;
}

/* Alt menü grubunu görsel olarak ayırmak için ince sol çizgi */
.mega-menu-links ul ul {
	border-left: 1px solid #e5e7eb;
	margin-left: 0.75rem;
	padding-left: 0.25rem;
}

.mega-menu-links a::after {
	content: '';
	width: 16px;
	height: 16px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5l7 7-7 7'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	opacity: 0.5;
	transition: opacity 0.2s, transform 0.2s;
	flex-shrink: 0;
	margin-left: 0.5rem;
}

.mega-menu-links a:hover,
.mega-menu-links a.active {
	background-color: #f9fafb;
	color: var(--x-dynamics-red);
}

.mega-menu-links a:hover::after,
.mega-menu-links a.active::after {
	opacity: 1;
	transform: translateX(3px);
}

.mega-menu-image {
	grid-column: span 4;
	padding: 1.5rem;
	border-left: 1px solid #e5e7eb;
}

.mega-menu-image-box {
	height: 10rem;
	width: 100%;
	border-radius: 0.375rem;
	background-color: #f3f4f6;
	overflow: hidden;
}

.mega-menu-image-box > div {
	height: 100%;
	width: 100%;
	background-size: cover;
	background-position: center;
}

.mega-menu-image-text {
	font-size: 0.75rem;
	color: #6b7280;
	margin-top: 0.75rem;
}

/* Sticky header mega menus - center under button, prevent overflow */
#sticky-mini .mega-menu {
	left: 50%;
	right: auto;
	transform: translateX(-50%);
	max-width: calc(100vw - 2rem);
}

/* Ensure mega menu doesn't overflow on the left */
#sticky-mini .mega-menu-group:first-child .mega-menu,
#sticky-mini .mega-menu-group:nth-child(2) .mega-menu {
	left: 0;
	transform: translateX(0);
}

/* Ensure mega menu doesn't overflow on the right */
#sticky-mini .mega-menu-group:last-child .mega-menu,
#sticky-mini .mega-menu-group:nth-last-child(2) .mega-menu {
	left: auto;
	right: 0;
	transform: translateX(0);
}

/* Slider Styles */
.slider-content-container {
	position: relative;
	min-height: 400px;
}

.slider-slide {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	opacity: 0;
	transform: translateX(20px);
	transition: opacity 0.5s ease, transform 0.5s ease;
	pointer-events: none;
	visibility: hidden;
}

.slider-slide.active {
	position: relative;
	opacity: 1;
	transform: translateX(0);
	pointer-events: auto;
	visibility: visible;
}

.slider-bg {
	transition: opacity 0.5s ease;
}

.slider-pagination {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
}

/* Subtitle Style */
.subtitle {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: #6b7280;
	letter-spacing: 0.05em;
	font-weight: 400;
}

/* Alpine.js x-cloak - Hide elements until Alpine.js is loaded */
[x-cloak] {
	display: none !important;
}

/* Tab Content Container - Responsive min-height */
.tab-content-container {
	min-height: auto;
}

@media (min-width: 768px) {
	.tab-content-container {
		min-height: 200px;
	}
}

@media (min-width: 1024px) {
	.tab-content-container {
		min-height: 250px;
	}
}

/* Hide scrollbar for tab navigation */
.scrollbar-hide {
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.scrollbar-hide::-webkit-scrollbar {
	display: none;
}

/* Key Benefits Section - Mobile Padding */
.key-benefits-section {
	padding-top: 500px;
	padding-bottom: 100px;
}

/* Hamburger Menu Styles */
.hamburger-menu {
	display: none;
	position: relative;
	width: 40px;
	height: 40px;
	background: transparent;
	border: 1px solid #e5e7eb;
	border-radius: 0.375rem;
	cursor: pointer;
	transition: all 0.3s ease;
	justify-content: center;
	align-items: center;
}

/* Normal header: Show hamburger menu only on mobile (below lg breakpoint) */
header .hamburger-menu {
	display: flex;
}

@media (min-width: 1024px) {
	/* Hide hamburger menu in normal header on desktop */
	header .hamburger-menu {
		display: none !important;
	}
}

.hamburger-menu:hover {
	border-color: #d1d5db;
	background-color: #f9fafb;
}

.hamburger-menu span {
	display: block;
	position: absolute;
	width: 20px;
	height: 2px;
	background-color: #374151;
	transition: all 0.3s ease;
	border-radius: 2px;
}

.hamburger-menu span:nth-child(1) {
	top: 12px;
}

.hamburger-menu span:nth-child(2) {
	top: 19px;
}

.hamburger-menu span:nth-child(3) {
	top: 26px;
}

.hamburger-menu.active span:nth-child(1) {
	top: 19px;
	transform: rotate(45deg);
}

.hamburger-menu.active span:nth-child(2) {
	opacity: 0;
}

.hamburger-menu.active span:nth-child(3) {
	top: 19px;
	transform: rotate(-45deg);
}

/* Sticky header: Show hamburger menu when max-width is 1400px or less */
@media (max-width: 1400px) {
	/* Show hamburger menu in sticky header */
	#sticky-mini .hamburger-menu {
		display: flex !important;
	}
	
	/* Hide desktop navigation in sticky header when hamburger menu is shown */
	#sticky-mini .desktop-nav {
		display: none !important;
	}
	
	/* Show sticky header mobile section up to 1400px */
	#sticky-mini .sticky-mobile-section {
		display: flex !important;
	}
	
	/* Hide sticky header desktop section when hamburger menu is shown */
	#sticky-mini .sticky-desktop-section {
		display: none !important;
	}
	
}

/* Sticky header: Hide hamburger menu on larger screens (above 1400px) */
@media (min-width: 1401px) {
	/* Hide hamburger menu in sticky header */
	#sticky-mini .hamburger-menu {
		display: none !important;
	}
	
	
	/* Show sticky header desktop section on larger screens */
	#sticky-mini .sticky-desktop-section {
		display: flex !important;
	}
	
	/* Hide sticky header mobile section on larger screens */
	#sticky-mini .sticky-mobile-section {
		display: none !important;
	}
}

/* Mobile Menu Styles */
.mobile-menu-main-item {
	display: block;
	width: 100%;
	border-bottom: 1px solid #e5e7eb;
}

.mobile-menu-main-item:last-child {
	border-bottom: none;
}

.mobile-menu-sub-item {
	display: block;
	width: 100%;
}

/* Alt menüler için sol çizgiye yakın padding */
.mobile-menu-sub-item.border-l-2 {
	padding-left: 0.75rem !important;
}

.mobile-menu-sub-item.border-l {
	padding-left: 1rem !important;
}

/* Mobile Language Selector Styles */
.mobile-language-selector {
	margin-bottom: 1rem;
}

.mobile-language-label {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	color: #6b7280;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 0.75rem;
}

.mobile-language-buttons {
	display: flex;
	gap: 0.5rem;
}

.mobile-language-btn {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.625rem 1rem;
	border-radius: 0.5rem;
	border: 2px solid #e5e7eb;
	background-color: #ffffff;
	color: #374151;
	font-size: 0.875rem;
	font-weight: 500;
	transition: all 0.2s ease;
	text-decoration: none;
}

.mobile-language-btn:hover {
	border-color: #d1d5db;
	background-color: #f9fafb;
	color: #111827;
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.mobile-language-btn.active {
	border-color: var(--x-dynamics-red);
	background-color: rgba(255, 107, 53, 0.1);
	color: var(--x-dynamics-red);
	font-weight: 600;
}

.mobile-language-btn.active:hover {
	border-color: var(--x-dynamics-red);
	background-color: rgba(255, 107, 53, 0.15);
	color: var(--x-dynamics-red);
}

.mobile-language-flag {
	width: 20px;
	height: 15px;
	flex-shrink: 0;
	object-fit: cover;
	border-radius: 2px;
}

.mobile-contact-btn {
	width: 100%;
	justify-content: center;
}

/* Social Icons */
.social-icon img {
	filter: brightness(0) saturate(100%) invert(60%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%);
	transition: filter 0.3s ease;
}

.social-icon:hover img {
	filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%);
}

/* Show mobile menu drawer and overlay on mobile and up to 1400px (for sticky header) */
@media (max-width: 1400px) {
	.mobile-menu-overlay,
	.mobile-menu-drawer {
		display: block;
	}
}

/* Hide mobile menu drawer and overlay above 1400px */
@media (min-width: 1401px) {
	.mobile-menu-overlay,
	.mobile-menu-drawer {
		display: none !important;
	}
}

/* File Input Custom Styling - Choose File Button */
input[type="file"]::file-selector-button {
	background-color: var(--x-dynamics-red) !important;
	color: white !important;
	border: none !important;
	padding: 0.625rem 1.5rem !important;
	border-radius: 0.5rem !important;
	font-size: 0.875rem !important;
	font-weight: 600 !important;
	margin-right: 1rem !important;
	cursor: pointer !important;
	transition: background-color 0.3s ease !important;
}

input[type="file"]::file-selector-button:hover {
	background-color: var(--x-dynamics-red-hover) !important;
}

/* Footer Equal Column Widths */
@media (min-width: 1024px) {
	.footer-columns-equal {
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: flex-start;
	}
	
	.footer-columns-equal > .footer-col {
		/* Footer link kolonlarını daha dar yap, tasarımdaki gibi sütun sütun dursun */
		flex: 0 0 150px !important;
		max-width: 200px !important;
		min-width: 0 !important;
	}
	
	/* Brand column (logo) - slightly smaller */
	.footer-columns-equal > .footer-col:first-child {
		/* Logo/slogan alanını sabitle ve yanında ekstra boşluk bırak */
		flex: 0 0 260px !important;
		max-width: 260px !important;
		min-width: 0 !important;
		margin-right: 100px; 
	}
}