.cta-text h3,
.hero-title {
	text-shadow: 0 .0625rem .125rem rgba(0, 0, 0, .25)
}

.cta-button,
.footer-nav a,
.partner-logo {
	text-decoration: none
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box
}

:root {
	--primary-color: #e69500;
	--primary-light: #ffddaa;
	--text-dark: #333333;
	--text-gray: #666666;
	--bg-light: #f8f9fa;
	--white: #ffffff;
	--border-radius: 20px;
	--transition: all 0.3s ease
}

body {
	font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	background-color: var(--bg-light);
	color: var(--text-dark);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	opacity: 1;
	transition: opacity .4s ease-in-out
}

.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background-color: var(--white);
	z-index: 1001;
	box-shadow: 0 .125rem .625rem rgba(0, 0, 0, .05);
	/*transition: transform .4s, box-shadow .3s;
	transform: translateY(0)
	*/
}

.header.header-hidden {
	transform: translateY(-100%)
}

.header-container {
	max-width: 90rem;
	margin: 0 auto;
	padding: .625rem 1rem
}

.header-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-height: 3.125rem;
	position: relative
}

.logo {
	height: 3.125rem;
	width: clamp(8rem, 15vw, 9.375rem);
	display: block;
	flex-shrink: 0;
	left: 0;
	z-index: 102
}

.footer-logo img,
.logo img,
.value-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain
}

.menu-toggle {
	display: flex
}

@media (min-width:1200px) {

	.header-right,
	.nav-menu {
		align-items: center;
		display: flex
	}

	.contact-button,
	.nav-menu a {
		font-weight: 500;
		text-decoration: none;
		white-space: nowrap
	}

	.menu-toggle {
		display: none !important
	}

	.nav-menu {
		display: flex !important;
		left: 50%;
		transform: translateX(-50%);
		gap: clamp(1rem, 2vw, 2rem);
		align-items: center
	}

	.nav-menu a {
		color: var(--text-gray);
		border-radius: .5rem;
		transition: var(--transition);
		font-size: clamp(0.9rem, .85vw, 0.9rem);
		padding: .3rem .4rem
	}

	.contact-button {
		color: var(--primary-color);
		border: 2px solid var(--primary-color);
		transition: var(--transition)
	}

	.nav-menu a:focus,
	.nav-menu a:hover {
		color: var(--primary-color);
		background-color: rgba(230, 149, 0, .1);
		outline: 0
	}

	.nav-menu a:focus-visible {
		outline: 2px solid var(--primary-color);
		outline-offset: 2px
	}

	.contact-button {
		display: block;
		right: 0;
		z-index: 102
	}

	.contact-button:focus,
	.contact-button:hover {
		background-color: var(--primary-color);
		color: var(--white);
		outline: 0;
		background-color: var(--primary-color);
		color: var(--white)
	}

	.nav-menu {
		flex-direction: row;
		position: static;
		background: 0 0;
		padding: 0;
		margin: 0 auto;
		gap: clamp(1rem, 2vw, 2rem);
		transform: none
	}

	.header-content {
		flex-wrap: nowrap
	}

	.header-right {
		gap: 1rem;
		flex-shrink: 0
	}

	.contact-button {
		position: static !important;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		font-size: clamp(.875rem, 1.2vw, 1rem);
		padding: .625rem 1.5rem;
		border-radius: 1.5625rem
	}

	.contact-button:focus-visible {
		outline: 2px solid var(--primary-color);
		outline-offset: 2px
	}
}

.mission-vision-card,
.stat-item {
	transition: opacity .8s, transform .8s
}

.feature-item span,
.hero-description,
.hero-title,
.value-card h5 {
	color: var(--text-dark)
}

.mission-vision-card,
.stat-item,
.value-card {
	transform: translateY(30px)
}

.hero-section {
	padding: clamp(2rem, 5vw, 3.125rem);
	min-height: clamp(40rem, 80vh, 62.5rem);
	display: flex;
	align-items: center;
	justify-content: center
}

.hero-container {
	max-width: 90rem;
	width: 100%;
	margin: 0 auto
}

