 @charset "utf-8";
/* doc.css는 디자인페이지 스타일을 정의합니다. */
.root_daum_roughmap {width:100% !important; height:clamp(250px, calc( 500 / var(--inner) * 100vw ), 500px) !important;}
.root_daum_roughmap .wrap_map {height:clamp(250px, calc( 500 / var(--inner) * 100vw ), 500px) !important;}
.roughmap_lebel_text {line-height:0 !important; font-size:0 !important;}
.roughmap_lebel_text:after {content:"광주 광산구 송대길 28"; font-size:12px; line-height:15px;}

.bullet-item .bullet-list {position:relative; padding-left:15px; margin-top:10px; line-height:1.3;}
.bullet-item .bullet-list:first-child {margin-top:0;}
.bullet-item .bullet-list::before {position:absolute; content:''; left:0; top:9px; width:3px; height: 3px; background:var(--color-primary); border-radius: 50%;}
.bullet-item .bullet-list.none {padding-left: 0;}
.bullet-item .bullet-list.none::before {display: none;}
.bulletitem2 { padding-left: 0.6em; text-indent: -0.6em;}

/*  css 파일 추가 처리(선택사항)  */
.fr-box .swiper-wrapper {display:block;}

.blocker {z-index: 100;}
.modal {max-width:980px; width: 100%;}

