.brand-story {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(3rem, 8vw, 4.5rem);
	padding: 0 clamp(1rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
	max-width: 1600px;
	margin: 0 auto;
	background: #FFF;
	min-height: 100vh;
}

.brand-story__top {
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}

.brand-story__top img {
	width: 100%;
	max-height: 600px;
	object-fit: cover;
}

.brand-story__hero {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(1rem, 3vw, 1.5rem);
	text-align: center;
	padding-top: clamp(2rem, 4vw, 3rem);
}

.brand-story__badge {
	display: inline-flex;
	padding: 0.5rem 1.25rem;
	justify-content: center;
	align-items: center;
	border-radius: 90px;
	background: #6D7885;
	color: #FFF;
	font-size: clamp(0.875rem, 2vw, 1rem);
	line-height: 1.25;
	font-weight: 400;
	font-family: 'Inter', -apple-system, system-ui, sans-serif;
}

.brand-story__title {
	font-size: clamp(4.25rem, 12vw, 8rem);
	font-weight: 500;
	line-height: 0.9;
	letter-spacing: -0.32rem;
	text-transform: uppercase;
	color: #2C2D2E;
	margin: 0;
	font-family: 'Inter', -apple-system, system-ui, sans-serif;
}

.brand-story__founders {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(1.5rem, 4vw, 2rem);
	max-width: 1200px;
}

.founders__images {
	width: clamp(18rem, 25vw, 19rem);
	height: auto;
	display: block;
	position: relative;
}
.founders__image:nth-child(2) {
	position: absolute;
	left: 45%;
	top: 0;
}

.brand-story__text {
	font-size: clamp(1rem, 2.5vw, 1.5rem);
	line-height: 1.2;
	color: #2C2D2E;
	max-width: 69rem;
	text-align: center;
	margin: 0;
	font-family: 'Inter', -apple-system, system-ui, sans-serif;
}

.brand-story__text--centered {
	max-width: 61rem;
	margin-inline: auto;
}

.brand-story__gallery {
	width: 100%;
	overflow-x: auto;
	overflow-y: hidden;
	display: flex;
	justify-content: center;
}

.gallery__grid {
	display: flex;
	gap: var(--size-20);
	overflow-x: auto;
}

.gallery__grid img {
	width: clamp(10rem, 15.5vw, 14.5rem);
	height: clamp(12rem, 20vw, 19.875rem);
	object-fit: cover;
	display: block;
	flex-shrink: 0;
}

.brand-story__collaboration {
	max-width: 1370px;
	width: 100%;
	padding: clamp(1rem, 3vw, 2rem) 0;
}

.brand-story__name-origin {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(2rem, 5vw, 3rem);
	width: 100%;
	max-width: 1370px;
}

.divider {
	width: 100%;
	height: 1px;
	background: #D9D9D9;
}

.brand-story__subtitle {
	font-size: clamp(1.5rem, 4vw, 2.5rem);
	font-weight: 500;
	line-height: 1.3;
	text-align: center;
	color: #2C2D2E;
	max-width: 50rem;
	margin: 0;
	font-family: 'Inter', -apple-system, system-ui, sans-serif;
}

.brand-story__description {
	max-width: 1370px;
	width: 100%;
}

.brand-story__banners {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 25rem), 1fr));
	gap: clamp(0.125rem, 0.5vw, 0.22rem);
	width: 100%;
	max-width: 1509px;
}

.banner {
	position: relative;
	height: clamp(25rem, 60vw, 53.5rem);
	overflow: hidden;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}

.banner--left {
	background: #B5BDC7;
}

.banner--right {
	background: #D6CBB7;
}

.banner__images {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.banner__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.banner__overlay {
	position: relative;
	z-index: 10;
	padding: clamp(2rem, 5vw, 4rem);
	text-align: center;
}
.banner__overlay:before {
	content: '';
	display: block;
	inset: 0;
	position: absolute;
	background-color: rgba(29, 19, 19, 0.6);
	filter: blur(20px);
}
.banner-text {
	font-size: clamp(1rem, 2.5vw, 1.75rem);
	line-height: 1.12;
	color: #FFF;
	margin: 0;
	position: relative;
}

.brand-story__final {
	max-width: 68rem;
	width: 100%;
	padding-bottom: clamp(2rem, 4vw, 3rem);
}

@media (max-width: 768px) {
	.brand-story__title {
		letter-spacing: -0.16rem;
	}
	
	.gallery__grid img {
		width: clamp(8rem, 30vw, 12rem);
		height: clamp(10rem, 35vw, 15rem);
	}
	
	.brand-story__banners {
		grid-template-columns: 1fr;
	}
	
	.banner {
		height: clamp(20rem, 70vw, 30rem);
	}
}

@media (min-width: 768px) and (max-width: 1199px) {
	.gallery__grid img {
		width: clamp(9rem, 18vw, 13rem);
		height: clamp(11rem, 22vw, 17rem);
	}
}

@media (min-width: 1200px) {
	.brand-story__banners {
		grid-template-columns: 1fr 1fr;
	}
	
	.gallery__grid img {
		width: 14.5rem;
		height: 19.875rem;
	}
}