.hero-content {
	display: flex;
	gap: clamp(2rem, 5vw, 3.125rem);
	align-items: center
}

.hero-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 3.125rem);
	margin-left: 1rem
}

.hero-title {
	font-size: clamp(2rem, 5vw, 4rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -.03125rem;
	animation: .8s ease-out fadeInUp
}

.hero-description {
	font-size: clamp(1rem, 2vw, 1.25rem);
	line-height: 1.6;
	animation: .8s ease-out .2s backwards fadeInUp
}

.hero-features {
	display: flex;
	gap: clamp(.75rem, 2vw, 1.25rem);
	flex-wrap: wrap;
	animation: .8s ease-out .4s backwards fadeInUp
}

.feature-item {
	display: flex;
	align-items: center;
	gap: .3125rem
}

.feature-item img {
	width: clamp(1.25rem, 2vw, 1.5rem);
	height: clamp(1.25rem, 2vw, 1.5rem)
}

.feature-item span {
	font-size: clamp(.875rem, 1.5vw, 1rem);
	letter-spacing: .0125rem
}

.hero-image {
	width: clamp(18rem, 40vw, 34.375rem);
	height: clamp(16rem, 35vw, 31.25rem);
	flex-shrink: 0;
	animation: 1s ease-out .6s backwards fadeIn
}

.image-placeholder,
.image-placeholder2,
.image-placeholder3 {
	width: 100%;
	height: 100%;
	opacity: .5;
	position: relative;
	border-radius: var(--border-radius)
}

.image-placeholder {
	background: url('./images/4239192635.png') center center/contain no-repeat
}

.image-placeholder2 {
	background: url('./images/4239192630.png') center center/contain no-repeat
}
.image-placeholder3 {
	background: url('./images/4239192639.png') center center/contain no-repeat
}
.divider {
	height: 1px;
	background: linear-gradient(90deg, transparent, #ddd, transparent);
	margin: 3rem 0
}

.stats-section {
	padding: clamp(3rem, 6vw, 4rem) 0;
	background-color: var(--white)
}

.stats-container {
	max-width: 90rem;
	margin: 0 auto;
	padding: 0 1.25rem;
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
	gap: 2rem
}

.stat-item {
	text-align: center;
	opacity: 0
}

.stat-number {
	font-size: clamp(2.5rem, 6vw, 3.5rem);
	font-weight: 700;
	color: var(--primary-color)
}

.stat-label {
	font-size: clamp(1rem, 2vw, 1.25rem);
	color: var(--text-gray);
	margin-top: .5rem
}

.contact-item a:focus,
.contact-item a:hover,
.highlight,
.partners-title .highlight,
.values-title .highlight {
	color: var(--primary-color)
}

.mission-vision-section {
	padding: clamp(3rem, 6vw, 4rem) 0
}

.mission-vision-container {
	max-width: 90rem;
	margin: 0 auto;
	padding: 0 1.25rem;
	display: flex;
	gap: clamp(2rem, 5vw, 4rem);
	flex-wrap: wrap;
	justify-content: center
}

.mission-vision-card {
	flex: 1;
	min-width: 280px;
	background: var(--white);
	padding: clamp(2rem, 4vw, 2.5rem);
	border-radius: var(--border-radius);
	box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
	opacity: 0
}

.mission-vision-card h3 {
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin-bottom: 1rem
}

.values-section {
	padding: clamp(3rem, 6vw, 4rem) 0;
	background-color: var(--bg-light)
}

.value-card,
.value-icon {
	background: var(--white)
}

.values-container {
	max-width: 90rem;
	margin: 0 auto;
	padding: 0 1.25rem;
	text-align: center
}

.values-title {
	font-size: clamp(2rem, 5vw, 3rem);
	margin-bottom: clamp(2rem, 5vw, 3rem);
	font-weight: 700
}

.cta-container,
.footer-container,
.values-grid {
	max-width: 90rem;
	margin: 0 auto
}

.values-title .highlight {
	font-weight: 900
}

.values-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: clamp(1.5rem, 3vw, 2rem)
}

@media (min-width:1025px) {
	.values-grid {
		grid-template-columns: repeat(3, 1fr)
	}
}

.value-card {
	padding: clamp(2rem, 4vw, 2.5rem);
	border-radius: 1.5rem;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .05);
	opacity: 0;
	transition: .4s;
	text-align: left;
	border: 3px solid transparent;
	display: flex;
	flex-direction: column;
	align-items: left;
	gap: 1rem
}

