/* ===== About Section ===== */
.about-section {
	max-height: fit-content;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	background: #fff;
	position: relative;
	overflow-x: hidden;
}
.about-focus {
	margin-top: 200px;
	font-size: 48px;
	color: #d0211c;
	text-align: center;
	letter-spacing: 0.01em;
	font-family: 'Pretendard-ExtraBold';
}
.about-main-title {
	margin-top: 18px;
	font-size: 48px;
	font-weight: 400;
	text-align: center;
	color: #111;
	line-height: 1.22;
	word-break: keep-all;
}
.about-main-title .main-underline {
	display: inline-block;
	text-decoration: underline;
	text-underline-offset: 6px;
}
.about-main-title .and {
	display: inline-block;
	font-weight: 500;
	text-decoration: none !important;
	margin: 0 6px;
}
.about-desc-top {
	margin-top: 60px;
	font-size: 29px;
	font-weight: 600;
	color: #232323;
	text-align: center;
	word-break: keep-all;
}
.about-desc-sub {
	margin-top: 10px;
	font-size: 26px;
	color: #232323;
	text-align: center;
}
.about-desc-sub b {
	font-weight: 700;
	color: #111;
}
.about-logo-motion-wrap {
	width: 100%;
    position: relative;
    margin: 120px 0px 120px 0px;
    justify-content: center;
    align-items: flex-end;
}
.about-logo-motion {
	position: relative;
	left: -100%;
	opacity: 0;
	transition: left 1.2s cubic-bezier(.86,0,.07,1), opacity 1.2s;
	z-index: 10;
	display: flex;
	align-items: center;
}
.about-logo-motion.active {
	left: 0;
	opacity: 1;
}
.about-logo-img {
	width: 80%;
	max-width: 1110px;
	height: auto;
	display: block;
	margin: 0 auto;
	user-select: none;
}

/* ===== Teams Section ===== */
#teams-section {
	position: relative;
	width: 100%;
	min-height: 100vh;
	max-height: 1000px;
	background: #000;
	overflow: hidden;
}
.teams-bg-image {
	position: absolute;
	top: 0; left: 0; width: 100%; height: 100%;
	z-index: 0;
}
.teams-bg-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.teams-content {
	position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    max-width: 83%;
    padding-left: 10%;
    /* margin: 0 auto; */
    z-index: 1;
    height: 100%;
    margin-top: 260px;
}
.teams-left {
	width: 68%;
	color: #fff;
}
.teams-title {
	font-family: 'BespokeSerif-ExtraBold', serif;
	font-size: 50px;
	font-weight: 800;
	margin-bottom: 60px;
	margin-top: 0;
	letter-spacing: 0.02em;
	line-height:0.8;
	text-shadow: 0 2px 10px rgba(10,10,20,0.10);
}
.teams-desc {
	font-size: 22px;
	color: #fff;
	font-weight: 400;
	line-height: 1.65;
	margin-bottom: 0;
	text-shadow: 0 1.5px 6px rgba(10,10,10,0.12);
}
.teams-desc b {
	font-size:26px;
}
.teams-right {
	display: flex;
	flex-direction: row;
	gap: 44px;
	width: 55%;
	justify-content: flex-end;
}
.team-group {
	display: flex;
	flex-direction: column;
	gap: 34px;
	flex: 1 1 0;
}
.team-block {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	color: #fff;
	margin-bottom: 0;
}
.team-num {
	font-family: 'Pretendard-Medium', serif;
	font-size: 20px;
	font-weight: 800;
	line-height: 1;
	margin-right: 19px;
	margin-top: 1px;
	color: #fff;
	opacity: 0.8;
}
.team-block-title {
	font-size: 19px;
	font-weight: 700;
	margin-bottom: 5px;
	letter-spacing: 0.01em;
}
.team-block ul {
	margin: 0;
	padding: 0 0 0 14px;
	list-style: disc;
	font-size: 16px;
	line-height: 1.65;
}
.team-block ul li {
	margin-bottom: 2.5px;
}

/* ===== Goals Section ===== */
#goals-section {
	background: #181818;
	position: relative;
	width: 100%;
	min-height: fit-content;
	max-height: 1000px;
	overflow: hidden;
}
.goals-title {
	text-align: center;
	margin-top: 200px;
}
.goals-title h2 {
	font-family: 'BespokeSerif-ExtraBold', 'Pretendard', sans-serif;
	font-size: 45px;
	color: #fff;
	margin-bottom: 60px;
}
.goals-title p {
	font-size: 24px;
	color: #fff;
	margin-bottom: 60px;
	font-family: 'Pretendard', sans-serif;
}
.goals-title b {
	font-weight: 700;
}
.goals-cards {
	display: flex;
	justify-content: center;
	align-items: stretch;
	gap: 2.2%;
	width: 75%;
	margin: 0 auto;
	margin-bottom:100px;
}
.goal-card {
	background: #232323;
	border: 2px solid #404040;
	border-radius: 18px;
	box-shadow: 0 6px 36px 0 rgba(0,0,0,0.12);
	padding: 3.3% 2.2% 2.6% 2.2%;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	width: 31%;
	transition: box-shadow 0.2s, border 0.2s;
}
.goal-card:hover {
	box-shadow: 0 8px 48px 0 rgba(0,0,0,0.22);
	border-color: #aaa;
	margin-top: -10px;
}
.goal-icon {
	width: 140px;
	height: 140px;
	margin-bottom: 19px;
	border-radius: 50%;
	background: #fff;
	padding: 12px;
	box-shadow: 0 2px 12px rgba(0,0,0,0.07);
	object-fit: contain;
	display: flex;
	align-items: center;
	justify-content: center;
}
.goal-title {
    font-size: 40px;
    color: #fff;
    font-weight: 900;
    line-height: 0.8;
    margin-bottom: 30px;
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
}

