@charset 'utf-8';
@import url('https://fonts.googleapis.com/css2?family=Nanum+Myeongjo&display=swap');

/************************************* 공통 *************************************/
main {
	padding-top: 0 !important;
}

.section-padding {
	min-height: 85vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.section-header {
	/* margin-bottom: 6rem;  */
	text-align: center;
}

section>.container {
	overflow-y: visible !important;
}


/************************************* 섹션별 *************************************/

#home {
	position: relative;
	/* background: url(https://cdn.myplayer.kr/lawjibsa-mangobanana/corpsvr/hero_img_01.jpeg) no-repeat center center;
    background-size: cover; */
}

.home-bg-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
	opacity: 1;
	transition: opacity 0.6s ease;
}

.home-bg-video.is-hidden {
	opacity: 0;
	pointer-events: none;
}

@keyframes home-bg-slide {
	from {
		/* start at left edge */
		background-position: 0% center;
	}

	to {
		/* move to right edge (full sweep) */
		background-position: 100% center;
	}
}

#home.home-bg-anim {
	animation-name: home-bg-slide;
	/* animation-duration: 60s;  */
	animation-timing-function: linear;
	animation-iteration-count: 1;
	animation-fill-mode: forwards;
	will-change: background-position;
}

#home::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	z-index: 1;
}

#hero-box {
	position: relative;
	overflow: hidden;
	width: fit-content;
	padding: 2rem;
	/* background-color: #ffffffc7; */
	background-color: transparent;
}

#hero-box>* {
	position: relative;
	z-index: 1;
}

#home-heading {

	font-family: "Nanum Myeongjo", serif;
	font-size: max(3.5vw, var(--fz-xxl));
	font-weight: 700;
	margin-bottom: 1rem;
	text-align: center;
	background: linear-gradient(90deg, #c8a44e, #f4e2a1);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

#ecg-svg {
	stroke: #ff0000;
	stroke-width: 3;
	fill: none;
	z-index: 0;
	position: absolute;
}

#home-container {
	position: relative;
	z-index: 1;
}

.section-title {
	color: var(--color-text-main);
	font-size: var(--fz-xxl);
}

.section-eyebrow {
	color: var(--color-primary);
}

#consult {
	/* background: url(https://cdn.myplayer.kr/lawjibsa-mangobanana/corpsvr/form_section_bg.jpeg) center center;
    background-size: cover; */
	background: url(https://cdn.myplayer.kr/lawjibsa-mangobanana/corpsvr/corp_consult_bg.jpeg) center center / cover no-repeat;
	min-height: 600px;
	display: flex;
	align-items: center;
	color: #fff !important;
}

@media (max-width: 768px) {

	.section-eyebrow,
	.section-title,
	.section-desc {
		text-align: left;
	}
}

/* HERO ----------------------------------------------------- */
.hero-section {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	padding: 4.5rem 0;
	overflow: hidden;
	color: #222;
	background-size: cover;
	background-position: center;
}

@media (max-width: 992px) {
	.hero-inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
}

.hero-chip {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.25rem 0.75rem;
	font-size: var(--fz-md);
	border-radius: 999px;
	background-color: rgba(15, 23, 42, 0.7);
	color: #111;
	border: 1px solid rgba(75, 85, 99, 0.8);
	margin-bottom: 0.9rem;
}

.hero-chip i {
	color: var(--color-primary);
	font-size: var(--fz-md);
}

.hero-title {
	font-size: max(4vw, var(--fz-xxl));
	font-weight: 700;
	letter-spacing: -0.05em;
	line-height: 1.2;
	margin-bottom: 1rem;
	color: #fff;
	text-align: center;
}