.value-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, .1);
	border-color: var(--primary-color)
}

.value-icon {
	width: 2.5rem;
	height: 2.5rem;
	flex-shrink: 0;
	padding: .5rem;
	border: 3px solid var(--primary-color);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center
}

.cta-content,
.cta-section {
	padding: clamp(2rem, 5vw, 3.125rem)
}

.footer-nav a,
.social-links a {
	transition: var(--transition);
	border-radius: .25rem
}

.value-card h5 {
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	margin: 0;
	font-weight: 600;
	letter-spacing: -.00625rem;
	line-height: 1.3
}

.value-card p {
	font-size: clamp(.875rem, 1.5vw, 1rem);
	line-height: 1.7;
	color: var(--text-gray);
	letter-spacing: .0125rem;
	margin: 0
}

.cta-content {
	background: linear-gradient(#fda 0, #fda 50%, rgba(255, 221, 170, .25) 100%);
	border-radius: clamp(1rem, 2vw, 1.5625rem);
	animation: .8s ease-out fadeInUp
}

.cta-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: clamp(1rem, 4vw, 3rem);
	flex-wrap: wrap
}

.cta-text {
	flex: 1;
	min-width: 280px
}

.cta-text h3 {
	font-size: clamp(1.8rem, 4vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -.01875rem;
	color: var(--text-dark);
	margin-bottom: .5rem
}

.cta-text p {
	font-size: clamp(1rem, 2vw, 1.25rem);
	line-height: 1.6;
	color: var(--text-dark);
	opacity: .9
}

.cta-button {
	background-color: var(--primary-color);
	color: var(--white);
	padding: clamp(.875rem, 2vw, 1rem) clamp(1.75rem, 4vw, 2.5rem);
	border-radius: 3rem;
	font-size: clamp(1rem, 1.8vw, 1.125rem);
	font-weight: 500;
	display: inline-block;
	transition: var(--transition);
	white-space: nowrap;
	flex-shrink: 0
}

.cta-button:focus,
.cta-button:hover {
	background-color: #d68800;
	transform: translateY(-.125rem);
	box-shadow: 0 .5rem 1rem rgba(230, 149, 0, .4)
}

.footer {
	background-color: var(--white);
	padding: clamp(1.5rem, 3vw, 1.875rem)
}

.footer-content {
	display: flex;
	gap: clamp(1rem, 2vw, .9375rem);
	margin-bottom: clamp(1rem, 2.5vw, 1.25rem);
	flex-wrap: wrap
}

.footer-column {
	flex: 1 1 clamp(12rem, 30%, 20rem);
	display: flex;
	flex-direction: column;
	gap: clamp(.75rem, 2vw, .9375rem);
	min-width: 12rem
}

.footer-logo {
	width: clamp(8rem, 15vw, 9.375rem);
	height: clamp(2.5rem, 5vw, 3.125rem)
}

.footer-column h5 {
	font-size: clamp(1.125rem, 2vw, 1.5rem);
	font-weight: 500;
	letter-spacing: -.00625rem;
	color: var(--text-dark)
}

.footer-nav {
	display: flex;
	flex-direction: column;
	gap: .3125rem
}

.footer-nav a {
	font-size: clamp(.9375rem, 1.8vw, 1.125rem);
	letter-spacing: .03125rem;
	color: var(--text-gray);
	padding: .3125rem 0
}

.footer-nav a:focus,
.footer-nav a:hover {
	color: var(--primary-color);
	padding-left: .3125rem;
	outline: 0
}

.footer-nav-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5rem 2rem;
	align-items: start
}

.footer-nav-grid a {
	justify-self: start
}

.contact-info {
	display: flex;
	flex-direction: column;
	gap: clamp(.75rem, 2vw, .9375rem)
}

.contact-item {
	display: flex;
	gap: .625rem;
	align-items: flex-start
}