.goal-title .sub-title {
	font-size: 24px;
	color: #fff;
	font-weight: 100;
	font-family: 'Pretendard', sans-serif;
}
.goal-desc {
	color: #d2d2d2;
	font-size: 18px;
	line-height: 1.5;
	letter-spacing: 0.01em;
	text-align: center;
	font-family: 'Pretendard', sans-serif;
}

/* ===== 반응형: About ===== */
@media (max-width: 1024px) {
	.about-section { padding: 0 1%; }
	.about-focus { font-size: 34px; }
	.about-main-title { font-size: 32px; }
	.about-desc-top { font-size: 19px; }
	.about-onemore { font-size: 24px; }
	.about-logo-img { width: 94%; }
	.text-motion-info { font-size: 15px; right: 2%; }
}
@media (max-width: 767px) {
	.about-section { padding: 0 3%; }
	.about-focus { font-size: 20px; margin-top:140px;}
	.about-main-title { font-size: 18px; }
	.about-desc-top { font-size: 16px; margin-top:32px; }
	.about-desc-sub { font-size: 14px; }
	.about-onemore { font-size: 12px; }
	.about-logo-img { width: 80%; }
	.about-logo-motion-wrap {margin-top:60px; margin-bottom:60px;}
	.text-motion-info { font-size: 12px; padding: 8px 18px; right: 2%; }
	.about-section {min-height:fit-content;}
}

/* ===== 반응형: Teams ===== */
@media (max-width: 1200px) {
	.teams-content { flex-direction: column; padding: 58px 4% 28px 4%; }
	.teams-left { width: 100%; margin-top: 0; margin-bottom: 42px; }
	.teams-right { width: 100%; gap: 22px; padding: 0 3%; }
}
@media (max-width: 900px) {
	.teams-content { padding: 32px 2% 18px 2%; }
	.team-group { gap: 18px; }
	.team-block-title { font-size: 17px; }
	.team-block ul { font-size: 15px; }
	.teams-title { font-size: 32px; }
}
@media (max-width: 680px) {
	#teams-section {min-height: fit-content;}
	.teams-content {flex-direction: column; padding: 0% 3% 60px 3%; width: 94%; margin:0 auto;}
	.teams-left { width: 94%; padding: 120px 3% 0px 3%; text-align:center; margin-bottom:30px;}
	.teams-right { flex-direction: column; gap: 16px; margin-top: 0px; }
	.team-group { gap: 12px; }
	.team-block { margin-bottom: 0; }
	.teams-title {font-size: 22px; }
	.teams-desc { font-size: 16px; line-height:1.2;}
	.teams-desc b { font-size: 18px; }
	.team-block-title { font-size: 16px; }
	.team-num { font-size: 20px; margin-right: 10px; }
	.team-block ul { font-size: 13px; }
}

/* ===== 반응형: Goals ===== */
@media (max-width: 1024px) {
	.goals-cards { gap: 3%; }
	.goal-card { width: 45%; margin-bottom: 3%; }
}
@media (max-width: 767px) {
	#goals-section { min-height:fit-content;}
	.goals-title { margin-top: 120px; }
	.goals-title h2 { font-size: 22px; margin:0px 0px 20px 0px; }
	.goals-title p { font-size: 16px; margin-bottom:20px;}
	.goal-icon {
		width: 110px;
		height: 110px;
	}
	.goal-title {
		font-size: 30px;
		line-height:1;
	}

	.goal-title .sub-title {
		font-size: 20px;
	}

	.goal-desc {
		font-size: 16px;
	}
	/* 모바일에서 세로 배치 */
	.goals-cards { 
		flex-direction: column; 
		gap: 20px; 
		align-items: center;
		margin-bottom:20px;
	}
	.goal-card { 
		width: 100%; 
		max-width: 350px; /* 너무 넓어지지 않도록 최대 너비 설정 */
		margin-bottom: 0; /* gap으로 간격 조절하므로 margin 제거 */
	}
	.goal-card:hover {
		margin-top: 0; /* 호버 시 위로 올라가는 효과 제거 (모바일에서는 불필요) */
	}
}

@media (max-width: 500px) {
    .teams-title {
        font-size: 25px;
		margin-bottom:25px;
    }
    .teams-desc {
        font-size: 14px;
    }
	.teams-desc b{
        font-size: 16px;
    }
	.goals-title h2 {
        font-size: 25px;
		margin-bottom:25px;
    }
	.goals-title p {
        font-size: 14px;
		margin-bottom:50px;
    }
	.goal-icon {
        width: 90px;
        height: 90px;
    }
	.goal-icon svg {
        width: 70px;
        height: 70px;
    }
	.goal-title {
        font-size: 25px;
        line-height: 1;
    }
	.goal-title .sub-title {
        font-size: 16px;
    }
	.goal-desc {
        font-size: 14px;
    }
	.goal-card {
		padding: 8% 2.2% 8% 2.2%;
	}
	
}