.hero-sub {
	font-size: var(--fz-lg);
	color: #eaeaea;
	opacity: 0.9;
	margin-top: 5rem;
	text-align: center;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

@media (max-width: 768px) {
	.hero-sub {
		margin-top: 2rem;
	}
}

.hero-sub span {
	color: #f14536;
	font-weight: 500;
}

.hero-meta {
	font-size: var(--fz-md);
	color: var(--color-text-sub);
	margin-top: 1rem;
}

.hero-meta i {
	color: var(--color-accent-red);
}

.hero-visual-card {
	border-radius: var(--radius-xl);
	background-color: rgba(255, 255, 255, 0.5);
	padding: 1.4rem 1.5rem;
	box-shadow: var(--shadow-soft);
}

@media (max-width: 768px) {
	.hero-visual-card {
		padding: 1rem;
		margin: 0 -0.5rem;
	}
}

.hero-stat-row {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75rem;
	margin-top: 1rem;
}

.hero-stat {
	padding: 0.65rem 0.8rem;
	border-radius: 0.85rem;
	background-color: #fff;
	border: 1px solid rgba(31, 41, 55, 0.9);
}

.hero-stat-label {
	font-size: var(--fz-md);
	color: var(--color-text-sub);
}

.hero-stat-value {
	font-size: var(--fz-md);
	font-weight: 600;
	margin-top: 0.15rem;
	color: #222;
}

.hero-timeline {
	border-radius: 0.85rem;
	background-color: #fff;
	border: 1px dashed rgba(55, 65, 81, 0.9);
	padding: 0.8rem 0.9rem;
	font-size: var(--fz-md);
	color: var(--color-text-sub);
	margin-top: 1rem;
}

.hero-timeline strong {
	color: var(--color-accent-red);
}

/* FEATURE CARDS ------------------------------------------- */
#why-summary>.container {
	position: relative;
	padding-left: 2rem;
}

/* #why-summary > .container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 5px;
    height: 100%;
    background-color: var(--color-primary);    
} */


.feature-card {
	/* min-height: 70vh; */
	width: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: visible;
	margin-bottom: 4rem;
}

.feature-card>h3 {
	font-size: var(--fz-xl);
	font-weight: 700;
	color: #222;
	text-align: center;
}

.feature-card .feature-description {
	font-size: var(--fz-md);
	font-weight: 500;
	color: #222;
	margin-top: 1.25rem;
	padding: 1.6rem 1.8rem;
	border: none;
	border-radius: var(--radius-lg);
	line-height: 1.8;
	max-width: 860px;
	/* box-shadow: 0 10px 30px rgba(var(--color-primary-rgb),0.3); */
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 30px;
	transition: transform 0.18s ease, box-shadow 0.18s ease;
}

/* ensure card content sits above decorative SVG */
.feature-card>* {
	position: relative;
	z-index: 2;
}

/* decorative SVG inserted by JS */
/* .feature-card-svg {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
    pointer-events: none;
    overflow: visible;
}

.feature-card-svg circle {
    fill: none;
    stroke: #308dffa5;
    stroke-width: 6;
    stroke-linecap: round;
    transform-origin: center center;
    transform: rotate(-90deg);
} */

.feature-card .feature-description h3 {
	margin: 0 0 2rem 0;
	font-size: var(--fz-xl);
	line-height: 1.2;
	color: var(--color-primary);
	font-weight: 700;
}

.feature-card .feature-description p.lead {
	font-size: var(--fz-md);
	font-weight: 600;
	color: #1f2937;
	margin-bottom: 2rem;
}

.feature-card .feature-description p {
	margin: 0;
	color: var(--color-text-sub);
	font-size: var(--fz-sm);
	line-height: 1.7;
}

@media (max-width: 768px) {
	#why-summary .section-header {

		margin-bottom: 3rem;
	}

	.feature-card .feature-description {
		padding: 0;
		max-width: 100%;
		text-align: left;
	}

	.feature-card .feature-description h3 {
		text-align: left;
	}
}

.feature-card:nth-child(1) img {}

.feature-img-wrap {
	width: 100%;
	height: 500px;
	overflow: hidden;
}