.contact-item img {
	width: clamp(1.5rem, 3vw, 2rem);
	height: clamp(1.5rem, 3vw, 2rem);
	flex-shrink: 0
}

.contact-item a,
.contact-item p {
	font-size: clamp(.875rem, 1.5vw, 1rem);
	letter-spacing: .0125rem;
	color: var(--text-gray);
	text-decoration: none;
	line-height: 1.8
}

.footer-divider {
	height: .0625rem;
	background: linear-gradient(90deg, rgba(51, 51, 51, 0) 0, rgba(51, 51, 51, .15) 50%, rgba(51, 51, 51, 0) 100%);
	margin: clamp(1rem, 2.5vw, 1.25rem) 0
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem
}

.footer-bottom p {
	font-size: clamp(.75rem, 1.5vw, .875rem);
	letter-spacing: .0125rem;
	color: var(--text-gray)
}

.social-links {
	display: flex;
	gap: clamp(1rem, 2vw, 1.25rem)
}

.social-links a {
	width: clamp(1.25rem, 2.5vw, 1.5rem);
	height: clamp(1.25rem, 2.5vw, 1.5rem);
	display: flex;
	align-items: center;
	justify-content: center
}

.social-links a:focus,
.social-links a:hover {
	transform: translateY(-.1875rem)
}

.social-links img {
	width: 100%;
	height: 100%
}