.bg-gray {background:#fafafa;}
.overhidden {overflow: hidden;}
.subsec-pd {padding: clamp(50px, calc( 150 / var(--inner) * 100vw ), 150px) 0;}

.radiobx {display: flex; flex-wrap: wrap;}
.radiobx .item {display: flex;align-items: center; min-height: clamp(38px, calc( 44 / var(--inner) * 100vw ), 44px);}
.radiobx .item:not(:last-child) {margin-right: clamp(15px, calc( 40 / var(--inner) * 100vw ), 40px);}

.greet-wrap {overflow: hidden;}
.greet-wrap .flxWrap {gap: var(--padding-100);}
.greet-wrap .imgbx {width:clamp(300px, calc( 462 / var(--inner) * 100vw ), 462px);}
.greet-wrap .textbx{ flex: 1; letter-spacing: -0.6px;}
.greet-wrap .title {font-size: var(--font-size-44); line-height: 1.22; font-weight: 400; color: var(--color-primary);}
.greet-wrap .decbx {display: flex;flex-direction: column;gap: var(--padding-20); margin-top: var(--padding-40);}
.greet-wrap .decbx .dec {font-size:var(--font-size-18); line-height: 1.55; color: var(--color-body);}

.subsec-titbx {margin-bottom: var(--padding-50); text-align: center;}
.subsec-titbx .subtitle {font-size: var(--font-size-32); font-weight: 600; line-height: 1.43;}
.subsec-titbx.ty2 {margin-bottom: var(--padding-60);}

.sub1_2_1 .toptext {font-size: var(--font-size-18); line-height: 1.55; color: var(--color-body); text-align: center;}
.sub1_2_1 .vision-3core { display: flex; flex-direction: column; gap: clamp(40px, calc( 60 / var(--inner) * 100vw ), 60px); width: 100%; margin-top: clamp(40px, calc( 60 / var(--inner) * 100vw ), 60px); }
.sub1_2_1 .vision-value-item { display: flex; flex-direction: column; gap: var(--padding-20); width: 100%; }
.sub1_2_1 .vision-value-head { display: flex; flex-wrap: wrap; align-items: center; column-gap: var(--padding-10); row-gap: var(--padding-20); }
.sub1_2_1 .vision-value-head::before { content: ""; flex-shrink: 0; width: clamp(2px, calc( 4 / var(--inner) * 100vw ), 4px); height: clamp(16px, calc( 24 / var(--inner) * 100vw ), 24px); background: var(--color-primary); }
.sub1_2_1 .vision-value-head::after { content: ""; flex-basis: 100%; width: 100%; height: 1px; background: #d9d9d9; }
.sub1_2_1 .vision-value-tit { font-size: var(--font-size-20); font-weight: 600; line-height: 1.3; color: var(--color-dark); letter-spacing: -0.03em; }
.sub1_2_1 .vision-value-desc { padding:0 var(--padding-10);  font-size: var(--font-size-18); font-weight: 400; line-height: 1.56; color: var(--color-body); letter-spacing: -0.03em; }
.sub1_2_2 {padding: var(--padding-180) 0; background: url(../images/sub/sub1_2_2-bg.jpg) no-repeat center center / cover;}
.sub1_2_2 .subsec-titbx .subtitle {color: #fff;}
.sub1_2_3 .flxWrap {align-items: center; gap:var(--padding-60);}
.sub1_2_3 .flxWrap .imgbx {width: clamp(300px, calc( 500 / var(--inner) * 100vw ), 500px);}
.sub1_2_3 .flxWrap .textbx { flex: 1; min-width: 0; }
.sub1_2_3 .vision-brief { display: flex; flex-direction: column; gap: var(--padding-30); width: 100%; }
.sub1_2_3 .vision-brief-tt { display: flex; align-items: center; column-gap: var(--padding-12); }
.sub1_2_3 .vision-brief-tt::before { content: ""; flex-shrink: 0; width: clamp(2px, calc( 4 / var(--inner) * 100vw ), 4px); height: clamp(18px, calc( 26 / var(--inner) * 100vw ), 26px); background: var(--color-primary); }
.sub1_2_3 .vision-brief-lead { font-size: var(--font-size-24); font-weight: 400; line-height: 1.42; color: var(--color-primary); letter-spacing: -0.03em; }
.sub1_2_3 .vision-brief-lead-sm { font-weight: 600; }
.sub1_2_3 .vision-brief-body { width: 100%; }
.sub1_2_3 .vision-brief-body p { font-size: var(--font-size-18); font-weight: 400; line-height: 1.56; color: var(--color-body); letter-spacing: -0.03em; }

.history-timeline { display: flex; flex-direction: column; gap: var(--padding-120); width: 100%; }
.history-era { display: grid; grid-template-columns: minmax(0, 34%) minmax(0, 1fr); gap: clamp(24px, calc( 40 / var(--inner) * 100vw ), 40px); align-items: start; width: 100%; }
.history-era-side { display: flex; flex-direction: column; gap: var(--padding-20); }
.history-era-period { font-size: var(--font-size-60); font-weight: 700; line-height: 1.2; color: var(--color-primary); letter-spacing: -0.05em; }
.history-era-desc { font-size: var(--font-size-18); font-weight: 400; line-height: 1.56; color: var(--color-body); letter-spacing: -0.05em; }
.history-era-body { display: flex; flex-direction: column; gap: var(--padding-20); width: 100%; }
.history-rail { display: flex; align-items: center; width: 100%; min-height: 48px; }
.history-rail-mark { flex-shrink: 0; width: 20px; height: 20px; border-radius: 50%; background:#E9EBF1; position: relative;}
.history-rail-mark::before { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 10px; height: 10px; border-radius: 50%; background: #fff; border: 2px solid var(--color-primary);}
.history-rail-line { flex: 1 1 auto; min-width: 0; height: 1px; align-self: center; margin-left: var(--padding-12); background: repeating-linear-gradient(to right, #e2e2e2 0, #e2e2e2 6px, transparent 6px, transparent 11px); }
.history-era-list { display: flex; flex-direction: column; gap: var(--padding-40); width: 100%; padding-left: var(--padding-30); }
.history-era-row { display: flex; align-items: flex-start; flex-wrap: wrap; gap: 10px; width: 100%; }
.history-year { display: inline-flex; align-items: center; column-gap: 6px; font-size: var(--font-size-18); font-weight: 600; line-height: 1.3; color: var(--color-dark); }
.history-year::before { content: ""; flex-shrink: 0; width: 5px; height: 5px; border-radius: 50%; background: var(--color-primary); }
.history-txt {flex: 1; font-size: var(--font-size-18); font-weight: 400; line-height: 1.56; color: var(--color-body); letter-spacing: -0.03em;}
.history-txt span { display: block;  }
@media (max-width: 1024px) {
.history-era { grid-template-columns: 1fr; }
.history-era-body { padding-top: 0; }
.history-era-list {padding-left: 0;}
}

.location-area .map-title {margin-bottom: var(--padding-30); display: flex; align-items: center; gap: var(--padding-12);}
.location-area .map-title .icn img {width:24px;}
.location-area .map-title .tit {font-size:var(--font-size-24); font-weight: 600; color: var(--color-body); line-height: 1.25;}
.location-area .location-info { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--padding-20); width: 100%; margin-top: var(--padding-30); }
.location-area .location-info-card { width:  calc((100% - 3 * var(--padding-20)) / 4);  border: 1px solid #ddd; box-sizing: border-box; }
.location-area .location-info-in { display: flex; flex-direction: column; align-items: center; gap: var(--padding-30); height: 100%; padding: var(--padding-40) var(--padding-20) ; }
.location-area .location-info-icn { display: flex; align-items: center; justify-content: center; }
.location-area .location-info-icn img {width: clamp(35px, calc( 48 / var(--inner) * 100vw ), 48px); height: auto; aspect-ratio: 1 / 1; object-fit: contain; }
.location-area .location-info-body { display: flex; flex-direction: column; align-items: center; gap: var(--padding-20); width: 100%; text-align: center; color: var(--color-body); }
.location-area .location-info-tit { font-size: var(--font-size-24); font-weight: 600; line-height: 1.3; letter-spacing: -0.05em; }
.location-area .location-info-desc { display: flex; flex-direction: column; align-items: center; gap: var(--padding-8); font-size: var(--font-size-20); font-weight: 500; line-height: 1.4; letter-spacing: -0.05em; }
.location-area .location-info-desc p { font-size: inherit; font-weight: inherit; line-height: inherit; }

.sub3_1_1-intro { width: 100%; }
.sub3_1_1-overlap { position: relative; width: 100%; min-height: clamp(520px, calc( 680 / var(--inner) * 100vw ), 680px); }
.sub3_1_1-imgclip { width: clamp(300px, calc( 600 / var(--inner) * 100vw ), 600px); overflow: hidden; }
.sub3_1_1-panel { position: absolute; left: clamp(200px, calc( 420 / var(--inner) * 100vw ), 420px); top: clamp(48px, calc( 180 / var(--inner) * 100vw ), 180px); width: min(980px, calc(100% - clamp(200px, calc( 420 / var(--inner) * 100vw ), 420px) - var(--container-space))); min-height: clamp(360px, calc( 500 / var(--inner) * 100vw ), 500px); padding: clamp(20px, calc( 80 / var(--inner) * 100vw ), 80px); background: #fff; box-shadow: 0 0 16px rgba(0, 0, 0, 0.25); box-sizing: border-box; display: flex; flex-direction: column; gap: clamp(30px, calc( 60 / var(--inner) * 100vw ), 60px); }
.sub3_1_1-panel-head { display: flex; flex-direction: column; gap: var(--padding-20); width: 100%; }
.sub3_1_1-kicker { display: flex; flex-wrap: wrap; align-items: center; gap: var(--padding-16); }
.sub3_1_1-kicker-line { flex-shrink: 0; width: 30px; height: 2px; background: var(--color-primary); }
.sub3_1_1-kicker-txt { font-size: var(--font-size-18); font-weight: 400; line-height: 1.55; color: var(--color-primary); letter-spacing: -0.03em; }
.sub3_1_1-tt { font-size: var(--font-size-32); font-weight: 600; line-height: 1.19; color: var(--color-dark); letter-spacing: -0.03em; }
.sub3_1_1-panel-body { display: flex; flex-direction: column; gap: var(--padding-30); width: 100%; min-width: 0; }
.sub3_1_1-desc { display: flex; flex-direction: column; gap: var(--padding-20); }
.sub3_1_1-desc p { font-size: var(--font-size-18); font-weight: 400; line-height: 1.55; color: #454545; letter-spacing: -0.03em; }
.sub3_1_1-callout { padding: var(--padding-12) var(--padding-30); background: rgb(26 46 110 / 0.06); width: 100%; }
.sub3_1_1-callout p { font-size: var(--font-size-18); font-weight: 600; line-height: 1.55; color: var(--color-primary); letter-spacing: -0.03em; }

.sub3_1_2-list { display: flex; flex-direction: column; gap: clamp(28px, calc( 40 / var(--inner) * 100vw ), 40px); width: 100%; }
.sub3_1_2-item:nth-child(odd) { background: #fafbfc; }
.sub3_1_2-item:nth-child(even) { background: #f6f7f9; }
.sub3_1_2-item { width: 100%;  padding: var(--padding-80) clamp(20px, calc( 130 / var(--inner) * 100vw ), 130px); }
.sub3_1_2-in { display: flex; flex-wrap: wrap; align-items: center; flex-wrap: wrap;  width: 100%; }
.sub3_1_2-left { display: flex; flex-wrap: wrap; align-items: center; gap: clamp(24px, calc( 50 / var(--inner) * 100vw ), 50px); flex-shrink: 0; width: clamp(200px, calc( 490 / var(--inner) * 100vw ), 490px);}
.sub3_1_2-icn { display: flex; align-items: center; justify-content: center;  overflow: hidden; }
.sub3_1_2-icn img { width: clamp(45px, calc( 80 / var(--inner) * 100vw ), 80px); height: auto; aspect-ratio: 1 / 1;}
.sub3_1_2-stit {font-size: var(--font-size-24); font-weight: 600; line-height: 1.3; color: var(--color-dark); letter-spacing: -0.03em; }
.sub3_1_2-body {flex: 1 ; display: flex; flex-direction: column; gap: clamp(16px, calc( 22 / var(--inner) * 100vw ), 22px); }
.sub3_1_2-lead { font-size: var(--font-size-20); font-weight: 600; line-height: 1.3; color: var(--color-dark); letter-spacing: -0.03em; }
.sub3_1_2-desc p {font-size: var(--font-size-18); font-weight: 400; line-height: 1.55; color: var(--color-body); letter-spacing: -0.03em; }

.sub3_1_3-gallery { display: flex; flex-direction: column; gap: clamp(40px, calc( 65 / var(--inner) * 100vw ), 65px); width: 100%; }
.sub3_1_3-row-top { display: flex; flex-wrap: wrap; align-items: flex-start; gap: clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px); width: 100%; }
.sub3_1_3-fig { display: flex; flex-direction: column; gap: var(--padding-12); margin: 0; min-width: 0; }
.sub3_1_3-fig-wide { flex: 1 1 320px; max-width: min(1020px, 100%); }
.sub3_1_3-fig-narrow { flex: 0 1 clamp(260px, calc( 340 / var(--inner) * 100vw ), 340px); min-width: 0; }
.sub3_1_3-imgbox-tall { position: relative; width: 100%; height: clamp(360px, calc( 650 / var(--inner) * 100vw ), 650px); overflow: hidden; }
.sub3_1_3-imgbox-short { position: relative; width: 100%; height: clamp(180px, calc( 280 / var(--inner) * 100vw ), 280px); overflow: hidden; }
.sub3_1_3-imgbox img { display: block; width: 100%; height: 100%; object-fit: cover; }
.sub3_1_3-cap { font-size: var(--font-size-18); font-weight: 400; line-height: 1.55; color: var(--color-body); letter-spacing: -0.03em; }
.sub3_1_3-row-btm { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px); width: 100%; align-items: start; }
.sub3_1_3-fig-eq { min-width: 0; }
@media (max-width: 900px) {
.sub3_1_3-row-btm { grid-template-columns: 1fr; }
.sub3_1_3-fig-wide { max-width: 100%; }
.sub3_1_3-fig-narrow { flex: 1 1 100%; max-width: 100%; }
.sub3_1_3-imgbox-tall {height: auto;}
.sub3_1_3-imgbox-short {height: auto;}
}

.sub3_1_4 {padding: var(--padding-100) 0; background: url(../images/sub/sub3_1_4-bg.jpg) no-repeat center center / cover;}
.sub3_1_4 .subsec-titbx .subtitle {color: #fff;}
.sub3_1_4 .morebx .btn-more {color: #fff;}
.sub3_1_4 .morebx .btn-more path {fill: #fff;}