@charset "utf-8";
/* CSS Document */

/* main roll img */

.mSlideWrap{width:100%; float:left; position:relative; z-index:1; min-width:320px;}
.mSlideWrap img{width:100%;}
.mSlideWrap .mSlide{width:100%; height:100%; float:left; position:absolute; top:0; left:0; z-index:1; overflow:hidden;}
.mSlideWrap .mSlide ul{width:100%; float:left; position:relative; z-index:1;}
.mSlideWrap .mSlide ul li{width:100%; position:absolute; top:0; left:0; z-index:1;}
.mSlideWrap .mSlide ul li img{width:100%;}

.mSlideWrap .msTxt{width:100%; position:absolute; top:8%; left:0%; z-index:200; font-family: Nanum Barun Gothic,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; font-size:16px; color:#222222; line-height:30px; text-align:center; color:#ffffff; display:none;}/* main roll img txt*/
.mSlideWrap .msTxt ul{width:100%; float:left; position:relative;}
.mSlideWrap .msTxt ul li{float:left; width:100%; position:absolute; top:0; left:0;}
.mSlideWrap .msTxt ul li .mTxt01{ font-family: Nanum Barun Gothic,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; font-size:20px; color:#ffffff; line-height:30px; text-align:center; width:100%;}
.mSlideWrap .msTxt ul li .mTxt01 img{width:23.4%; max-width:449px;}
.mSlideWrap .msTxt ul li .mTxt02{ font-family: Nanum Barun Gothic,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; font-size:16px; color:#ffffff; width:94%; padding-left:3%; text-align:center; padding-top:20px; text-align:left; display:none;}
.mSlideWrap .msTxt ul li .mTxt02 img{width:134px;}

.mSlideWrap .sBlet{position:absolute; width:100%; bottom:20px; left:0; z-index:200; text-align:center; display:none;}
.mSlideWrap .sBlet a{display:inline-block; width:15px; height:15px; margin:0 2px; border-radius:100%; box-sizing:border-box; background:#dcdcdc;}
.mSlideWrap .sBlet a.on{background:#073445;}

.mSlideWrap .arrowL{position:absolute; top:50%; left:3%; z-index:200; cursor:pointer; width:80px; /*max-width:80px;*/  display:none;}
.mSlideWrap .arrowR{position:absolute; top:50%; right:3%; z-index:200; cursor:pointer; width:80px;/* max-width:80px;*/  display:none;}
/* end : main roll img */

/* swiper */
.mRollWrap{width:100%; position:relative; z-index:1;}
.mRollWrap img{width:100%; max-width:1000px;}
.mRollWrap .mRoll{/*position:absolute; top:0; left:0; height:100%; width:100%; z-index:2;*/}
.mRollWrap .swiper-container{width:100%; height:100%;}
.mRollWrap .swiper-slide{width:100%; height:100%; background-repeat:no-repeat; background-position:center center;}
.mRollWrap .swiper-slide img{width:100%;}
.mRollWrap .swiper-pagination{bottom:20px; width:100%; text-align:center;}
.mRollWrap .swiper-pagination .swiper-pagination-bullet{width:12px; height:12px; margin:0 3px; background:#d7d7d7; border:2px solid #d7d7d7; border-radius:100%; opacity:1;}
.mRollWrap .swiper-pagination .swiper-pagination-bullet-active{background:#7a9195; border:2px solid #7a9195;}

/* 외국인용*/
.foriegner {position:absolute; z-index:200;  top:10px; right:10px;}
.foriegner a{display:inline-block; padding:10px 12px;  background:#8bc11f; color:#fff; font-size:16px;}

/* mainCont01*/
.mainCont01{width:100%; position:relative;}
.mainCont01 .mCont01Box{width:100%; float:left; position:relative; z-index:1;}
.mainCont01 .mCont01Box img{width:100%;}

.mainCont01 .mCont01Txt{width:100%; float:left; position:absolute; text-align:center; top:0; left:0; z-index:2;}
.mainCont01 .mCont01Txt img{width:100%; max-width:640px;}
.mainCont01 .mCont01Txt ul{width:100%; position:relative; float:left;}
.mainCont01 .mCont01Txt ul li{width:100%; position:absolute; top:0; left:0; text-align:center;}
.mainCont01 .mCont01Txt ul li img{width:100%; max-width:640px;}

.mainCont01 .mCont01Link{width:100%; float:left; position:absolute; text-align:center; bottom:20%; left:0; z-index:3; text-align:center;}
.mainCont01 .mCont01Link .linkWrap{width:100%; max-width:640px; display:inline-block; text-align:left;}
.mainCont01 .mCont01Link .linkWrap a{display:inline-block; margin-right:5%; padding:15px 30px; line-height:24px; color:#c63232; background:#fff; font-size:18px; float:right;}
.mainCont01 .mCont01Link .linkWrap .dday{display:inline-block; float:left; margin-left:10px; line-height:54px; color:#fff; font-size:40px; font-weight:600;}

.mainCont01 .mScroll{width:100%; float:left; position:absolute; text-align:center; bottom:0px; left:0; z-index:4; text-align:center; font-size:16px; color:#000; line-height:24px;}


@media screen and (max-width : 640px){
	
	
	.mainCont01 .mCont01Txt{bottom:3%;}
	.mainCont01 .mCont01Link{bottom:2%;}
	
}

@media screen and (max-width : 480px){
	
	.mainCont01 .mCont01Link .linkWrap a{padding:7px 20px; line-height:24px; color:#fff; background:#1762a8; font-size:16px;}
	.mainCont01 .mCont01Link .linkWrap .dday{line-height:44px; font-size:26px;}
	
	.mainCont01 .mScroll{font-size:14px;}
	
	.mainCont01 .mScroll img{width:26px;}
	
}


/* mainCont02 */
.videobox {width:100%; padding: 50px 0px 50px 0px; position:relative; background:url("../images/main/mvideobg2.png?ver=3") no-repeat top center; background-size:contain;    text-align: center;}
.mainCont02{width:100%; padding: 75px 0 60px 0; position:relative; background:url(../images/main/infobg_m.png) no-repeat top center; background-size:cover;}
.mainCont02 a{display:inline-block;width:47%; text-align:center; margin:10px 1% 10px 2%; padding:30px 0; border:1px solid #fff; color:#fff; font-size:18px; font-weight:600; background: #003d6782;line-height:30px; box-sizing:border-box;}
.mainCont02 .mCont02Box{width:100%; text-align:center; color:#fff; font-size:18px; font-weight:600; line-height:30px;}
.mainCont02 .mCont02Box img{width:70%; max-width:128px;}

.mainCont02 .info1 {display:flex;flex-wrap:wrap;width:100%;margin-top:0px; border:0px solid red}

/* mainCont03*/
.mainCont03{width:100%; height: auto; margin-top:0px; position:relative;}
.mContTit{width:100%; padding-bottom:20px; float:left; color:#292929; font-size:18px; font-weight:600; text-align:center;}

.giftBox{width: 100%; height: auto;}

.mCont03Box{width:96%; margin-left:2%; float:left; text-align:center; margin-bottom:20px;}
.mCont03Box .mCont03Img{width:100%; box-sizing:border-box; border:1px solid #e1e1e1; float:left;}
.mCont03Box .mCont03Img img{width:100%; max-width:588px;}
.mCont03Txt{width:100%; padding:15px 0; float:left; color:#fff; font-size:18px; line-height:24px; background:#eb0045; text-align:center; font-weight:600;}
.mCont03Txt span{font-weight:normal;}
.giftTxt{display:block;width:100%; padding:15px 0; color:#fff; font-size:18px; line-height:24px; background:#2e3b79; text-align:center; font-weight:600; margin-bottom: 40px;}

/* mainCont04*/
.mainCont04 {
    width: 100%;
    padding: 66px 0 45px 0;
    float: left;
    position: relative;
    background: url(../images/main/virtualbg_m.jpg) no-repeat top center;
    background-size: cover;
}
.mCont04Box{width:96%; margin-left:2%; float:left; text-align:center;}
.mCont04Box a {
    display: inline-block;
    width: 80%;
    padding: 20px 0;
    margin: 10px 0;
    box-sizing: border-box;
    border: 1px solid #fff;
    line-height: 24px;
    color: #fff;
    font-size: 20px;
    font-weight: 600;
    background: #003d6782;
}

/* mainCont05*/
.mainCont05{width:100%; padding:80px 0 20px 0; float:left; position:relative; background:#fff;}
.mContTit05{width:100%; padding-bottom:40px; float:left; color:#292929; font-size:18px; font-weight:600; text-align:center;}

.mCont05Box{width:90%; margin-left:5%; float:left; text-align:center; margin-bottom:40px;}
.mCont05Box .mCont05Img{width:100%; box-sizing:border-box; border:1px solid #e1e1e1; float:left;}
.mCont05Box .mCont05Img img{width:100%; max-width:588px;}
.mCont05Box .mCont05Txt{width:100%; padding:15px 0; float:left; color:#fff; font-size:18px; line-height:24px; background:#eb0045; text-align:center; font-weight:600;}
.mCont05Box .mCont05Txt span{font-weight:normal;}

/* mainCont06*/
#mCont06Wrap{width:100%; height: auto; background:#fff; position:relative; z-index:1;}
.mCont06{width:100%; height:auto; text-align:center;}
.boardLeft{width:90%; margin: 0 auto; padding: 20px 0; height: auto;}
.boardRight{width:90%; margin: 0 auto; height: auto;}

.boardTit{width:90%; font-size:24px; font-weight:600; color:#292929; position:relative; padding:0 5% 20px; text-align:left; margin-top:0px;}
.boardTit .more{position:absolute; top:0px; right:5%;}
.mBoardWrap{width:100%; border-top:2px solid #2e3b79;}
.mBoard{width:100%; }
.mBoard li{width:90%; padding:10px 5%; border-bottom:1px solid #999; font-size:16px; line-height:24px; position:relative; }
.mBoard li a{display:inline-block; width:100%; font-size:16px; color:#616161; text-align:left;}
.mBoard li a .date{display:inline-block; float:right; color:#c0c0c0; font-size:14px;}



@media screen and (max-width : 480px){
	
	.mainCont02 .mCont02Box{font-size:16px;}
	.mContTit{font-size:22px;}
	.mCont03Box .mCont03Txt{font-size:16px; padding:10px 0;}
	
}



/*#popupWrap{width:100%; height:100%; position:absolute; top:0; left:0; z-index:999999; background:rgba(0,0,0,0.7); display:none; }
#popupWrap .popCont{width:96%; height:94%; overflow-y:scroll; max-width:600px; margin:0 auto; }
#popupWrap .popCont img{width:100%;}
#popupWrap .popClose{width:96%; max-width:600px; margin:0 auto; height:30px; line-height:30px; font-size:14px; text-align:center; background:#000; color:#fff;}
#popupWrap .popClose span{display:inline-block; padding:0 10px;}
#popupWrap .popClose span a{color:#fff;}*/

#popupWrap{width:100%; height:100%; position:absolute; top:0; left:0; z-index:200; background:rgba(0,0,0,0.7); }
#popupWrap .popCont{width:96%; height:400px; padding-top:80px; overflow-y:none; max-width:600px; margin:0 auto; }
#popupWrap .popCont img{width:100%;}
#popupWrap .popClose{width:96%; max-width:600px; margin:0 auto; height:30px; line-height:30px; font-size:14px; text-align:center; background:#000; color:#fff;}
#popupWrap .popClose span{display:inline-block; padding:0 10px;}
#popupWrap .popClose span a{color:#fff;}

#popup02{width:100%; position:absolute; top:0; left:0; z-index:300; }
#popup02 .popCont{width:96%; padding-top:80px; overflow-y:none; max-width:600px; margin:0 auto; }
#popup02 .popCont img{width:100%;}
#popup02 .popClose{width:96%; max-width:600px; margin:0 auto; height:30px; line-height:30px; font-size:14px; text-align:center; background:#000; color:#fff;}
#popup02 .popClose span{display:inline-block; padding:0 10px;}
#popup02 .popClose span a{color:#fff;}









/* =========================================
   [4] Hero Section (Static Cross-Fade)
   ========================================= */
#hero {
    width: 100%;

    /* PC 이미지 비율 고정 (잘림 없음) */
    height: auto;
    aspect-ratio: 1920 / 800;

    position: relative;
    overflow: hidden;
    background: transparent;
}

.hero-slider { width: 100%; height: 100%; }

/* [수정] 슬라이드 애니메이션: 움직임 없이 투명도만 조절 */
.slide {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;

    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center;

    /* 기본 상태: 투명 (안 보임) */
    opacity: 0;
    z-index: 1;

    /* 코스 맵과 동일한 원리: 부드럽게 나타나고 사라짐 */
    transition: opacity 1s ease-in-out;
}

/* 활성화 상태: 불투명 (보임) */
.slide.active {
    opacity: 1;
    z-index: 2;
    /* transform이나 animation 없음 -> 제자리에서 깔끔하게 바뀜 */
}

/* 페이지네이션 (점) - 기존 유지 */
.slider-pagination {
    position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%);
    display: flex; gap: 15px; z-index: 20;
}
.dot {
    width: 12px; height: 12px; background: rgba(255, 255, 255, 0.5);
    border: none; border-radius: 50%; cursor: pointer; transition: all 0.3s ease;
}
.dot:hover { background: rgba(255, 255, 255, 0.9); }
.dot.active {
    background: var(--accent-color);
    transform: scale(1.3); width: 30px; border-radius: 10px;
}


/* =========================================
   [5] Overview
   ========================================= */
#overview { background: var(--white); padding: 120px 0; }
.overview-layout-text { display: flex; gap: 60px; }
.overview-intro { flex: 0 0 40%; padding-right: 40px; border-right: 1px solid #eee; display: flex; flex-direction: column; justify-content: center; }
.section-title.left-align { text-align: left; margin-bottom: 30px; }
.section-title.left-align::after { margin: 20px 0 0; }
.intro-headline { font-size: 1.5rem; font-weight: 800; line-height: 1.4; color: var(--text-dark); margin-bottom: 20px; word-break: keep-all; }
.intro-desc { font-size: 1rem; color: #666; line-height: 1.7; word-break: keep-all; }
.overview-details { flex: 1; display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; }
.detail-card {
    background: #fdfdfd; padding: 25px 30px; border-radius: 12px; border: 1px solid #f0f0f0;
    border-left: 5px solid var(--accent-color); transition: all 0.3s ease; display: flex; align-items: flex-start; gap: 20px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.03); width: 100%;
}
.detail-card:hover { transform: translateY(-3px); background: #fff; border-left-color: var(--primary-color); }
.d-icon { font-size: 1.8rem; color: #ccc; transition: 0.3s; flex-shrink: 0; }
.detail-card:hover .d-icon { color: var(--primary-color); }
.d-text { display: flex; flex-direction: column; }
.d-label { font-size: 0.9rem; color: #888; margin-bottom: 5px; font-weight: 700; }
.detail-card strong { font-size: 1.1rem; color: var(--text-dark); line-height: 1.4; font-weight: 600; }

/* =========================================
   [6] Video
   ========================================= */
#video { background: linear-gradient(135deg, var(--primary-color), #003f7f); padding: 120px 0; }
#video .section-title { color: var(--white); margin-bottom: 70px; }
#video .section-title::after { background: var(--white); opacity: 0.8; }
.video-wrapper {
    position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden;
    border-radius: 24px; box-shadow: 0 30px 60px rgba(0,0,0,0.4) !important; border: none;
}
.video-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

/* =========================================
   [7] Course (Layout Fix & Animation)
   ========================================= */
#course { background: #f9fbfd; padding: 120px 0; border-top: 1px solid #eef2f5; }
.course-layout { display: flex; gap: 50px; align-items: flex-start; }

.course-menu {
    width: 300px; flex-shrink: 0; background: white;
    padding: 30px 30px;
    border-radius: 24px; box-shadow: 0 10px 30px rgba(0,0,0,0.05); border: 1px solid #fff;
}
.course-menu h3 {
    font-size: 1.4rem; font-weight: 800; color: var(--text-dark);
    margin-bottom: 30px; padding-bottom: 20px; border-bottom: 2px solid #f0f0f0;
}

.course-tabs.vertical { display: flex; flex-direction: column; gap: 12px; }
.course-tabs.vertical .tab-btn {
    display: flex; justify-content: space-between; align-items: center;
    width: 100%; padding: 18px 25px; background: #f8f9fa; cursor: pointer;
    border: 1px solid transparent; border-radius: 16px;
    text-align: left; transition: all 0.3s;
}
.c-name { font-size: 1.15rem; font-weight: 700; color: #555; }
.c-dist { font-size: 0.9rem; color: #999; font-weight: 500; }

/* 탭 버튼 활성화 디자인 */
.course-tabs.vertical .tab-btn.active,
.course-tabs.vertical .tab-btn:hover {
    background: var(--primary-color); border-color: var(--primary-color);
    transform: translateX(5px);
}
.course-tabs.vertical .tab-btn.active .c-name,
.course-tabs.vertical .tab-btn:hover .c-name { color: white; }
.course-tabs.vertical .tab-btn.active .c-dist,
.course-tabs.vertical .tab-btn:hover .c-dist { color: rgba(255,255,255,0.8); }

/* [중요] 코스 맵 디스플레이 영역 + 애니메이션 통합 */
.course-display.large-view {
    flex: 1; background: white; border-radius: 24px; overflow: hidden; border: 1px solid #f0f0f0;
    display: flex; flex-direction: column; justify-content: center;

    /* 페이드 애니메이션 설정 */
    transition: opacity 0.3s ease-in-out;
    opacity: 1; /* 평소엔 보임 */
}

/* JS가 이 클래스를 붙이면 투명해짐 */
.course-display.large-view.fading {
    opacity: 0;
}

.map-header { padding: 20px 30px; border-bottom: 1px solid #eee; background: #fff; }

/* [수정] 폰트 굵기 700 적용 */
.map-header h3 { font-size: 1.8rem; color: var(--text-dark); margin: 0; font-weight: 700; }

/* 맵 프레임 (비율 유지 - 여백 방지) */
.map-frame {
    width: 100%;

    /* [핵심] 고정 높이 제거하고 비율 적용 */
    height: auto;
    aspect-ratio: 16 / 9; /* 16:9 비율 유지 */

    background: #fff;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}

/* 맵 이미지 설정 (잘림 방지 + 확대 효과 준비) */
.map-frame img {
    width: 100%; height: 100%;
    object-fit: contain !important;
    transition: transform 0.5s ease;
}

/* 마우스 올렸을 때 확대 효과 */
.map-frame:hover img {
    transform: scale(1.05);
}

.map-footer {
    padding: 20px 30px; background: #fdfdfd; border-top: 1px solid #eee;
    display: flex; justify-content: space-between; align-items: center; gap: 20px;
}
.mf-info p { font-size: 1.15rem; color: #444; font-weight: 500; display: flex; align-items: center; gap: 12px; margin: 0; }
.mf-info i { color: var(--accent-color); font-size: 1.3rem; }

.btn-course-detail {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 20px; background: #fff; border: 1px solid #ddd;
    border-radius: 50px; color: #555; font-weight: 700; font-size: 0.95rem;
    transition: 0.3s; white-space: nowrap;
}
.btn-course-detail:hover { border-color: var(--primary-color); color: var(--primary-color); background: #f0f7ff; }
.mobile-sticky-bar { display: none; }

/* =========================================
   [8] Souvenir
   ========================================= */
#souvenir { background: var(--white); padding: 120px 0; }
.souvenir-gallery-combined { display: flex; flex-direction: column; gap: 80px; }
.souvenir-group { padding: 50px; background: #fff; border-radius: 30px; }
.souvenir-group.highlight-group { background: #f8fcff; border-color: #e1f0fa; }
.group-header { margin-bottom: 40px; text-align: center; }
.step-badge { display: inline-block; padding: 8px 20px; border-radius: 50px; font-size: 1.1rem; font-weight: 800; margin-bottom: 15px; }
.step-badge.delivery { background: var(--primary-color); color: white; }
.step-badge.site { background: var(--accent-color); color: white; }
.group-header p { font-size: 1.2rem; color: #666; }
.gallery-grid { display: grid; gap: 40px; }
.gallery-grid.col-3 { grid-template-columns: repeat(3, 1fr); }
.gallery-grid.center-pc { display: flex; justify-content: center; gap: 40px; }
.gallery-grid.center-pc .gallery-card { width: calc(33.33% - 27px); flex: 0 0 auto; }
.gallery-card { background: white; border-radius: 24px; overflow: hidden; transition: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); box-shadow: 0 15px 35px rgba(0,0,0,0.08); border: none; }
.gallery-card:hover { transform: translateY(-15px); }
.card-img {
    width: 100%; padding: 0 !important; aspect-ratio: 3 / 2; height: auto;
    background: #f9f9f9; position: relative; display: flex; align-items: center; justify-content: center;
}
.card-img img { width: 100%; height: 100%; object-fit: contain !important; transition: 0.4s; }
.gallery-card:hover .card-img img { transform: scale(1.08); }
.card-body { padding: 20px; text-align: center; }
.card-body h4 { font-size: 1.4rem; margin-bottom: 10px; color: var(--text-dark); font-weight: 700; }
.card-body p { color: #888; font-size: 1rem; }
.sv-note {
    margin-top: 40px;
    text-align: center;
    font-size: 0.9rem;
    color: #888;
    font-weight: 400;
    letter-spacing: -0.5px;
}
.sv-note-box {
    margin-top: 60px; /* 위쪽 기념품들과 충분한 간격 */
    background: #f8f9fa; /* 아주 연한 회색 배경 */
    padding: 20px 30px;
    border-radius: 12px; /* 부드러운 라운드 */
    text-align: center;
    color: #666;
    font-size: 0.95rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px; /* 아이콘과 텍스트 사이 간격 */
    border: 1px solid #eee; /* 살짝 테두리를 줘서 깔끔하게 */
}

.sv-note-box i {
    color: var(--accent-color); /* 아이콘에 포인트 컬러 */
    font-size: 1.1rem;
}

/* =========================================
   [9] Board
   ========================================= */
#board-section { background: var(--primary-color); padding: 120px 0; }
#board-section .section-title { color: var(--white); }
#board-section .section-title::after { background: var(--white); opacity: 0.3; }
.board-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 50px; }
.board-column { background: var(--white); padding: 30px; border-radius: 24px; box-shadow: 0 10px 30px rgba(0,0,0,0.05); }
.board-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 5px; padding-bottom: 10px; border-bottom: 2px solid #eee; }
.board-title { font-size: 1.6rem; font-weight: 800; color: var(--text-dark); }
.btn-more { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: #f0f0f0; color: #888; transition: 0.3s; font-size: 1rem; }
.btn-more:hover { background: var(--accent-color); color: white; transform: rotate(90deg); }
.board-list { display: flex; flex-direction: column; gap: 5px; }
.board-item { display: flex; align-items: center; gap: 20px; cursor: pointer; padding: 5px 0; border-bottom: 1px solid #f9f9f9; }
.board-item:last-child { border-bottom: none; }
.board-item:hover .board-subject { color: var(--primary-color); font-weight: 600; }
.board-cat { font-size: 0.8rem; padding: 5px 10px; border-radius: 6px; font-weight: 700; background: #eee; color: #666; white-space: nowrap; }
.board-cat.notice { background: #e02f2f; color: white; }
.board-cat.qna { background: #e7f1ff; color: var(--primary-color); }
.board-subject { flex: 1; font-size: 1.05rem; color: #444; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: 0.2s; }
.board-date { font-size: 0.9rem; color: #999; white-space: nowrap; }


/* =========================================
   [13] Media Queries (Responsive)
   ========================================= */

/* A. Tablet & Mobile (1200px 이하 공통) */
@media (max-width: 1200px) {

    /* 1. [전체 레이아웃] 여백 및 폰트 밸런스 */
    .container { max-width: 100%; padding: 0 20px; }

    /* 섹션 간격 (40px 유지) */
    section { padding: 40px 0; }

    /* [수정] 섹션 제목 크기 확대 (1.6rem -> 2.0rem) */
    /* 제목이 커졌으므로 아래 여백도 살짝 더 줍니다 (25px -> 35px) */
    .section-title {
        font-size: 2.0rem;
        margin-bottom: 35px;
        line-height: 1.2;
    }
    .section-title::after { margin: 15px auto 0; width: 45px; }

    /* [수정] 본문 서브 헤드라인 밸런스 조정 */
    /* 제목과 본문 사이를 이어주는 문구 크기를 키워 자연스럽게 연결 */
    .intro-headline { font-size: 1.25rem; line-height: 1.5; margin-bottom: 20px; }
    p { font-size: 0.95rem; line-height: 1.6; }

    /* 2. 헤더 & 네비게이션 */
    header {
        padding: 0 25px;
        justify-content: space-between;
        height: 80px;
    }

    .logo-img {
        /* [유지] 로고 크기 55px */
        height: 55px;
        width: auto;
    }

    .header-inner { padding: 0; width: 100%; }
    .top-bar, nav, .btn-nav-reg { display: none !important; }
    .mobile-menu-btn { display: block; font-size: 1.8rem; margin-left: auto; }

    /* 4. 대회 개요 (중앙 정렬) */
    .overview-layout-text { flex-direction: column; gap: 25px; }
    .overview-intro {
        padding-right: 0; border-right: none; border-bottom: 1px solid #eee;
        padding-bottom: 25px; text-align: center;
    }
    .section-title.left-align { text-align: center !important; width: 100%; }
    .section-title.left-align::after { margin: 15px auto 0 !important; }

    .overview-details { grid-template-columns: repeat(2, 1fr); gap: 10px; }

    .detail-card {
        padding: 20px 10px;
        display: flex; flex-direction: column; align-items: center; justify-content: center;
        text-align: center;
        gap: 8px;
        border-left: 1px solid #f0f0f0; border-top: 4px solid var(--accent-color);
        height: 100%;
    }

    .d-icon { font-size: 2.2rem; margin-bottom: 5px; color: var(--primary-color); }
    .d-label { font-size: 0.85rem; }
    .detail-card strong { font-size: 1rem; } /* 본문이 커져서 여기도 살짝 키움 */

    /* 5. 코스 안내 */
    .course-layout { flex-direction: column; gap: 20px; }
    .course-menu { width: 100%; padding: 0; background: transparent; box-shadow: none; border: none !important; margin-bottom: 0; }
    .course-menu h3 { display: none; }

    .course-tabs.vertical { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
    .course-tabs.vertical .tab-btn:first-child { grid-column: 1 / -1; }
    .course-tabs.vertical .tab-btn { justify-content: center; text-align: center; padding: 12px; font-size: 0.95rem; }
    .c-dist { display: none; }

    .course-display.large-view { width: 100%; }
    .map-frame { height: auto; aspect-ratio: 16 / 9; }

    .map-header { padding: 15px 20px; }
    .map-header h3 { font-size: 1.3rem; }

    .map-footer { flex-direction: column; gap: 12px; text-align: center; padding: 20px; }
    .mf-info p { font-size: 1rem; flex-direction: column; gap: 5px; }
    .btn-course-detail { justify-content: center; width: 100%; }

    /* 6. 기념품 */
    .souvenir-group { padding: 0 !important; background: transparent !important; }
    .group-header { margin-bottom: 20px; }
    .group-header p { font-size: 0.95rem; margin-top: 5px; word-break: keep-all; }

    .gallery-grid.col-3, .gallery-grid.center-pc {
        display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
    }
    .gallery-grid.center-pc .gallery-card { width: 100%; }

    .card-body { padding: 15px 10px; }
    .card-body h4 { font-size: 1rem; margin-bottom: 5px; }
    .card-body p { font-size: 0.85rem; }

    .sv-note-box {
        margin-top: 30px;
        flex-direction: column; gap: 5px; padding: 15px;
        font-size: 0.85rem; line-height: 1.4; word-break: keep-all;
    }

    /* 7. 소식 및 문의 */
    .board-grid { grid-template-columns: 1fr; gap: 25px; }
    .board-column { width: 100%; padding: 15px 20px; box-sizing: border-box; }
    .board-title { font-size: 1.3rem; margin-bottom: 15px; }
    .board-item { padding: 12px 0; gap: 10px; }
    .board-subject {
        font-size: 0.95rem;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        max-width: 180px;
    }
    .board-date { font-size: 0.85rem; }


}

/* B. 아주 작은 모바일 (360px 이하) 대응 */
@media (max-width: 380px) {
    .section-title { font-size: 1.6rem; } /* 작은 폰에서는 제목 약간 줄임 */
    .board-subject { max-width: 130px; }
    .gallery-grid.col-3, .gallery-grid.center-pc { grid-template-columns: 1fr; }
}
