:root {
    --sub-primary: #4d327c;
}

.inner_1920 { position: relative; left: 50%; width: 1920px; max-width: 100%; min-width: 1200px; transform: translateX(-50%); padding: 0; }

.sub_content_visual { position: relative; overflow: hidden; height: 295px; }
.sub_content_visual > img { width: 100%; height: 100%; object-fit: cover; object-position: center); }
.sub_content_visual_text { position: absolute; inset: 0; width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; flex-direction: column; }
.sub_content_visual_text h1 { font-size: 38px; font-weight: 400; }

.sub_content_breadcrumb { position: absolute; left: 0; bottom: 0; width: 100%; background-color: rgba(255,255,255,0.6); padding: 15px; }
.sub_content_breadcrumb ol { width: 100%; max-width: 1280px; margin: 0 auto; display: flex; justify-content: flex-start; align-items: center; gap: 0.5em; padding: 0 20px; }
.sub_content_breadcrumb li + li:before { content: ">"; margin-right: 0.5em; }
.sub_content_breadcrumb a { display: flex; justify-content: flex-start; align-items: center; gap: 0.5em; }


.sub_content { padding: 60px 0 100px; }
.sub_nav  { margin-bottom: 50px; }
.sub_nav ul { display: flex; justify-content: flex-start; align-items: center; }
.sub_nav li { flex: 1; outline: 1px solid #ccc; outline-offset: -1px; transition: all 0.3s; -webkit-transition: all 0.3s; }
.sub_nav li + li { margin-left: -1px; }
.sub_nav li.active,
.sub_nav li:hover { color: #fff; background-color: var(--primary); }
.sub_nav a { display: block; padding: 15px 8px; font-size: 16px; font-weight: 600; text-align: center; transition: all 0s; -webkit-transition: all 0s; }


.sub_content_head { display: flex; justify-content: flex-start; align-items: center; gap: 60px; }
.sub_content_head_img { flex-shrink: 0; width: 400px; aspect-ratio: 1/1.1; overflow: hidden; }
.sub_content_head_img img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.sub_content_head_text { flex: 1; min-width: 0; }
.sub_content_head_text h2 { font-size: 40px; font-weight: 600; margin-bottom: 30px; }
.sub_content_head_text h2.p404 { text-align: center; padding: 100px 0; }
.sub_content_head_text strong { display: block; font-size: 22px; font-weight: 300; letter-spacing: -0.03em; margin-bottom: 10px; word-break: keep-all; }
.sub_content_head_text strong b { font-weight: 500; }
.sub_head_desc { position: relative; padding: 30px 0; margin-top: 30px; color: var(--gray-700); }
.sub_head_desc:before,
.sub_head_desc:after { content: ""; position: absolute; left: 0;; height: 1px; width: 100px; background-color: #ccc; }
.sub_head_desc:before { top: 0; }
.sub_head_desc:after { bottom: 0; }
.sub_head_desc p { position: relative; line-height: 1.6; }
.sub_head_desc_tag { display: flex; justify-content: flex-start; align-items: center; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.sub_head_desc_tag p { background-color: #4d327c; color: #fff; font-size: 18px; flex: 1 1 0; padding: 10px 8px; text-align: center; }

.sub_content_banner { position: relative; margin-top: 120px; }
.sub_content_banner img { width: 100%; height: auto; }
.sub_content_banner_text { position: absolute; inset: 0; display: flex; justify-content: flex-start; align-items: center; flex-direction: column; padding: 80px 20px 20px; text-align: center; }
.sub_content_banner_text > span { font-size: 16px; letter-spacing: 0.5em; margin-bottom: 20px; }
.sub_content_banner_text p,
.sub_content_banner_text p * { font-family: 'Gowun Dodum'; }
.sub_content_banner_text p { font-size: 30px; font-weight: 500; line-height: 1.5; }
.sub_content_banner_text p + p { margin-top: 15px; font-size: 34px;  }
.sub_content_banner_text p span { background-color: #000; color: #fff; padding: 0.1em 0.2em; }


.sub_section { position: relative; margin-top: 100px; z-index: 1; }
.sub_section_title { font-size: 24px; margin-bottom: 24px; }
.sub_section_title span { font-size: 14px; color: #666; font-weight: 400; }
.sub_section_desc { font-size: 16px; color: var(--gray-700); line-height: 1.5; }
.sub_section_desc + .sub_section_desc { margin-top: 20px; }
.sub_section_desc h4 { font-size: 22px; color: #222; margin-bottom: 10px; }
.sub_section_desc li + li { margin-top: 25px; }
.sub_section_desc li b { font-size: 1.2em; word-break: keep-all; }
.section_bef_img { position: absolute; width: 100%; height: 100%; bottom: 0; z-index: -1; text-align: right; }
.section_bef_img img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.section_bef_img ~ .sub_section_title { padding-top: 200px; }


.sub_section_table { overflow: hidden; }
.sub_section_table table { table-layout: fixed; border-collapse: collapse; min-width: 100%; }
.botox_table { border-top: 2px solid #555; color: #555; font-size: 16px; line-height: 1.8; }
.botox_table th,
.botox_table td { border-bottom: 1px solid #bfbfbf; border-left: 1px solid #bfbfbf; padding: 42px 26px; vertical-align: top; word-break: keep-all; }
.botox_table th:first-child,
.botox_table td:first-child { border-left: 0; }
.botox_table thead th { padding: 18px 20px; background-color: #fafafa; color: #111; font-size: 18px; font-weight: 500; text-align: center; vertical-align: middle; }
.botox_table .type { color: #111; font-size: 17px; font-weight: 600; text-align: center; }
.botox_table .effect { width: 45%; }
.botox_table .caution { width: 45%; }
.botox_table p + p { margin-top: 2px; }
.botox_table .note { margin-top: 22px; color: var(--sub-primary); }

@media(max-width: 1024px) {
    .sub_nav { margin: 0 -20px; padding: 0 20px; overflow: auto; }
    .sub_nav ul { }
    .sub_nav li { min-width: 100px; flex-shrink: 0; }
    
    .sub_content_head { padding-top: 50px; gap: 30px; align-items: flex-start; }
    .sub_content_head_img { width: 340px; }
    .sub_head_desc_tag { flex-direction: column; align-items: flex-start; }
    .sub_head_desc_tag p { white-space: nowrap; }
}

@media(max-width: 768px) {
    .sub_content_visual { height: 50rem; }
    .sub_content_visual_text h1 { font-size: 4rem; }
    .sub_content_breadcrumb { padding: 3rem; }
    .sub_content_breadcrumb ol { padding: 0; }

    .sub_content { padding: 0 0 5rem; }
    .sub_nav { position: sticky; top: 61px; margin: 0 -3rem; border-bottom: 0.1rem solid #eee; overflow: auto; background-color: #fff; z-index: 20; }
    .sub_nav li { min-width: inherit; flex: inherit; flex-shrink: 0; outline: none; border-bottom: 0.2rem solid transparent; }
    .sub_nav li:hover,
    .sub_nav li.active { background-color: transparent; color: var(--primary); border-bottom-color: currentColor; }
    .sub_nav li a { padding: 3rem 2rem; }

    .sub_content_head { padding: 5rem 0; align-items: stretch; flex-direction: column; gap: 5rem; }
    .sub_content_head_img,
    .sub_content_head_img img { width: 100%; }
    .sub_content_head_text h2 { font-size: 4rem; font-weight: 700; margin-bottom: 3rem; }
    .sub_content_head_text strong { font-size: 3rem; word-break: keep-all; }
    .sub_head_desc { padding: 5rem 0; margin-top: 5rem; font-size: 2.5rem; }
    .sub_head_desc_tag { margin-top: 1.5rem; }
    .sub_head_desc_tag p { flex: inherit; flex-shrink: 0; font-size: inherit; padding: 0.4rem 1rem; }

    .sub_content_banner { margin-top: 10rem; padding-top: 15rem; background-color: #ededf1; }
    .sub_content_banner_text { padding-top: 5rem; background-color: rgba(255,255,255,0.5); }
    .sub_content_banner_text > span { font-size: 2rem;}
    .sub_content_banner_text p { font-size: 2.1rem; }
    .sub_content_banner_text p + p { margin-top: 2rem; font-size: 2.4rem; }
    .sub_content_banner_text p span { padding: 0 0.2em; }


    .sub_section { margin-top: 10rem; }
    .sub_section_title { font-size: 4rem; margin-bottom: 4rem; }
    .sub_section_table { overflow: auto; margin: 0 -3rem; padding: 0 3rem; }
    .sub_section_title span { display: block; font-size: 2rem; margin-top: 1rem; }
    .sub_section_table table { min-width: 110rem; table-layout: fixed; border-collapse: collapse; }
    .sub_section_desc { font-size: 2.4rem; }
    .sub_section_desc h4 { font-size: 2.4rem; margin-bottom: 1.5rem; }
    .sub_section_desc li + li { margin-top: 3rem; }
    .sub_section_desc + .sub_section_desc { margin-top: 3rem; } 
}


@media(max-width: 768px) {
    .botox_table { font-size: 2.2rem; }
    .botox_table th,
    .botox_table td { padding: 3rem 2rem; }
    .botox_table thead th { font-size: 2.4rem; }
    .botox_table .type { font-size: 2.3rem; }
}


.sub_item_01 { position: relative; display: flex; justify-content: flex-end; align-items: center; margin-top: 20px; gap: 0px; }
.sub_item_01_text { display: flex; justify-content: flex-start; align-items: center;  }
.sub_item_01_text span { display: flex; justify-content: center; align-items: center; width: 90px; height: 90px; border-radius: 50%; background-color: #e11047; color: #fff; font-size: 18px; }
.sub_item_01_text:after { content: ""; width: 200px; height: 1px; background-color: #e11047; }
.sub_item_01_img { position: relative; display: flex; justify-content: flex-start; align-items: center; width: auto; height: 300px;  }
.sub_item_01_img .img { position: absolute; left: 0; top: 0; z-index: -1; width: 100%; height: 100%; overflow: hidden; }
.sub_item_01_img .img img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.sub_item_01_img ul { min-width: 450px; height: 100%; padding: 50px; display: flex; justify-content: center; align-items: stretch; flex-direction: column; background-color: rgba(0,0,0,0.6); }
.sub_item_01_img span { display: inline-block; width: 1.5em; font-size: 24px; font-style: italic; color: #ffa1a1;  }
.sub_item_01_img li p { display: flex; justify-content: flex-start; align-items: baseline; font-size: 18px; gap: 0.2em; color: #fff; line-height: 1.5; }
.sub_item_01_img li + li { margin-top: 8px; }

.sub_item_01.reverse { justify-content: flex-start;}
.sub_item_01.reverse .sub_item_01_text,
.sub_item_01.reverse .sub_item_01_text span { order: 2; }

@media(max-width: 768px) {
   .sub_item_01,
   .sub_item_01_text { flex-direction: column; gap: 0; }
   .sub_item_01_text:after { width: 1px; height: 5rem; }
   .sub_item_01_img { width: 100%; }
   .sub_item_01_img span { font-size: 3rem; }
   .sub_item_01_img ul { padding: 5rem; width: 100%; min-width: inherit; }
   .sub_item_01_img li p  { font-size: 2.4rem; word-break: keep-all; }
}


.sub_section_bg { position: relative; left: 50%; width: 1920px; min-width: 1240px; transform: translateX(-50%); -webkit-translateX(-50%); height: 580px; max-width: 100vw;; }
.sub_section_bg .inner { height: 100%; }
.sub_section_bg_img { position: absolute; inset: 0; overflow: hidden; z-index: -1; background-color: #eee; }
.sub_section_bg_img img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.sub_section_bg_img.right { text-align: right; background-color: #fff; }
.sub_section_bg_img.left { text-align: left; background-color: #fff; }
.sub_section_bg_img.left img,
.sub_section_bg_img.right img { width: auto; }
.sub_section_bg_img_half { height: 280px; margin-bottom: 200px; }
.sub_section_bg_img_dk { background-color: #000; }
.sub_section_bg_img_dk img { opacity: 0.5; }
.sub_section_bg_img_max { width: 100%;  transform: translateX(0%); -webkit-translateX(0%); left: 0; }
.skin-fit-section.left { justify-content: flex-start;  }


.wrinkle-section { display: flex; justify-content: center; align-items: center; overflow: hidden; height: 100%; }
.wrinkle-list { padding: 100px 50px; display: flex; justify-content: center; align-items: flex-end; position: relative; gap: 50px; }
.wrinkle-card { width: 330px; height: 330px; border: 1px solid #e5e5e5; background: rgba(255, 255, 255, 0.82); transform: rotate(45deg); box-sizing: border-box; }
.wrinkle-card:nth-child(2n) { margin-bottom: 100px; }
.wrinkle-card .card-inner { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; transform: rotate(-45deg); text-align: center; color: #666;}
.wrinkle-card h4 { margin: 0; font-size: 18px; font-weight: 700; color: #555; }
.wrinkle-card .line { display: block; width: 1px; height: 23px; margin: 18px 0 19px; background: #bfbfbf; }
.wrinkle-card p { margin: 0; font-size: 15px; font-weight: 400; line-height: 1.75; letter-spacing: -0.04em; color: #777; }

.wrinkle-list-og { gap: 30px; align-items: stretch; }
.wrinkle-card-og,
.wrinkle-card-og .card-inner { position: relative; transform: none; }
.wrinkle-card-og { padding: 30px; width: 400px; min-height: 300px; height: inherit; } 
.wrinkle-card-og .card-inner { height: 100%; justify-content: flex-start; }
.wrinkle-card-og .t0 { font-size: 74px; font-weight: 600; margin-bottom: 20px; color: #a2a7a5; }
.wrinkle-card-og p { font-size: 16px; }
.wrinkle-card-og .t1 { color: #b8aad2; }
.wrinkle-card-og:nth-child(2n) { margin: 0; }


.wrinkle-list-2 { gap: 180px; }
.wrinkle-list-2 .wrinkle-card { width: 400px; height: 400px; }
.wrinkle-list-2 .wrinkle-card:nth-child(2n) { margin: 0; }

@media(max-width: 768px) {
    .wrinkle-section { align-items: stretch; }
    .sub_section_bg { width: 100%; min-width: 100%; height: inherit; left: 0; transform: translateX(-0%); -webkit-translateX(-0%); }
    .sub_section_bg .inner { padding: 0; }
    /* .sub_section_bg_img  { display: none; } */
    .sub_section_bg_img { position: relative; }
    .sub_section_bg_img_mo { position: absolute; }

    .wrinkle-list  { padding: 0rem; flex-direction: column; align-items: stretch; gap: 3rem; }
    .wrinkle-card:nth-child(2n) { margin-bottom: 0; }
    .wrinkle-card,
    .wrinkle-card .card-inner { position: relative; transform: none; }
    .wrinkle-card { width: 100%; height: inherit; background-color: #fff; }
    .wrinkle-card .card-inner  { padding: 3rem; gap: 2rem; align-items: flex-start; text-align: left; }
    .wrinkle-card h4 { font-size: 3rem; }
    .wrinkle-card p { font-size: 2.4rem; }
    .wrinkle-card .line { display: none; }

    .wrinkle-list-2 .wrinkle-card { width: 100%; height: inherit; }

    .wrinkle-list-og,
    .wrinkle-card-og { width: 100%; }
    .wrinkle-list-og { padding-top: 3rem; }
    .wrinkle-card-og { padding: 2rem }
    .wrinkle-card-og .t0 { font-size: 6rem; margin-bottom: 0rem; }
}


.skin-fit-section { display: flex; justify-content: flex-end; align-items: flex-end; width: 100%; height: 100%; padding: 80px 50px 30px;}
.skin-fit-wrap { display: flex; justify-content: flex-end; align-items: flex-end; gap: 0px; margin: auto 0; box-sizing: border-box;}
.skin-fit-box { position: relative; display: flex; align-items: center; justify-content: center; /* 텍스트 기반 크기 */ padding: 16px; width: max-content; /* 정사각 유지 */ aspect-ratio: 1 / 1; min-width: 180px; }
.skin-fit-box::before { content: ""; position: absolute; inset: 0; margin: auto; width: 100%; height: 100%; border: 1px solid #e5e5e5; background: rgba(255,255,255,0.65); transform: rotate(45deg); z-index: 0;}
.skin-fit-box.yellow::before { background-color: #fbe9a9; border-color: #fbe9a9; }
.skin-fit-box > * { position: relative; z-index: 1;}
.skin-fit-box:nth-child(2) { margin-bottom: 150px;}
.skin-fit-box ul { margin: 0; padding: 0; list-style: none;}
.skin-fit-box li { position: relative; padding-left: 10px; margin-bottom: 6px; font-size: 16px; line-height: 1.5; letter-spacing: -0.04em; color: #333; white-space: nowrap;}
.skin-fit-box li:last-child { margin-bottom: 0;}
.skin-fit-box li::before { content: ""; position: absolute; left: 0; top: 0.7em; width: 3px; height: 3px; border-radius: 50%; background: #b0182f;}
.skin-fit-box.no-mark li:before { display: none; }
.skin-fit-box.no-mark li { text-align: center; padding-left: 0; }

@media(max-width: 768px){
    .skin-fit-section { padding: 0rem; justify-content: flex-start; align-items: stretch; }
    .skin-fit-wrap { flex-direction: column; align-items: stretch; width: 100%; gap: 3rem; padding: 3rem; border: 1px solid #e5e5e5; }
    .skin-fit-box { aspect-ratio: inherit; width: 100%; justify-content: flex-start; padding: 0; border: 0; background: #fff; }
    .skin-fit-box + .skin-fit-box { border-top: 1px solid #e5e5e5; padding-top: 2rem; }
    .skin-fit-box::before { display: none; }
    .skin-fit-box:nth-child(2) { margin: 0; }
    .skin-fit-box ul { width: 100%; }
    .skin-fit-box.no-mark li { text-align: left; }
}

.skin-step-section { width: 100%; }
.skin-step-list { display: flex; gap: 8px; width: 100%; max-width: 1000px; margin: 0; padding: 0; list-style: none; }
.skin-step-item { max-width: 280px; display: flex; flex-direction: column; flex: 1 1 0; min-width: 0; border: 1px solid #ddd; box-sizing: border-box; min-height: 300px; }
.skin-step-text { flex-grow: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; height: 200px; padding: 30px 12px; text-align: center; box-sizing: border-box; background-color: #fff; }
.skin-step-text strong { margin-left: auto; margin-right: -10px; padding-right: 20px; text-align: right; margin-bottom: 30px; font-size: 30px; font-weight: 100; line-height: 1; color: #9e92ad; border-bottom: 1px solid currentColor; }
.skin-step-text p { margin: 0; font-size: 16px; line-height: 1.6; letter-spacing: -0.04em; color: inherit; margin: auto 0; word-break: keep-all; }
.skin-step-text h4 { margin: auto 0; font-size: 18px; text-align: left; line-height: 1.5; padding-bottom: 20px; }
.skin-step-text ul { margin: auto;  }
.skin-step-text li { display: flex; justify-content: flex-start; align-content: start; text-align: left; line-height: 1.8; }
.skin-step-text li:before { content: '·'; margin: 0 0.4em; }

.skin-step-img { width: 100%; overflow: hidden; }
.skin-step-img img { display: block; width: 100%; height: 100%; object-fit: cover; }
.skin-step-item:nth-child(even) .skin-step-text { background: #9d91b4; color: #fff; }
.skin-step-item:nth-child(even) .skin-step-text strong { color: #e6e2eb; }

@media(max-width: 768px){
    .skin-step-list { gap: 2rem; flex-wrap: wrap; }
    .skin-step-item { flex: 0 1 calc(50% - 1rem); }
    .skin-step-text { padding: 1.5rem; height: inherit; min-height: 30rem; }
    .skin-step-text strong { font-size: 4rem; margin-bottom: 2rem; padding-right: 1.5rem,; margin-right: -1.5rem; }
    .skin-step-text p { font-size: 2rem; word-break: keep-all; }
    .skin-step-text h4 { font-size: 2.4rem; }
    .skin-step-item { max-width: inherit; min-height: 35rem; }
}

.step-flow-section { position: relative; width: 100%; overflow: hidden; }
.step-flow-list { display: flex; margin: 0; padding: 0; list-style: none; }
.step-flow-item { position: relative; flex: 1 1 0; }
/* 이미지 영역 */.step-flow-img { width: 100%; height: 460px; }
.step-flow-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* 어두운 오버레이 */
.step-flow-item::after { content: ""; position: absolute; inset: 0; background: rgba(0,0,0,0.6); }
/* 텍스트 영역 */
.step-flow-text { position: absolute; inset: 0; z-index: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: #fff; }
/* STEP 타이틀 */
.step-flow-text strong { font-size: 36px; font-weight: 300; letter-spacing: 0.05em; color: #ff8a8a; }
/* 설명 */
.step-flow-text p { margin-top: 16px; font-size: 16px; line-height: 1.5; }

/* =========================
   📱 반응형 (모바일)
========================= */
@media (max-width: 768px) { 
    .step-flow-list { flex-direction: column; }
    .step-flow-img { height: 300px; }
    .step-flow-text strong { font-size: 4rem; }
    .step-flow-text p { font-size: 2.4rem; margin-top:1rem; }
}

.face-point-section {
    width: 100%;
    overflow: hidden;
}

.face-point-inner {
    position: relative;
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
}

.face-point-img {
    display: block;
    width: 100%;
    height: auto;
}

.face-point-list {
    position: absolute;
    inset: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.face-point-item {
    position: absolute;
    display: flex;
    align-items: center;
}

.point-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.point-text strong {
    font-size: 15px;
    font-weight: 700;
    color: #333;
}

.point-text span {
    min-width: 156px;
    padding: 5px 14px;
    background: #4b2d79;
    font-size: 18px;
    line-height: 1.2;
    color: #fff;
    text-align: center;
    box-sizing: border-box;
}

.point-line {
    display: block;
    width: clamp(120px, 18vw, 285px);
    height: 1px;
    background: #7f68a9;
}

.point-circle {
    display: block;
    width: 54px;
    aspect-ratio: 1 / 1;
    border: 1px solid rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.18);
    box-sizing: border-box;
}

.point-01 {
    left: 12%;
    top: 31%;
}

.point-02 {
    left: 20%;
    top: 54%;
}

.point-03 {
    left: 34%;
    top: 48%;
}

.point-04 {
    left: 12%;
    top: 41%;
}

.point-05 {
    left: 16%;
    top: 12%;
}

.point-06 {
    left: 9%;
    top: 20%;
}

.point-07 {
    left: 9%;
    top: 30%;
}

.point-08 {
    left: 20%;
    top: 40%;
}

.point-09 {
    left: 10%;
    top: 46%;
}

.point-10 {
    left: 15%;
    top: 54%;
}


@media (max-width: 768px) {
    .face-point-list {
        display: grid;
        gap: 1rem;
        padding: 20px;
    }

    .face-point-item {
        position: static;
    }

    .point-line,
    .point-circle {
        display: none;
    }
    .point-text { background-color: #fff; }
    .point-text strong {
        font-size: 2rem;
        padding: 0.5rem 0 0;
    }
    .point-text span {
        min-width: 28rem;
        font-size: 2.4rem;;
    }

    .point-05 .point-text span,
    .point-05 ~ .face-point-item .point-text span {
        min-width: 22rem;
    }
}

.nonsurgery-section {
    width: 100%;
    padding: 80px 0;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    background: #fff;
}

.nonsurgery-inner {
   padding-left: 150px;
}

/* 타이틀 */
.nonsurgery-title {
    margin: 0;
    font-size: 42px;
    font-weight: 300;
    letter-spacing: 0.08em;
    color: #444;
}

.nonsurgery-title span {
    color: #9bb3d9; /* 연한 블루 포인트 */
    font-weight: 400;
}

/* 설명 */
.nonsurgery-desc {
    margin-top: 20px;
    font-size: 16px;
    line-height: 1.7;
    color: #666;
}

.nonsurgery-desc strong {
    font-size: 1.3em;
    font-weight: 700;
    color: #333;
}

@media (max-width: 768px) {
    .nonsurgery-section { padding: 8rem 0; }
    .nonsurgery-inner { padding: 0 5rem; text-align: center; }
    .nonsurgery-title { font-size: 6rem; }
    .nonsurgery-desc { margin-top: 2rem; font-size: 2.4rem; }
}


.hiko-info-section {
    width: 100%;
    background: #fff;
    overflow: hidden;
}

.hiko-info-inner {
    position: relative;
    display: flex;
    align-items: center;
    margin: 0 auto;
    background-color: #dfdfdf;
}

.hiko-info-text {
    position: absolute;
    left: 0;
    top: 14%;
    z-index: 2;
    padding: 50px;
}

.hiko-info-list {
    display: flex;
    flex-direction: column;
    gap: 46px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.hiko-info-list li {
    display: flex;
    align-items: center;
    gap: 18px;
}
.hiko-info-list li:nth-child(odd) {
    margin-left: 50px;
}

.hiko-info-list em {
    min-width: 76px;
    font-style: normal;
    font-size: 74px;
    font-weight: 600;
    line-height: 0.85;
    letter-spacing: -0.06em;
    color: #c9c9c9;
}

.hiko-info-list li:nth-child(3) em {
    color: #bab0de;
}

.hiko-info-list h3 {
    margin: 0 0 8px;
    font-size: 20px;
    font-weight: 700;
    color: #333;
}

.hiko-info-list p {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    letter-spacing: -0.05em;
    color: #777;
}

.hiko-info-visual {
    position: relative;
    width: 64%;
    margin-left: auto;
}

.hiko-info-visual > img {
    display: block;
    width: 100%;
    height: auto;
}

.hiko-point {
    position: absolute;
    left: 24%;
    top: 31%;
    display: flex;
    align-items: center;
}

.hiko-circle {
    width: 150px;
    aspect-ratio: 1;
    border: 4px solid #fff;
    border-radius: 50%;
    overflow: hidden;
    box-sizing: border-box;
}

.hiko-circle img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hiko-line {
    width: 240px;
    height: 1px;
    background: #8a70b0;
}

.hiko-dot {
    width: 7px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: #4c2c82;
}

@media (max-width: 768px) {
    .hiko-info-inner {
        flex-direction: column;
        align-items: stretch;
        min-height: auto;
        padding: 0;
        background-color: #fff;
    }

    .hiko-info-text {
        position: relative;
        width: 100%;
        flex: none;
        order: 2;
        padding: 0rem
    }

    .hiko-info-visual {
        order: 1;
        margin-left: 0;
        width: 100%;
    }

    .hiko-info-list {
        gap: 30px;
        margin-top: 30px;
    }

    .hiko-info-list li {
        align-items: flex-start;
        gap: 1rem;
    }
    .hiko-info-list li:nth-child(odd) {
        margin-left: 0;
    }
    .hiko-info-list li:last-child br { 
        display: none;
    }

    .hiko-info-list em {
        min-width: 1.3em;
        font-size: 6rem;
    }
    .hiko-info-list h3 {
        font-size: 3rem;
    }
    .hiko-info-list p {
        font-size: 2.4rem;
        word-break: keep-all;
    }

    .hiko-point {
        left: 14%;
        top: 25%;
    }

    .hiko-circle {
        width: 22vw;
        min-width: 90px;
        max-width: 140px;
        border-width: 3px;
    }

    .hiko-line {
        width: 22vw;
    }
}

.burial-method-section {
    width: 100%;
    background: #fff;
}

.burial-method-inner {
    margin: 0 auto;
    padding: 28px 0 58px;
    box-sizing: border-box;
}

.burial-method-head {
    display: flex;
    align-items: center;
    gap: 24px;
}

.burial-method-label {
    position: relative;
    flex: 0 0 110px;
    width: 110px;
    aspect-ratio: 1 / 1;
    border: 1px solid #d8d8d8;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.burial-method-label::after {
    content: "";
    position: absolute;
    right: -12px;
    bottom: -1px;
    width: 16px;
    height: 1px;
    background: #d8d8d8;
    transform: rotate(45deg);
    transform-origin: left center;
}

.burial-method-label strong {
    position: relative;
    z-index: 1;
    font-size: 27px;
    font-weight: 700;
    color: #222;
}

.burial-method-label span {
    position: absolute;
    left: -6px;
    bottom: -15px;
    font-size: 48px;
    font-weight: 300;
    line-height: 1;
    color: #d8d1e8;
}

.burial-method-head p {
    margin: 0;
    font-size: 16px;
    line-height: 1.8;
    letter-spacing: -0.04em;
    color: #777;
}

.burial-method-process {
    margin-top: 12px;
    padding-left: 132px;
    max-width: 1200px;
}

.burial-method-process h3 {
    margin: 0 0 18px;
    font-size: 20px;
    font-weight: 700;
    color: #111;
}

.burial-step-list {
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.burial-step-list li {
    flex: 1;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
    min-height: 275px;
    padding: 26px 10px;
    border: 1px solid #d8d8d8;
    text-align: center;
    box-sizing: border-box;
}

.burial-step-list li:nth-child(2) {
    background: #9f94b7;
    border-color: #9f94b7;
    color: #fff;
}

.burial-step-list strong {
    margin-bottom: 58px;
    margin-left: auto;
    margin-right: -10px;
    padding-right: 20px;
    font-size: 32px;
    font-weight: 300;
    line-height: 1;
    border-bottom: 1px solid currentColor;
    color: #cfc8df;
}

.burial-step-list li:nth-child(2) strong {
    color: #eeeaf5;
}

.burial-step-list h4 {
    width: 100%;
    margin: 0 0 20px;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5;
    color: inherit;
}

.burial-step-list p {
    width: 100%;
    margin: 0;
    font-size: 16px;
    line-height: 1.7;
    letter-spacing: -0.04em;
    color: #777;
}

.burial-step-list li:nth-child(2) p {
    color: #fff;
}

.burial-reference {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 10px;
}

.burial-reference span {
    font-size: 12px;
    color: #777;
    margin-bottom: 5px;
}

.burial-reference img {
    display: block;
    height: 90px;
}

.burial-summary {
    margin: 42px 0 0;
    padding-left: 132px;
}

.burial-summary div {
    display: flex;
    align-items: flex-start;
    gap: 48px;
    margin-bottom: 20px;
}

.burial-summary div:last-child {
    margin-bottom: 0;
}

.burial-summary dt {
    flex: 0 0 80px;
    font-size: 20px;
    font-weight: 700;
    color: #111;
}

.burial-summary dd {
    margin: 0;
    font-size: 16px;
    line-height: 1.7;
    letter-spacing: -0.04em;
    color: #777;
}

@media (max-width: 768px) {
    .burial-method-section + .burial-method-section { margin-top: 12rem; }
    .burial-method-inner {
        width: 100%;
        padding: 0;
    }

    .burial-method-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 18px;
    }

    .burial-method-label {
        flex-basis: auto;
        width: 96px;
    }

    .burial-method-label strong {
        font-size: 4rem;
    }

    .burial-method-label span {
        font-size: 8rem;
    }
    .burial-method-head p {
        font-size: 2rem;
    }
    .burial-method-head p br {
        display: none;
    }

    .burial-method-process {
        margin-top: 34px;
        padding-left: 0;
    }
    .burial-method-process h3 {
        font-size: 4rem;
        margin-bottom: 2rem;
    }

    .burial-step-list {
        flex-direction: column;
        gap: 1rem;
    }

    .burial-step-list li {
        min-height: 34rem;
        padding: 3rem;
    }

    .burial-step-list strong {
        margin-bottom: 5rem;
        font-size: 5rem;
        margin-right: -3rem;
        padding-right: 3rem;
    }
    .burial-step-list h4 {
        font-size: 3rem;
        margin-bottom: 2rem;
    }
    .burial-step-list p {
        font-size: 2.4rem;
    }

    .burial-reference {
        flex-direction: column;
        align-items: flex-start;
    }

    .burial-reference img {
        width: 100%;
        max-width: none;
        height: auto;
    }
    .burial-reference span {
        font-size: 2rem;
        margin-bottom: 0;
    }

    .burial-summary {
        padding-left: 0;
        margin-top: 36px;
    }
    .burial-summary dt {
        font-size: 3rem;
    }
    .burial-summary dd {
        font-size: 2.4rem;
    }

    .burial-summary div {
        flex-direction: column;
        gap: 8px;
    }

    .burial-summary dt {
        flex: none;
    }
}


.caution-section {
    position: relative;
    width: 100%;
    padding: 60px 0 0;
    overflow: hidden;
}

/* 배경 (full width) */
.caution-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 260px;
    background: url('/images/caution-bg.jpg') center / cover no-repeat;
    z-index: 0;
}

/* inner (1240 고정) */
.caution-inner {
    position: relative;
    width: 1240px;
    margin: 0 auto;
    z-index: 1;
    text-align: center;
}

/* 타이틀 */
.caution-title {
    margin: 0 0 40px;
    font-size: 45px;
    font-weight: 300;
    letter-spacing: -0.02em;
    color: #fff;
}

h4.caution-title {
    font-size: 45px;
}

.caution-title span {
    color: #e7c47a;
}

/* 박스 */
.caution-box {
    width: 100%;
    max-width: 920px;
    margin: 0 auto;
    padding: 48px 60px;
    border: 1px solid #ddd;
    background-color: #fff;
    background-image:
        linear-gradient(#eaeaea 1px, transparent 1px),
        linear-gradient(90deg, #eaeaea 1px, transparent 1px);
    background-size: 12px 12px;
}

/* 리스트 */
.caution-box ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.caution-box li {
    position: relative;
    margin-bottom: 14px;
    padding-left: 14px;
    font-size: 16px;
    line-height: 1.7;
    color: #555;
    text-align: left;
}

.caution-box li:last-child {
    margin-bottom: 0;
}

/* - 표시 */
.caution-box li::before {
    content: "-";
    position: absolute;
    left: 0;
    top: 0;
}
@media (max-width: 768px) {
    .sub_section_bg_img_half {
        margin-bottom: 0;
    }
    .sub_section_bg_img_half .sub_section_bg_img {
        display: block;
    }

    .caution-section {
        padding: 12rem 5rem;
    }

    .caution-title {
        font-size: 5rem;
        margin-bottom: 3rem;
    }

    .caution-box {
        padding: 3rem;
        width: 100%;
        margin: 0;
    }

    .caution-inner {
        width: 100%;
    }

    .caution-box li {
        font-size: 2.4rem;
        margin-bottom: 2rem;;
    }
}


.eye-step-section {
    width: 100%;
    overflow: hidden;
}

.eye-step-inner {
    display: flex;
    align-items: stretch;
    margin: 0 auto;
}

/* 왼쪽 카드 영역 */
.eye-step-content {
    flex: 1;
}

.eye-step-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin: 0;
    padding: 0;
    list-style: none;
    max-width: 860px;
}

/* 카드 */
.eye-step-list li {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;

    border: 1px solid #ddd;
    padding: 20px;
    min-height: 180px;
    box-sizing: border-box;
}
.eye-step-list li:empty { border: 0; }

/* Step 타이틀 */
.eye-step-list strong {
    display: block;
    margin-bottom: 50px;
    font-size: 28px;
    font-weight: 300;
    color: #cfc8df;
    margin-left: auto;
    margin-right: -20px;
    padding-right: 20px;
    border-bottom: 1px solid currentColor;
}

/* 내부 구조 */
.eye-step-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
}

.eye-step-body p {
    margin: 0;
    font-size: 16px;
    font-weight: 500;
    color: #333;
}

.eye-step-body img {
    width: 100px;
    height: auto;
}

/* 오른쪽 이미지 */
.eye-step-visual {
    flex: 0 0 360px;
    margin-left: 20px;
}

.eye-step-visual img {
    width: 100%;
    height: auto;
    display: block;
}

@media (max-width: 768px) {
    .eye-step-inner {
        flex-direction: column;
    }
    .eye-step-list { gap: 3rem; }
    .eye-step-list li:empty  { display: none; }

    .eye-step-visual {
        order: -1;
        margin-left: 0;
        margin-bottom: 20px;
    }

    .eye-step-list {
        grid-template-columns: repeat(2, 1fr);
    }
    .eye-step-list strong { font-size: 4rem; margin-bottom: 5rem; }
    .eye-step-body p { font-size: 3rem; margin-bottom: 1rem; }
    .eye-step-body img { width: 20rem; }
    .eye-step-body { flex-direction: column; }
}


.eye-correction-section {
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    width: 100%;
    background: #fff;
}

.eye-correction-img {
    margin-left: auto;
    height: 505px;
}
.eye-correction-img img {
    height: 100%;
}

.eye-correction-inner {
   
}

.eye-correction-box {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;

    width: 370px;
    min-height: 225px;
    padding: 30px 30px 32px;
    border: 1px solid #ddd;
    background: #fff;
    box-sizing: border-box;
}

.eye-correction-box + .eye-correction-box {
    margin-top: 14px;
}

.eye-correction-box h4 {
    margin-bottom: 20px;
    margin-left: auto;
    margin-right: -30px;
    padding-right: 30px;
    border-bottom: 1px solid currentColor;
    font-size: 27px;
    font-weight: 300;
    line-height: 1;
    color: #ff7fa0;
    text-align: center;
}

.eye-correction-box ul {
    margin: 0;
    padding: 0;
    list-style: none;
    width: 100%;
}

.eye-correction-box li {
    position: relative;
    margin-bottom: 8px;
    padding-left: 12px;
    font-size: 16px;
    line-height: 1.45;
    letter-spacing: -0.04em;
    color: #555;
    word-break: keep-all;
}

.eye-correction-box li:last-child {
    margin-bottom: 0;
}

.eye-correction-box li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: #ec5f8f;
}

.eye-correction-box.is-pink {
    border-color: #ec6790;
    background: #ec6790;
}

.eye-correction-box.is-pink h4 {
    border-bottom-color: rgba(255,255,255,0.35);
    color: #fff;
}

.eye-correction-box.is-pink li {
    color: #fff;
}

.eye-correction-box.is-pink li::before {
    background: #fff;
}

@media (max-width: 768px) {
    .eye-correction-section { 
        flex-direction: column;
    }
    .eye-correction-inner {
        order: 2;
    }
    .eye-correction-img {
        width: 100%;
        height: 80rem;
        overflow: hidden;
    }
    .eye-correction-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
    }

    .eye-correction-box {
        width: 100%;
        min-height: auto;
        padding: 5rem;
    }

    .eye-correction-box h4 {
        font-size: 4rem;
        margin-bottom: 4rem;
        margin-right: -5rem;
        padding-right: 5rem;
    }

    .eye-correction-box li {
        font-size: 2.4rem;
    }
}

.target-face-section {
    width: 100%;
    height: 100%;
}

.target-face-inner {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    height: 100%;
    margin: 0 auto;
}

/* 핵심 grid */
.target-face-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    width: 630px; /* 좌측 영역만 */
}

/* 기본 박스 */
.target-face-grid .box {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: left;
    aspect-ratio: 1/1;
    padding: 16px;
    border: 1px solid #ddd;
    background-color: rgba(255, 255, 255, 0.9);
    font-size: 16px;
    line-height: 1.6;
    color: #555;
    box-sizing: border-box;
}

/* 핑크 박스 */
.target-face-grid .box:last-child {
    background: rgba(250, 198, 202, 0.9);
    border: none; 
}

@media (max-width: 768px) {
    .target-face-grid {
        width: 100%;
        grid-template-columns: repeat(2, 1fr);
        margin-top: 3rem;
        gap: 2rem;
    }

    .target-face-grid .box {
        font-size: 2.4rem;
        padding: 1.5rem;
        aspect-ratio: 1.3/1;
    }

    .target-face-grid .empty {
        display: none;
    }
}

.procedure_list { }
.procedure_step { position: relative; padding: 50px 0px; display: flex; justify-content: flex-start; align-items: flex-start; gap: 30px; background-color: #f8f6fb; }
.procedure_step:before { content: ""; position: absolute; inset: 0; left: -340px; right: -340px; background-color: #f8f6fb; z-index: -1; }
.procedure_step img { width: 160px; }
.procedure_step p { font-size: 18px; text-align: center; margin-top: 10px; }
@media (max-width: 768px) {
    .procedure_list { margin: 0 -3rem; overflow: auto; }
    .procedure_step { padding: 5rem 0; position: static; }
    .procedure_step li { flex-shrink: 0; width: 23rem; }
    .procedure_step img { width: 100%; }
    .procedure_step p { font-size: 3rem; margin-top: 1.5rem; }
    .procedure_step:before { height: 38rem; bottom: 0; top: auto; right: -3rem; }
}

.treatment-list-section {
    width: 100%;
    background: #fff;
}

.treatment-list-inner {
    width: 1205px;
    margin: 0 auto;
}

/* 리스트 */
.treatment-list {
    max-width: 900px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    border: 1px solid #ddd;
    border-bottom: none;
    background-color: #fff;
}

/* 한 줄 */
.treatment-list li {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

/* 셀 */
.treatment-list span {
    display: flex;
    align-items: center;
    justify-content: flex-start;

    min-height: 68px;
    padding: 10px 30px;

    border-bottom: 1px solid #ddd;
    border-right: 1px solid #ddd;

    font-size: 16px;
    line-height: 1.5;
    color: #555;
    text-align: center;
    box-sizing: border-box;
}

/* 마지막 열 border 제거 */
.treatment-list span:nth-child(2n) {
    border-right: none;
}

@media (max-width: 768px) {
    .treatment-list-inner {
        width: 100%;
        padding: 0 16px;
        box-sizing: border-box;
    }
    h4.caution-title { 
        font-size: 5rem;
    }

    .treatment-list li {
        grid-template-columns: 1fr;
    }

    .treatment-list span {
        border-right: none;
        text-align: left;
        display: block;
        justify-content: flex-start;
        min-height: auto;
        padding: 2.5rem;
        font-size: 2.2rem;
        word-break: keep-all;
        line-height: 1.5;
    }

    .treatment-list span:empty {
        display: none;
    }
}

.process-photo-section {
    position: relative;
    z-index: 10;
}
.process-photo-list {
    display: flex;
    gap: 20px;
    margin: 0;
    padding: 0 0 80px;
    list-style: none;
}
.process-photo-list li > p {
    text-align: center;
    padding-top: 30px;
}
.process-photo-list li > p span {
    color: #c8c0d8;
    font-weight: 500;
}

.process-photo-item {
    position: relative;
    flex: 1;
    text-align: center;
}
.process-photo-item.is-current {
    flex:inherit;
    flex-shrink: 0;
    width: 80px;
    background-color: #4b2486;
}

.process-photo-arrow {
    position: absolute;
    left: 50%;
    top: 88%;
    transform: translateX(-50%);
    flex-direction: column;

    width: 180px;
    height: 130px;

    background: #4b2486;
    color: #fff;
    font-size: 14px;
    font-weight: 600;

    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0 60px;

    clip-path: polygon(
        0 0,
        100% 0,
        50% 100%,
        50% 100%
    );
}
.process-photo-arrow p {
    color: #e8d89e;
}

.process-photo-arrow::before {
    content: "";
    position: absolute;
    left: 50%;
    top: -14px;
    transform: translateX(-50%);

    width: 84px;
    height: 14px;
    background: #4b2486;
}

@media(max-width: 768px){
    .procedure_list { display: flex; justify-content: flex-start; align-items: stretch; flex-direction: column; padding: 0rem 3rem; }
    .process-photo-list { padding: 0rem 3rem 12rem; margin: 0 -3rem; }
    .process-photo-list li:not(.is-current) { flex: 0 0 45rem; }
    .process-photo-list li > p { padding-top: 3rem; font-size: 3rem; }
    .process-photo-list li img { width: 100%; }
}


/* 좌측 텍스트 */
.fcr-text {
    
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 600px;
    height: 100%;
    padding: 60px 40px;
    background: rgba(120, 105, 150, 0.9);
    color: #fff;
    box-sizing: border-box;
}
.fcr-text.pink {
    background: rgba(244, 159, 173, 0.8);
}
.fcr-text.right { 
    margin-left: auto;
}

/* 타이틀 */
.fcr-text h3 {
    margin: 0;
    font-size: 28px;
    font-weight: 400;
    text-align: center;
}

/* 라인 */
.fcr-text .line {
    display: block;
    width: 1px;
    height: 30px;
    margin: 18px auto 28px;
    background: rgba(255,255,255,0.6);
}

/* 텍스트 */
.fcr-text .desc {
    margin: 0 0 18px;
    font-size: 16px;
    line-height: 1.8;
    letter-spacing: -0.03em;
    text-align: center;
    color: rgba(255,255,255,0.9);
}

.fcr-text .strong {
    font-weight: 700;
    margin-top: 24px;
}

.fcr-text .dl {  border: 1px solid #fff; border-left: 0; border-right: 0;; }
.fcr-text .dl dl { display: flex; justify-content: flex-start; align-items: stretch; }
.fcr-text .dl dl + dl { border-top: 1px solid #fff; }
.fcr-text dt,
.fcr-text dd { padding: 20px 20px; }
.fcr-text dt { width: 180px; }
.fcr-text dd { border-left:  1px solid #fff; }

@media(max-width: 768px){
    .inner_1920 { min-width: inherit; max-width: 100%; }
    .fcr-text { width: 100%; padding: 5rem; }
    .fcr-text h3 { font-size: 4rem; }
    .fcr-text .desc { font-size: 2.4rem; margin-bottom: 3rem; }
    .fcr-text .desc br { display: none; }
    .fcr-text .line { height: 5rem; margin: 2rem auto; }
    .fcr-text .strong { margin-top: 3rem;; }

    .fcr-text dd,
    .fcr-text dt { padding: 2rem 2rem; } 
    .fcr-text dt { width: 20rem; }
}

.triple-red-section {
    width: 100%;
    background: #fff;
}

.triple-red-inner {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    align-items: stretch;
    margin: 0 auto;
}

.triple-red-content {
    padding: 46px 28px 52px;
    border: 1px solid #ff3030;
    text-align: center;
    box-sizing: border-box;
}

.triple-red-desc {
    margin: 0 0 12px;
    font-size: 14px;
    color: #777;
}

.triple-red-content h3 {
    margin: 0 0 52px;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 42px;
    font-weight: 400;
    line-height: 1;
    color: #222;
}

.triple-red-content h3 span {
    color: #ff3030;
}

.triple-red-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin: 0;
    padding: 0;
    list-style: none;
}

.triple-red-list li {
    padding: 0 28px;
    border-right: 1px solid #f0b0b0;
    box-sizing: border-box;
}

.triple-red-list li:last-child {
    border-right: 0;
}

.triple-red-list strong {
    display: block;
    margin-bottom: 28px;
    font-size: 26px;
    font-weight: 300;
    color: #bcbcbc;
}

.triple-red-list p {
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
    color: #333;
}

.triple-red-visual {
    position: relative;
    min-height: 350px;
}

.triple-red-visual > img {
    display: block;
    width: 100%;
    height: auto;
}

.triple-red-tags {
    position: absolute;
    inset: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.triple-red-tags li {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 74px;
    aspect-ratio: 1 / 1;
    border: 1px solid #ff3030;
    border-radius: 50%;
    background: #fff;
    font-size: 16px;
    line-height: 1.35;
    color: #444;
    text-align: center;
    box-sizing: border-box;
}

.triple-red-tags li.is-active {
    background: #ff3030;
    color: #fff;
}

.triple-red-tags li:nth-child(1) {
    right: 110px;
    top: 0;
}

.triple-red-tags li:nth-child(2) {
    right: 28px;
    top: 48px;
}

.triple-red-tags li:nth-child(3) {
    right: 0;
    top: 142px;
}

.triple-red-tags li:nth-child(4) {
    right: 110px;
    bottom: 38px;
}

.triple-red-tags li:nth-child(5) {
    right: 24px;
    bottom: 94px;
}

@media (max-width: 768px) {
    .triple-red-inner {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .triple-red-content {
        padding: 3rem;
    }

    .triple-red-content h3 {
        margin-bottom: 3rem;
        font-size: 4rem;
    }

    .triple-red-desc {
        font-size: 2rem;
    }

    .triple-red-list {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .triple-red-list strong {
        font-size: 4rem;
        color: #666;
    }
    .triple-red-list p {
        font-size: 2.4rem;
    }

    .triple-red-list li {
        padding: 0;
        border-right: 0;
        border-bottom: 1px solid #f0b0b0;
        padding-bottom: 24px;
    }

    .triple-red-list li:last-child {
        border-bottom: 0;
        padding-bottom: 0;
    }

    .triple-red-list strong {
        margin-bottom: 10px;
        font-size: 22px;
    }

    .triple-red-visual {
        min-height: auto;
    }

    .triple-red-tags li {
        font-size: 2.4rem;
        width: 12rem;
        word-break: keep-all;
    }
    .triple-red-tags li:nth-child(1) { top: 5%;  right: 25%; }
    .triple-red-tags li:nth-child(4) { bottom: 5%; right: 25%; }
    .triple-red-tags li:nth-child(2) { top: 16%; right: 8%; }
    .triple-red-tags li:nth-child(5) { bottom: 16%; right: 8%; }
    .triple-red-tags li:nth-child(3) { top: 40%; right: 0%; }

}

.tip-section {
    width: 100%;
    position: relative;
    margin-top: 80px;
}

/* 좌측 텍스트 */
.tip-content {
    
}

/* 상단 헤드 */
.tip-head {
    display: flex;
    align-items: center;
    gap: 0px;
}

/* TIP 원형 */
.tip-badge {
    display: flex;
    align-items: center;
    justify-content: center;

    width: 64px;
    height: 64px;
    border-radius: 50%;

    background: #e91e63;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
}

/* 타이틀 */
.tip-head h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 700;
    color: #e91e63;
    padding: 4px 15px;
    margin-left: -3px;
    border-bottom: 1px solid currentColor;
}

/* 설명 */
.tip-desc {
    margin: 0;
    font-size: 16px;
    line-height: 1.8;
    color: #666;
    padding-left: 80px;
}

/* 이미지 */
.tip-visual {
    width: 40%;
    text-align: right;
}

.tip-visual img {
    max-width: 100%;
    height: auto;
}

@media (max-width: 768px) {
    .tip-badge { width: 12rem; height: 12rem; font-size: 3rem; }
    .tip-head h3 { font-size: 3rem; padding: 1rem 2rem; margin-left: -1rem; }
    .tip-desc { padding: 3rem; font-size: 2.4rem; }
}

.laser-feature-section {
    width: 100%;
    background: #fff;
}

.laser-feature-inner {
    position: relative;
    margin: 0 auto;
}

.laser-feature-img {
    width: 360px;
    margin: 0 auto;
}

.laser-feature-img img {
    display: block;
    width: 100%;
    height: auto;
}

.laser-feature-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.laser-feature-list li {
    position: absolute;
    width: 430px;
}

.laser-feature-list h3 {
    display: inline-block;
    min-width: 220px;
    margin: 0 0 10px;
    padding: 4px 8px;
    background: #6741a0;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
    color: #fff;
    box-sizing: border-box;
}

.laser-feature-list p {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    letter-spacing: -0.04em;
    color: #666;
}

.pos-left-top {
    left: 0;
    top: 88px;
    text-align: left;
}

.pos-left-bottom {
    left: 0;
    bottom: 70px;
    text-align: left;
}

.pos-right-top {
    right: 0;
    top: 88px;
    text-align: right;
}

.pos-right-bottom {
    right: 0;
    bottom: 70px;
    text-align: right;
}

@media (max-width: 768px) {
    .laser-feature-inner {
        min-height: auto;
    }

    .laser-feature-img {
        width: 100%;
        margin-bottom: 3rem;
    }

    .laser-feature-list {
        display: grid;
        gap: 24px;
    }

    .laser-feature-list li {
        position: static;
        width: 100%;
        text-align: left;
    }

    .laser-feature-list h3 {
        width: 100%;
        min-width: 0;
        font-size: 3rem;
    }
    .laser-feature-list p {
        font-size: 2.4rem;
    }
    .laser-feature-list p br {
        display: none;
    }
}

.body-part-section {
    width: 100%;
    background: #fff;
}

.body-part-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 430px 1fr;
    align-items: center;
    margin: 0 auto;
    padding: 50px 80px;
}

.body-part-list {
    margin: 0;
}

.body-part-list div {
    margin-bottom: 22px;
}

.body-part-list div:last-child {
    margin-bottom: 0;
}

.body-part-list dt {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 66px;
    height: 34px;
    margin-bottom: 10px;
    padding: 0 18px;
    border: 1px solid #d8d8d8;
    background-color: #fff;
    border-radius: 999px;
    font-size: 18px;
    font-weight: 700;
    color: #555;
    box-sizing: border-box;
}

.body-part-list .is-active dt {
    border-color: #a99bc1;
    background: #a99bc1;
    color: #fff;
}

.body-part-list dd {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    letter-spacing: -0.04em;
    color: #000;
}

.body-part-img {
    position: absolute;
    inset: 0;
    z-index: -1;
    min-width: 0;
    text-align: right;
    overflow: hidden;
}

.body-part-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    opacity: 0.4;
}


@media (max-width: 768px) {
    .body-part-inner {
        grid-template-columns: 1fr;
        gap: 3rem;
        padding: 5rem;
    }

    .body-part-content {
        order: 2;
    }

    .body-part-img {
        order: 1;
        text-align: center;
    }
    .body-part-list div {
        margin-bottom: 5rem;
    }
    .body-part-list dt {
        font-size: 2.8rem;
        padding: 0.5rem 2rem;
        margin-bottom: 2rem;;
    }
    .body-part-list dd {
        font-size: 2.4rem;
    }
    .body-part-list dd br {
        display: none;
    }
}

.sub_section_desc + .step-flow-section {
    margin-top: 50px;
}
.step-flow-card .step-flow-list {
    gap: 0;
}

.step-flow-card .step-flow-item {
    position: relative;
    flex: 1 1 0;
    min-height: 410px;
    overflow: hidden;
}

.step-flow-card .step-flow-img {
    width: 100%;
    height: 100%;
}

.step-flow-card .step-flow-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* 중앙 카드 */
.step-flow-card .step-flow-text {
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);

    width: 250px;
    aspect-ratio: 1 / 1;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    background: rgba(229, 45, 98, 0.82);
    color: #fff;
    text-align: center;
    box-sizing: border-box;
}

.step-flow-card .step-flow-item.is-dark .step-flow-text {
    background: rgba(0, 0, 0, 0.55);
}

.step-flow-card .step-flow-text strong {
    margin-bottom: 28px;
    font-size: 24px;
    font-weight: 300;
    color: #fff;
}

.step-flow-card .step-flow-text p {
    min-width: 140px;
    margin: 0;
    padding: 12px 20px;
    border: 1px solid rgba(255,255,255,0.8);
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .sub_section_desc + .step-flow-section {
        margin-top: 5rem;
    }
    .step-flow-card .step-flow-list {
        flex-direction: column;
    }

    .step-flow-card .step-flow-item {
        min-height: 48rem;
    }

    .step-flow-card .step-flow-text {
        width: 35rem;
    }

    .step-flow-card .step-flow-text strong {
        font-size: 3rem;
        margin-bottom: 2rem;
    }
    .step-flow-card .step-flow-text p {
        font-size: 2.4rem;
        padding: 2rem 2rem;
    }
}

.step-flow-compare {
    position: relative;
}

.step-flow-compare .step-flow-list {
    gap: 0;
}

.step-flow-compare .step-flow-item {
    position: relative;
    flex: 1;
    overflow: hidden;
}

/* 어둡게 */
.step-flow-compare .step-flow-item::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}

/* 텍스트 */
.step-flow-compare .step-flow-text {
    position: absolute;
    width: 60%;
    height: 60%;
    left: 20%;
    top: 20%;
    text-align: center;
    color: #fff;
    padding: 30px;
    z-index: 2;
}

.step-flow-compare .step-flow-text strong {
    display: block;
    margin-bottom: 10px;
    font-size: 26px;
    font-weight: 300;
    color: #fff;
}

.step-flow-compare .step-flow-text p {
    margin-bottom: 12px;
    font-size: 16px;
}

.step-flow-compare .result {
    display: block;
    width: 100%;
    padding: 10px 20px;
    border: 1px solid rgba(255,255,255,0.8);
    font-size: 16px;
}

/* 강조 카드 */
.step-flow-compare .is-highlight .step-flow-text {
    background: rgba(233, 64, 87, 0.6);
}

/* VS */
.step-flow-vs {
    position: absolute;
    inset: 50% 0 auto 0;
    transform: translateY(-50%);
    display: flex;
    justify-content: space-between;
    padding: 0 31%;
    pointer-events: none;
}

.step-flow-vs span {
    font-size: 48px;
    font-weight: 700;
    color: #ff8a9a;
}

@media(max-width: 768px){
    /* VS */
    .step-flow-vs {
        position: absolute;
        inset: 0% 0 auto 0;
        transform: translateY(0%);
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        padding: 69% 0;
        pointer-events: none;
        text-align: center;
        height: 100%;
    }

    .step-flow-vs span {
        font-size: 8rem;
        font-weight: 700;
        color: #ff8a9a;
    }

    .step-flow-compare .step-flow-text strong {
        font-size: 5rem;
    }
    .step-flow-compare .step-flow-text p {
        font-size: 2.4rem;
        margin-bottom: 2rem;
    }
    .step-flow-compare .result {
        font-size: 2.4rem;
        padding: 2rem;
    }
}

/* 전체 레이아웃 */
.slimming-target-inner {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 40px;
    align-items: center;
}

/* 기존 박스 확장 */
.slimming-target-grid {
    width: 820px;
}
.slimming-target-grid .box {
    justify-content: center;
    flex-direction: column;
    background: rgba(255,255,255,0.85);
    padding: 10px 10px;
    text-align: center;
}

.slimming-target-grid .box strong {
    display: block;
    margin-bottom: 14px;
    font-size: 60px;
    font-weight: 600;
    line-height: 1;
    color: #aaa;
}

.slimming-target-grid .box strong.t1 {
    color: #cac1de;
}

.slimming-target-grid .box p {
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
    color: #555;
}

.slimming-target-grid .box:last-child {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid #ddd;
}

/* 강조 박스 */
.slimming-target-grid .is-highlight strong {
    color: #b9a7d6;
}

/* 오른쪽 효과 리스트 */
.slimming-effect-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
    margin-left: 0px;
}

.slimming-effect-list li {
    position: relative;
    padding: 10px 16px;
    background: #5c3a91;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
}

/* 라인 (pseudo 사용) */
.slimming-effect-list li::after {
    content: "";
    position: absolute;
    right: 100%;
    top: 50%;
    width: 60px;
    height: 1px;
    background: #5c3a91;
    transform: translateY(-50%);
}

/* 반응형 */
@media (max-width: 768px) {
    .slimming-target-inner {
        grid-template-columns: 1fr;
        gap: 3rem;
    }

    .slimming-target-grid {
        width: 100%;
        grid-template-columns: repeat(1, 1fr);
    }
    .slimming-target-grid .box {
        aspect-ratio: inherit;
        padding: 5rem 3rem;
    }

    .slimming-effect-list {
        margin-top: 0px;
        margin-left: 0;
    }

    .slimming-effect-list li::after {
        display: none;
    }
    .slimming-target-grid .box strong{
        font-size: 5rem;
    }
    .slimming-target-grid .box p {
        font-size: 2.4rem;
    }
}

.carboxy-step-section {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.carboxy-step-inner {
    position: relative;
    z-index: 1;
    height: 100%;
    padding: 50px 0;
    box-sizing: border-box;
}

.carboxy-step-list {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin: 0 auto;
    padding: 0;
    height: 100%;
    list-style: none;
    max-width: 1100px;
}

.carboxy-step-list li {
    position: relative;
    z-index: 1;
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    aspect-ratio: 1 / 1;
    padding: 28px;
    text-align: center;
    box-sizing: border-box;
}
.carboxy-step-list li::before {
    content: "";
    position: absolute;
    inset: 0;
    background: #f7f0de;
    transform: rotate(45deg) scale(0.70);
    box-shadow: 0 10px 20px rgba(0,0,0,0.25);
    z-index: -1;
}
.carboxy-step-list li + li {
    margin-left: -120px;
}

.carboxy-step-list li:nth-child(2n) {
    margin-top: 170px;
}

.carboxy-step-list strong {
    display: block;
    margin-bottom: 8px;
    font-size: 42px;
    font-weight: 700;
    line-height: 1;
    color: #444;
}

.carboxy-step-list strong::after {
    content: "";
    display: block;
    width: 12px;
    height: 2px;
    margin: 8px auto 0;
    background: #444;
}

.carboxy-step-list p {
    margin: 0;
    font-size: 15px;
    line-height: 1.55;
    letter-spacing: -0.04em;
    color: #555;
}

@media (max-width: 768px) {
    .carboxy-step-inner {
        padding: 0;
    }
    .carboxy-step-list {
        flex-direction: column;
        align-items: stretch;
        background: #f7f0de;
        padding: 5rem;
    }
    .carboxy-step-list li + li,
    .carboxy-step-list li:nth-child(2n) { margin: 0; }
    .carboxy-step-list li::before { display: none; }
    .carboxy-step-list li { aspect-ratio: inherit; }
    .carboxy-step-list li + li { border-top: 1px solid #c7bfa9; }
    .carboxy-step-list strong { font-size: 5rem; }
    .carboxy-step-list p { font-size: 3rem; }
}

.injection-info-section {
    width: 100%;
    background: #fff;
}

.injection-info-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 70px 90px;
    width: 1205px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
}

.injection-info-item h3 {
    margin: 0 0 26px;
    font-size: 21px;
    font-weight: 700;
    color: #111;
}

.injection-info-item > p {
    margin: 0 0 28px;
    min-height: 100px;
    font-size: 15px;
    line-height: 1.8;
    letter-spacing: -0.04em;
    color: #666;
}

.injection-info-img {
    margin-bottom: 18px;
    overflow: hidden;
    width: 100%;
    height: 240px;
}

.injection-info-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.injection-effect h4 {
    margin: 0 0 12px;
    font-size: 18px;
    font-weight: 700;
    color: #b7abc9;
}

.injection-effect ul {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.injection-effect li {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 92px;
    aspect-ratio: 1 / 1.15;
    padding: 12px 5px;
    background: #f2f2f2;
    border: 1px solid #e8e8e8;
    clip-path: polygon(
        50% 0%,
        100% 25%,
        100% 75%,
        50% 100%,
        0% 75%,
        0% 25%
    );
    font-size: 15px;
    line-height: 1.45;
    word-break: keep-all;
    text-align: center;
    color: #555;
    box-sizing: border-box;
}

.injection-effect li:nth-child(even) {
    background: #f7dfe5;
    border-color: #f7dfe5;
}

/* 기본 (핑크 계열) */
.injection-effect li:nth-child(even) {
    background: #f7dfe5;
    border-color: #f7dfe5;
}

/* 베이지 타입 */
.injection-effect ul.type-beige li:nth-child(even) {
    background: #f3dfcf;
    border-color: #f3dfcf;
}

@media (max-width: 768px) {
    .injection-info-list {
        grid-template-columns: 1fr;
        gap: 8rem;
        width: 100%;
        padding: 8rem 0;
    }

    .injection-info-item > p {
        min-height: auto;
    }

    .injection-effect ul {
        gap: 6px;
    }

    .injection-effect li {
        font-size: 2rem;
    }

    .injection-info-item h3 {
        font-size: 4rem;
        margin-bottom: 2rem;
    }
    .injection-info-item > p {
        font-size: 2.4rem;
    }
    .injection-info-item > p br {
        display: none;
    }
    .injection-effect li {
        width: 12rem;
        word-break: keep-all;
    }
    .injection-effect h4 {
        font-size: 3rem;
        margin-bottom: 1rem;
    }
    .injection-info-img {
        height: 30rem;
        margin-bottom: 5rem;
    }
}

.clinic-info-head .sub_content_head_img {
    aspect-ratio: 1.2 / 1;
}

.greeting_showcase {
    display: grid;
    grid-template-columns: minmax(360px, 0.9fr) minmax(0, 1fr);
    gap: 64px;
    align-items: center;
}

.greeting_photo_grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
}

.greeting_photo {
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background-color: #eee;
}

.greeting_photo_main {
    grid-column: 1 / -1;
    aspect-ratio: 1.28 / 1;
}

.greeting_photo img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.greeting_name {
    position: absolute;
    right: -96px;
    bottom: 16px;
    min-width: 208px;
    padding: 13px 24px;
    background-color: #191919;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
}

.greeting_text {
    padding: 30px 0;
}

.greeting_text h2 {
    color: #111;
    font-size: 32px;
    font-weight: 300;
    line-height: 1.2;
}

.greeting_text strong {
    position: relative;
    display: block;
    margin-top: 6px;
    padding-bottom: 22px;
    color: #e6002d;
    font-size: 18px;
    font-weight: 800;
}

.greeting_text strong:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 42px;
    height: 3px;
    background-color: #e6002d;
}

.greeting_text p {
    color: #666;
    font-size: 15px;
    line-height: 1.85;
    word-break: keep-all;
}

.greeting_text strong + p {
    margin-top: 38px;
}

.greeting_text p + p {
    margin-top: 22px;
}

.facility_showcase {
    margin-top: 0;
}

.facility_showcase_grid {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(320px, 1fr);
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 6px;
    align-items: stretch;
}

.facility_slide_box,
.facility_image_box {
    overflow: hidden;
    background-color: #f4f4f4;
}

.facility_slide_box {
    position: relative;
    aspect-ratio: 807 / 577;
    width: 100%;
}

.facility_swiper,
.facility_swiper .swiper-wrapper,
.facility_swiper .swiper-slide {
    width: 100%;
    height: 100%;
}

.facility_swiper img,
.facility_image_box img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.facility_image_tall {
    grid-column: 2;
    grid-row: 1 / span 2;
}

.facility_image_box:not(.facility_image_tall) {
    aspect-ratio: 807 / 311;
}

.facility_pagination {
    bottom: 17px !important;
}

.facility_pagination .swiper-pagination-bullet {
    width: 14px;
    height: 14px;
    margin: 0 4px !important;
    border: 1px solid #fff;
    background-color: transparent;
    opacity: 1;
}

.facility_pagination .swiper-pagination-bullet-active {
    background-color: #fff;
}

.facility_showcase_info {
    padding-top: 36px;
    text-align: right;
}

.facility_showcase_info h2 {
    margin-bottom: 22px;
    color: #e6002d;
    font-size: 20px;
    font-weight: 800;
}

.facility_showcase_info p {
    color: #444;
    font-size: 16px;
    line-height: 1.5;
}

.facility_showcase_info b {
    color: #222;
    font-weight: 800;
}

.info_table_wrap {
    border-top: 2px solid #555;
}

.info_table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

.info_table th,
.info_table td {
    padding: 24px 28px;
    border-bottom: 1px solid #ddd;
    font-size: 18px;
    line-height: 1.6;
    vertical-align: middle;
}

.info_table th {
    width: 220px;
    background-color: #fafafa;
    color: #222;
    font-weight: 700;
    text-align: left;
}

.info_notice {
    margin-top: 18px;
    color: var(--gray-700);
    font-size: 16px;
}

.guide_cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.guide_card {
    min-height: 150px;
    padding: 28px;
    border: 1px solid #e5e5e5;
    background-color: #fff;
}

.guide_card strong {
    display: block;
    margin-bottom: 16px;
    color: #222;
    font-size: 20px;
}

.guide_card p {
    color: var(--gray-700);
    font-size: 16px;
    line-height: 1.6;
    word-break: keep-all;
}

.guide_card a {
    color: var(--primary);
    font-size: 24px;
    font-weight: 700;
}

.guide_card a.btn {
    background-color: #000;
    color: #fff;
    padding: 12px 15px;
    font-size: 18px;
    display: block;
    text-align: center;
    margin-bottom: 10px;
}
.guide_card a.btn2 {
    background-color: #f5da15;
    color: #49461d;
}

.location_head {
    display: block;
}

.location_panel {
    display: grid;
    grid-template-columns: 1.35fr 1fr;
    gap: 30px;
    align-items: stretch;
}

.transit_panel {
    display: block;
}

.map_placeholder {
    min-height: 420px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 12px;
    padding: 40px;
    background: linear-gradient(135deg, #f6f3fb 0%, #eef3f4 100%);
    border: 1px solid #e1dce8;
    text-align: center;
}

.map_placeholder p {
    color: #222;
    font-size: 30px;
    font-weight: 700;
}

.map_placeholder span {
    color: #666;
    font-size: 18px;
}

.location_map iframe { width: 100%; margin-bottom: 50px; }

.location_info {
    padding: 34px;
    border-top: 2px solid #555;
    border-bottom: 1px solid #ddd;
}

.location_info dl > div + div {
    margin-top: 28px;
    padding-top: 28px;
    border-top: 1px solid #e5e5e5;
}

.location_info dt {
    margin-bottom: 10px;
    color: #222;
    font-size: 18px;
    font-weight: 700;
}

.location_info dd {
    color: var(--gray-700);
    font-size: 17px;
    line-height: 1.6;
}

.location_info a {
    color: var(--primary);
    font-size: 24px;
    font-weight: 700;
}

.transit_info {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 0;
    border-top: 0;
    border-bottom: 0;
    border-top: 1px solid #aaa;
    border-bottom: 1px solid #aaa;
}

.transit_col {
    min-height: 295px;
    text-align: center;
}

.transit_col + .transit_col {
    border-left: 1px solid #aaa;
}

.transit_col h4 {
    padding: 17px 20px;
    border-bottom: 1px solid #aaa;
    color: #111;
    font-size: 18px;
    font-weight: 700;
}

.transit_body {
    min-height: 235px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 35px 24px;
    color: #111;
    font-size: 16px;
    line-height: 1.5;
}

.bus_group + .bus_group {
    margin-top: 28px;
}

.bus_group strong {
    display: block;
    margin-bottom: 14px;
    color: #e6002d;
    font-size: 16px;
    font-weight: 700;
}

.bus_group p {
    color: #111;
    font-size: 16px;
    line-height: 1.45;
}

@media(max-width: 768px) {
    .greeting_showcase {
        grid-template-columns: 1fr;
        gap: 5rem;
    }

    .greeting_photo_main,
    .greeting_photo {
        aspect-ratio: 1.15 / 1;
    }

    .greeting_name {
        right: 2rem;
        bottom: 2rem;
        min-width: auto;
        padding: 1.5rem 2.4rem;
        font-size: 2.2rem;
    }

    .greeting_text {
        padding: 0;
    }

    .greeting_text h2 {
        font-size: 4rem;
    }

    .greeting_text strong {
        font-size: 2.8rem;
    }

    .greeting_text p {
        font-size: 2.3rem;
    }

    .facility_showcase_grid,
    .guide_cards,
    .location_panel {
        grid-template-columns: 1fr;
    }

    .facility_showcase_grid {
        gap: 3rem;
        grid-template-rows: auto;
    }

    .info_table th,
    .info_table td,
    .guide_card p,
    .location_info dd,
    .map_placeholder span {
        font-size: 2.4rem;
    }

    .facility_slide_box,
    .facility_image_box:not(.facility_image_tall) {
        aspect-ratio: 807 / 577;
    }

    .facility_image_tall {
        grid-column: auto;
        grid-row: auto;
        aspect-ratio: 807 / 577;
    }

    .facility_showcase_info {
        padding-top: 4rem;
    }

    .facility_showcase_info h2 {
        font-size: 3rem;
    }

    .facility_showcase_info p {
        font-size: 2rem;
    }

    .info_table th,
    .info_table td {
        display: block;
        width: 100%;
        padding: 3rem;
    }

    .info_notice {
        font-size: 2.2rem;
    }

    .guide_card {
        min-height: auto;
        padding: 3rem;
    }

    .guide_card strong,
    .location_info dt {
        font-size: 2.8rem;
    }

    .guide_card a,
    .location_info a {
        font-size: 3rem;
    }

    .map_placeholder {
        min-height: 45rem;
        padding: 5rem 3rem;
    }

    .map_placeholder p {
        font-size: 3.4rem;
    }

    .location_map iframe {
        width: 100%;
        height: 50rem;
        margin-bottom: 8rem;
    }

    .location_info {
        padding: 3rem;
    }

    .transit_info {
        grid-template-columns: 1fr;
        padding: 0;
    }

    .transit_col {
        min-height: auto;
    }

    .transit_col + .transit_col {
        border-left: 0;
        border-top: 1px solid #aaa;
    }

    .transit_col h4 {
        padding: 2.4rem;
        font-size: 2.8rem;
        background-color: #fafafa;
    }

    .transit_body {
        min-height: auto;
        padding: 4rem 3rem;
        font-size: 2.4rem;
    }

    .bus_group strong,
    .bus_group p {
        font-size: 2.4rem;
    }
}