.feature-img-wrap>img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.feature-card-bottom {
	padding: 1.2rem 1.3rem 1.4rem;
}

.feature-card h5 {
	font-weight: 600;
	margin-bottom: 0.5rem;
	font-size: var(--fz-md);
	color: #222;
}

.feature-card p {
	font-size: var(--fz-md);
	color: var(--color-text-sub);
}

/* SERVICES ------------------------------------------------- */
/* .services-section {
    background-color: #fff;
} */

#services-rehab .section-title,
#services-bankruptcy .section-title {
	font-size: var(--fz-xl) !important;
}

.service-card {
	border-radius: var(--radius-xl);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border-subtle);
	padding: 2rem;
	box-shadow: var(--shadow-soft);
}

.service-badge {
	font-size: var(--fz-tn);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	border-radius: 999px;
	color: var(--color-text-sub);
	margin-bottom: 0.6rem;
	display: inline-block;
}

.service-section-img {
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-soft);
}

.service-section-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.service-list li {
	font-size: var(--fz-md);
	color: var(--color-text-sub);
}

.service-list i {
	color: var(--color-primary);
}

/* SUCCESS CASES ------------------------------------------- */
.success-section {
	background-color: var(--color-bg);
}


/* COLUMNS & FAQ ------------------------------------------- */
.columns-faq-section {
	background-color: #fff;
}

.pill-nav .nav-link {
	border-radius: 999px;
	color: #111;
	font-size: var(--fz-md);
	border: 1px solid #1f2937;
}

.pill-nav .nav-link.active {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: #ffffff;
}

.column-card {
	border-radius: var(--radius-lg);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border-subtle);
	padding: 1.4rem 1.4rem 1.2rem;
	height: 100%;
	display: block;
}

.column-card .badge {
	font-size: var(--fz-md);
	border-radius: 999px;
}

.column-card h3 {
	font-size: var(--fz-md);
	margin-top: 0.4rem;
	margin-bottom: 0.5rem;
	color: #222;
}

.column-card p {
	font-size: var(--fz-md);
	color: var(--color-text-sub);
	margin-bottom: 0;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	text-overflow: ellipsis;
	overflow: hidden;
}

.columns-faq-section .accordion-item {
	border-radius: 0.8rem !important;
	overflow: hidden;
	border: 1px solid var(--color-border-subtle);
	margin-bottom: 0.7rem;
	background-color: transparent;
}

.columns-faq-section .accordion-button {
	background-color: var(--color-surface);
	color: #222;
	font-size: var(--fz-md);
	font-weight: 500;
	gap: 1rem;
	line-height: 1.5;
}

.columns-faq-section .accordion-button:not(.collapsed) {
	background-color: #ffffff;
	color: #222;
	box-shadow: none;
}

.columns-faq-section .accordion-body {
	font-size: var(--fz-md);
	color: var(--color-text-sub);
	background-color: #fff;
}

#columns-faq .row {
	justify-content: center;
}

#columns-faq .col-md-6>h3 {
	margin-bottom: 1rem;
	padding: .5rem 1rem;
	font-size: var(--fz-lg);
	border: 1px solid var(--color-primary);
	color: var(--color-primary);
	border-radius: 999px;
	text-align: center;
}

/* CONSULT CTA --------------------------------------------- */
.consult-section {
	background-color: var(--color-bg);
}

.consult-inner {
	border-radius: var(--radius-xl);
	background-color: rgba(255, 255, 255, 0.75);
	padding: 2.4rem 5.3rem;
	display: flex;
	align-items: center;
	backdrop-filter: blur(5px);
}

.consult-inner h2 {
	font-size: var(--fz-xl);
	letter-spacing: -0.04em;
	margin-bottom: 0.7rem;
	color: #222;
}

.consult-inner p {
	font-size: var(--fz-tn);
	color: var(--color-text-sub);
}

.consult-form .form-control {
	background-color: #fff;
	border-radius: 999px;
	border: 1px solid #d4d4d4;
	color: #222;
}