@keyframes fadeIn {
	from {
		opacity: 0
	}

	to {
		opacity: 1
	}
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

@media (max-width:1024px) {
	.hero-content {
		flex-direction: column
	}

	.hero-image {
		width: 100%;
		max-width: 34.375rem
	}
}

@media (max-width:768px) {

	.menu-toggle.active span:nth-child(2),
	.nav-menu {
		opacity: 0
	}

	.logo,
	.nav-menu a {
		position: relative
	}

	.logo {
		z-index: 1003
	}

	.menu-toggle {
		position: fixed;
		top: 1rem;
		z-index: 1002;
		background: rgba(255, 255, 255, .95);
		backdrop-filter: blur(10px);
		-webkit-backdrop-filter: blur(10px);
		border-radius: 50%;
		width: 3.5rem;
		height: 3.5rem;
		padding: .75rem;
		box-shadow: 0 4px 16px rgba(0, 0, 0, .15);
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: .375rem;
		cursor: pointer;
		border: none
	}

	.menu-toggle span {
		width: 1.5rem;
		height: .1875rem;
		background-color: var(--text-dark);
		border-radius: 1.5625rem;
		transition: var(--transition);
		display: block;
		margin: 0 auto
	}

	.menu-toggle:focus span,
	.menu-toggle:hover span {
		background-color: var(--primary-color)
	}

	.menu-toggle:focus-visible {
		outline: 2px solid var(--primary-color);
		outline-offset: 2px
	}

	.menu-toggle.active span:first-child {
		transform: rotate(45deg) translate(.5rem, .5rem)
	}

	.menu-toggle.active span:nth-child(3) {
		transform: rotate(-45deg) translate(.5rem, -.5rem)
	}

	.nav-menu {
		position: fixed !important;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		background-color: rgba(255, 255, 255, .6);
		backdrop-filter: blur(10px);
		-webkit-backdrop-filter: blur(10px);
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 1rem;
		padding: 2rem 1rem 2rem;
		visibility: hidden;
		transition: opacity .4s, visibility .4s;
		z-index: 1000
	}

	.nav-menu.active {
		opacity: 1;
		visibility: visible
	}

	.nav-menu a {
		font-size: clamp(.65rem, 6vw, .8rem);
		font-weight: 400;
		color: #000 !important;
		text-decoration: none;
		padding: .3rem .5rem;
		border-radius: 1rem;
		transition: var(--transition);
		line-height: .45;
		letter-spacing: .05em;
		text-align: center
	}

	.nav-menu a:focus,
	.nav-menu a:hover {
		color: var(--primary-color) !important;
		background-color: rgba(230, 149, 0, .15)
	}

	.nav-menu a::after {
		content: '';
		position: absolute;
		bottom: .5rem;
		left: 50%;
		width: 0;
		height: .3rem;
		background-color: var(--primary-color);
		border-radius: .15rem;
		transition: width .3s;
		transform: translateX(-50%)
	}

	.nav-menu a:focus::after,
	.nav-menu a:hover::after {
		width: 0 !important;
	}

	.contact-button {
		display: none
	}

	.header-right {
		position: absolute;
		right: 5.5rem;
		top: 50%;
		transform: translateY(-50%);
		gap: .75rem
	}

	.lang-btn {
		padding: .3rem .7rem;
		font-size: .8125rem
	}

	.menu-toggle {
		right: 1rem
	}

	.cta-inner {
		flex-direction: column;
		text-align: center;
		gap: 1.5rem
	}

	.cta-button {
		align-self: center
	}

	.footer-nav-grid {
		gap: .5rem 1.5rem
	}

	.hero-features {
		flex-direction: column;
		gap: .625rem
	}

	.stats-container {
		justify-content: center
	}

	.stat-item {
		flex: 1 1 45%
	}
}

@media (max-width:1200px) {

	.menu-toggle.active span:nth-child(2),
	.nav-menu {
		opacity: 0
	}

	.logo,
	.nav-menu a {
		position: relative
	}

	.logo {
		z-index: 1003
	}

	.menu-toggle {
		position: fixed;
		top: 1rem;
		z-index: 1002;
		background: rgba(255, 255, 255, .95);
		backdrop-filter: blur(10px);
		-webkit-backdrop-filter: blur(10px);
		border-radius: 50%;
		width: 3.5rem;
		height: 3.5rem;
		padding: .75rem;
		box-shadow: 0 4px 16px rgba(0, 0, 0, .15);
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: .375rem;
		cursor: pointer;
		border: none
	}

	.menu-toggle span {
		width: 1.5rem;
		height: .1875rem;
		background-color: var(--text-dark);
		border-radius: 1.5625rem;
		transition: var(--transition);
		display: block;
		margin: 0 auto
	}

	.menu-toggle:focus span,
	.menu-toggle:hover span {
		background-color: var(--primary-color)
	}

	.menu-toggle:focus-visible {
		outline: 2px solid var(--primary-color);
		outline-offset: 2px
	}

	.menu-toggle.active span:first-child {
		transform: rotate(45deg) translate(.5rem, .5rem)
	}

	.menu-toggle.active span:nth-child(3) {
		transform: rotate(-45deg) translate(.5rem, -.5rem)
	}

	.nav-menu {
		position: fixed !important;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		background-color: rgba(255, 255, 255, .6);
		backdrop-filter: blur(10px);
		-webkit-backdrop-filter: blur(10px);
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 1rem;
		padding: 5rem 1rem 2rem;
		visibility: hidden;
		transition: opacity .4s, visibility .4s;
		z-index: 1000
	}

	.nav-menu.active {
		opacity: 1;
		visibility: visible
	}

	.nav-menu a {
		font-size: clamp(.6rem, 5vw, .8rem);
		font-weight: 400;
		color: #000 !important;
		text-decoration: none;
		padding: .3rem .5rem;
		border-radius: 1rem;
		transition: var(--transition);
		line-height: .5;
		letter-spacing: .05em;
		text-align: center
	}

	.nav-menu a:focus,
	.nav-menu a:hover {
		color: var(--primary-color) !important;
		background-color: rgba(230, 149, 0, .15)
	}

	.nav-menu a::after {
		content: '';
		position: absolute;
		bottom: .5rem;
		left: 50%;
		width: 0;
		height: .3rem;
		background-color: var(--primary-color);
		border-radius: .15rem;
		transition: width .3s;
		transform: translateX(-50%)
	}

	.nav-menu a:focus::after,
	.nav-menu a:hover::after {
		width: 0 !important;
	}

	.contact-button {
		display: none
	}

	.header-right {
		position: absolute;
		right: 5.5rem;
		top: 50%;
		transform: translateY(-50%);
		gap: .75rem
	}

	.lang-btn {
		padding: .3rem .7rem;
		font-size: .8125rem
	}

	.menu-toggle {
		right: 1rem
	}
}


@media (prefers-reduced-motion:reduce) {

	*,
	::after,
	::before {
		animation-duration: 0s !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0s !important
	}
}

.partners-section {
	padding: clamp(3rem, 6vw, 5rem) 1rem;
	background-color: var(--white);
	text-align: center
}

.partners-container {
	max-width: 1200px;
	margin: 0 auto
}

.partners-title {
	font-size: clamp(2rem, 4.5vw, 2.8rem);
	font-weight: 700;
	margin-bottom: clamp(2rem, 4vw, 3.5rem);
	color: var(--text-dark)
}

.partners-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: clamp(1.5rem, 3vw, 2.5rem);
	justify-items: center;
	align-items: center;
	max-width: 1200px;
	margin: 0 auto
}

.partner-logo {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 200px;
	height: 100px;
	transition: .25s
}

.partner-logo img {
	max-width: 100%;
	max-height: 100%;
	height: auto;
	width: auto;
	object-fit: contain;
	transition: .3s
}

.partner-logo:focus,
.partner-logo:hover {
	transform: translateY(-4px)
}

.partner-logo:hover img {
	filter: grayscale(0%);
	transform: scale(1.08)
}

@media (max-width:768px) {
	.partners-grid {
		grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
		gap: 1.5rem 1rem
	}

	.partner-logo {
		max-width: 160px;
		height: 70px
	}
}

@media (max-width:480px) {

	.mission-vision-card,
	.stat-item {
		flex: 1 1 100%
	}

	.partner-logo {
		max-width: 140px;
		height: 60px
	}
}

.header-right {
	display: flex;
	align-items: center;
	gap: 1.25rem
}

.lang-switcher {
	display: flex;
	gap: .5rem
}

.lang-btn {
	background: 0 0;
	border: 1px solid var(--primary-color);
	border-radius: 2rem;
	padding: .375rem .875rem;
	font-size: .875rem;
	font-weight: 500;
	color: var(--primary-color);
	cursor: pointer;
	transition: .2s
}

.lang-btn.active,
.lang-btn:hover {
	background: var(--primary-color);
	color: #fff
}

[data-lang] {
	display: none
}

.lang-en [data-lang=en],
.lang-zh [data-lang=zh] {
	display: inline
}

/*
@media (min-width:769px) and (max-width:1024px) {
	.nav-menu {
		flex-wrap: wrap;
		justify-content: center;
		gap: .8rem 1.2rem;
		max-width: 50%
	}

	.header-content {
		flex-wrap: wrap;
		gap: 1rem
	}

	.logo {
		order: 1
	}

	.nav-menu {
		order: 2;
		width: 100%;
		text-align: center
	}

	.header-right {
		order: 3
	}
}*/

.events-section {
	padding: clamp(3rem, 6vw, 6rem) 1rem;
	background: linear-gradient(to bottom, #fff, #f8f9fa);
	text-align: center
}

.events-container {
	max-width: 1400px;
	margin: 0 auto
}

.events-title {
	font-size: clamp(2.2rem, 5vw, 3.2rem);
	margin-bottom: 2.5rem;
	color: var(--text-dark)
}

.events-gallery {
	display: flex;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	gap: 1.5rem;
	padding: 1rem 0;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch
}

.gallery-item {
	flex: 0 0 320px;
	height: 240px;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 15px rgba(0, 0, 0, .12);
	cursor: pointer;
	transition: transform .25s, box-shadow .25s;
	position: relative;
	scroll-snap-align: start
}

.gallery-item:hover {
	transform: scale(1.04);
	box-shadow: 0 10px 25px rgba(0, 0, 0, .18)
}

.gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s
}

.gallery-item:hover img {
	transform: scale(1.08)
}

.caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: rgba(0, 0, 0, .65);
	color: #fff;
	padding: .8rem;
	font-size: .95rem;
	text-align: center;
	opacity: 0;
	transition: opacity .3s
}

.gallery-item:hover .caption,
body.loaded {
	opacity: 1
}

.gallery-controls {
	margin: 2rem 0 1rem;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1.5rem
}