.consult-form .form-control::placeholder {
	color: #6b7280;
}

.consult-note {
	font-size: var(--fz-sm);
	color: var(--color-border-subtle);
}


.section-desc {
	color: var(--color-text-sub);
	margin: 0 auto 5rem;
	font-size: var(--fz-md);
}

#consult-heading {
	font-size: var(--fz-xl);
	margin-bottom: 2rem;
	font-weight: 700;
}

@media (max-width: 768px) {
	.consult-inner {
		padding: 2rem 1.5rem;
		height: auto;
		flex-direction: column;
		text-align: center;
		gap: 1.5rem;
	}

	#consult-heading {
		font-size: var(--fz-lg);
	}

	.consult-form .form-control {
		font-size: var(--fz-md);
	}


}



/* ===== 칼럼 및 faq 섹션 ===== */
.columns-faq-hero {
	text-align: center;
	padding: 4rem 0 3rem;
}

.columns-faq-section {
	background: linear-gradient(180deg, rgba(29, 69, 133, 0.05), rgba(255, 255, 255, 0));
}

.columns-faq-subtitle {
	font-size: var(--fz-lg);
	font-weight: 300;
}

.btn-pill-link {
	padding: 6px 14px;
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.08);
	font-size: var(--fz-sm);
	color: var(--color-text-main);
	background: var(--color-surface);
	text-decoration: none;
	transition: all .15s ease;
}

.btn-pill-link:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.insight-card {
	/* display: block;
    padding: 1.4rem 1.6rem;
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fafc 100%);
    border: 1px solid rgba(0,0,0,0.05);
    text-decoration: none;
    transition: all .2s ease;
    position: relative;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04); */
	display: block;
	text-decoration: none;
	background: rgba(255, 255, 255, 0.9);
	backdrop-filter: blur(6px);

	border-radius: 12px;
	border: 1px solid rgba(0, 0, 0, 0.06);

	padding: 22px 26px;
	margin-bottom: 16px;

	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);

	transition: all .25s ease;
	position: relative;
}

.insight-card:hover {
	/* transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0,0,0,0.07); */
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.12);
	background: white;
}

/* 제목 */
.insight-card-title {
	font-size: var(--fz-md);
	font-weight: 800;
	color: var(--color-text-main);
	display: block;
	margin-bottom: 0.4rem;
}

/* 요약 */
.insight-card-excerpt {
	font-size: var(--fz-sm);
	color: var(--color-text-sub);
	line-height: 1.6;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}


/* ===== FAQ 카드 스타일 subtle upgrade ===== */
.columns-faq-section .faq-card {
	border-radius: 14px !important;
	border: 1px solid rgba(0, 0, 0, 0.05);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.columns-faq-section .faq-card .accordion-button {
	font-weight: 400;
	font-size: var(--fz-md);
}

.columns-faq-section .faq-card .accordion-button:not(.collapsed) {
	background-color: #f4f8ff !important;
}

/* 버튼 hover subtle */
.columns-faq-section .faq-card .accordion-button:hover {
	background-color: #f8fbff;
}

.columns-faq-section .faq-card .accordion-body {
	font-size: var(--fz-sm);
	color: var(--color-text-sub);
	line-height: 1.7;
}

.consult-form {
	width: 100%;
	display: flex;
	flex-direction: column;
}

#quick_submit_btn {
	max-width: 100%;
	flex: 1;
	background: var(--bs-blue);
	color: #fff;
	font-weight: 700;
	transition: transform 0.18s ease, box-shadow 0.18s ease;
}

#quick_submit_btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

@media (max-width: 576px) {
	#article_goldenTimeDefense>.row>.col-md-6:nth-child(2) {
		order: -1;
	}

	.feature-img-wrap {
		height: 300px;
	}
}

.privacyModalBtn {
	font-size: var(--fz-sm);
	color: var(--bs-info);
	text-decoration: underline;
	cursor: pointer;
}