.gallery-controls button {
	background: var(--primary-color);
	color: #fff;
	border: none;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	font-size: 1.6rem;
	cursor: pointer;
	transition: .25s;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px rgba(230, 149, 0, .25)
}

.gallery-controls button:hover {
	background: #c77c00;
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(230, 149, 0, .35)
}

.gallery-controls button:active {
	transform: translateY(1px);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .2)
}

.modal {
	display: none;
	position: fixed;
	z-index: 2000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .92);
	align-items: center;
	justify-content: center
}

.modal-content {
	position: relative;
	max-width: 90%;
	max-height: 85vh;
	text-align: center
}

.close-modal,
.modal-nav {
	position: absolute;
	color: #fff;
	cursor: pointer
}

#modalImage {
	max-width: 100%;
	max-height: 75vh;
	border-radius: 8px;
	box-shadow: 0 10px 40px rgba(0, 0, 0, .6)
}

.modal-caption {
	color: #fff;
	margin-top: 1.2rem;
	font-size: 1.1rem;
	max-width: 800px;
	padding: 0 1rem
}

.close-modal {
	top: 20px;
	right: 30px;
	font-size: 3rem;
	font-weight: 700
}

.modal-nav {
	top: 50%;
	transform: translateY(-50%);
	background: rgba(0, 0, 0, .4);
	border: none;
	font-size: 2.5rem;
	padding: .5rem 1rem;
	border-radius: 50%;
	width: 60px;
	height: 60px
}

.modal-nav.prev {
	left: 20px
}

.modal-nav.next {
	right: 20px
}

.modal-nav:hover {
	background: rgba(230, 149, 0, .7)
}

@media (max-width:1200px) {
	.header-right {
		position: absolute;
		right: 5.5rem;
		top: 50%;
		transform: translateY(-50%);
		gap: .75rem
	}

	.lang-btn {
		padding: .3rem .7rem;
		font-size: .8125rem
	}

	.menu-toggle {
		right: 1rem
	}

	.gallery-item {
		flex: 0 0 280px;
		height: 210px
	}

	.header-right .contact-button {
		display: none !important
	}

	.mobile-contact-link {
		display: block !important;
		color: var(--primary-color) !important;
		font-weight: 600 !important;
		padding: 1rem 1.5rem !important;
		margin: .5rem 1rem !important;
		border: 2px solid var(--primary-color);
		border-radius: var(--border-radius);
		text-align: center;
		background-color: rgba(230, 149, 0, .05);
		transition: var(--transition)
	}

	.mobile-contact-link:focus,
	.mobile-contact-link:hover {
		background-color: var(--primary-color);
		color: #fff !important
	}

	.nav-menu.active {
		padding-bottom: 1rem
	}
}

.header-content {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 2rem;
	flex-wrap: nowrap
}

.logo {
	position: static;
	flex-shrink: 0;
	margin-right: 2rem
}

.nav-menu {
	display: flex;
	flex-wrap: nowrap;
	gap: clamp(.8rem, .8vw, 1.2rem);
	margin-left: auto;
	white-space: nowrap
}

.header-right {
	flex-shrink: 0;
	margin-left: 2rem
}

@media (max-width:1200px) {
	.nav-menu {
		gap: clamp(.6rem, .8vw, 1rem)
	}

	.nav-menu a {
		font-size: clamp(1.1rem, 8vw, 1rem);
		padding: 0.7rem
	}
}

body,
body.fade-out {
	opacity: 0
}
/*
@media (max-width:1100px) and (min-width:769px) {
	.header-content {
		gap: 1rem
	}

	.nav-menu {
		gap: clamp(.4rem, .6vw, .8rem)
	}

	.nav-menu a {
		font-size: clamp(.7rem, 1vw, .9rem);
		padding: .4rem .6rem
	}

	.contact-button {
		font-size: .9rem;
		padding: .5rem 1.1rem
	}

	.lang-switcher .lang-btn {
		font-size: .9rem;
		padding: .45rem .9rem;
		min-width: 50px
	}

	.header-right {
		gap: .6rem
	}
}*/

@media (min-width:1200px) {
	.mobile-contact-link {
		display: none !important
	}
}