/* CSS Document : layout */

:root {
  --main: #001d3f;
    --primary-color: #005bac;
    --accent-color: #00a0e9;
    --bg-light: #eef5fc;
    --text-dark: #1D3557;
    --text-gray: #6C757D;
    --white: #FFFFFF;
    --font-main: 'Noto Sans KR', sans-serif;
    --font-title: 'Montserrat', sans-serif;
    --header-height: 90px;
    --max-width: 1200px;
}

/* common */

#wrap{width:100%; height:100%; position:relative; max-width:1000px; min-width:320px; margin:0 auto; background:#fff;}

.sCenter{width:100%; float:left;}

#topWrap{width:100%; height:91px; max-width:1000px; min-width:320px;  position:fixed; z-index:100; top:0;}
.topMenu{width:100%; float:left; position:relative; padding:30px 0; background:var(--main); z-index:100;}
.topMenu .mLogo{width:100%; padding:0 2%; position:relative; float:left; text-align:left; z-index:100;}
.topMenu .mLogo img{width:150px}
.topMenu .menu{position:absolute; top:30px; right:7%; z-index:110;}
.topMenu .slideClose{position:absolute; top:30px; right:7%; z-index:200; display:none;}

.topMenu .topTel{position:absolute; top:18px; left:2%; z-index:110; width:80px; display:none;}
.topMenu .topTel img{width:44px;}

.openLogo{position:absolute;right:50px;z-index:200;}
.openLogo img{width:150px;}
#mPage{float:left;}
#mPage .topMenu{/*background:none;*/}
.topMenuOn{background:#fff !important;box-shadow: 0 3px 4px rgb(0 0 0 / 30%);}

@media screen and (max-width:480px){
	#topWrap{height:71px;}
	.topMenu{padding:10px 0;}
	.topMenu .mLogo img{width:130px;}
	.topMenu .menu{top:38px;}
	.topMenu .menu img{width:30px;}
	.topMenu .slideClose{top:38px;}
	.topMenu .slideClose img{width:30px;}
	/*.topMenu .mLogo a {width:120px; height:30px;}
	.topMenu .menu img{width:30px;}
	.topMenu .slideClose img{width:30px;}
	.topMenu .topTel img{width:33px;}*/
}
.title1 {
    width: 100%;
    box-sizing: border-box;
    padding: 30px 2%;
    color: #292929;
    font-size: 29px;
    font-weight: 700;
    text-align: center;
    margin-top: 76px;
}




* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--font-main); color: var(--text-dark); line-height: 1.6; overflow-x: hidden; }
a { text-decoration: none; color: inherit; transition: all 0.3s ease; }
ul { list-style: none; }
img { max-width: 100%; }
button { font-family: var(--font-main); }
section { /*padding: 100px 0;*/position: relative; }
.container { max-width: var(--max-width); margin: 0 auto; padding: 0 20px; }
h1, h2, h3, h4, h5, h6{font-family: 'Noto Sans KR', sans-serif;}

/* 섹션 타이틀 */
.section-title {
    text-align: center; margin-bottom: 60px; font-size: 2.2rem;
    font-weight: 700; color: var(--primary-color); position: relative;
}
.section-title::after {
    content: ''; display: block; width: 50px; height: 4px;
    background: var(--accent-color); margin: 20px auto 0;
}
.text-white { color: var(--white) !important; }
.text-white::after { background: var(--white); }

/* 버튼 평면 디자인 */
.btn-nav-reg, .tab-btn, .tab-btn.active, .btn-more, .btn-sticky-split {
    box-shadow: none !important; border: 1px solid #eee;
}

/* =========================================
   [2] Top Bar
   ========================================= */
.top-bar { background-color: #f8f9fa; border-bottom: 1px solid #e1e8ed; height: 40px; display: flex; justify-content: center; }
.top-bar-inner { width: 100%; max-width: none; padding: 0 60px; display: flex; justify-content: flex-end; align-items: center; gap: 15px; }
.auth-links { font-size: 0.8rem; color: #666; font-weight: 500; display: flex; align-items: center; gap: 10px; }
.auth-links a:hover { color: var(--primary-color); text-decoration: underline; }
.auth-links .sep { color: #ccc; font-size: 0.7rem; }
.group-sep { color: #ccc; font-size: 0.7rem; margin-top: 1px; }
.lang-switch { display: flex; align-items: center; font-size: 0.8rem; font-weight: 700; }
.lang-btn { background: none; border: none; cursor: pointer; color: #ccc; font-family: var(--font-title); font-weight: 700; padding: 0; transition: 0.3s; }
.lang-btn:hover { color: var(--primary-color); }
.lang-btn.active { color: var(--text-dark); text-decoration: underline; }
.lang-switch .sep { color: #ccc; margin: 0 5px; font-size: 0.7rem; }

/* =========================================
   [3] Header & Nav
   ========================================= */
header {
    position: sticky; top: 0; width: 100%; height: var(--header-height);
    background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); z-index: 1000; border-bottom: 1px solid #eee;
}
.header-inner { width: 100%; max-width: none; padding: 0 60px; height: 100%; display: flex; justify-content: space-between; align-items: center; }
.logo-link { flex-shrink: 0; }
.logo-img { height: 65px; width: auto; }
nav { flex: 1; display: flex; justify-content: center; padding: 0 20px; height: 100%; }
.nav-links { display: flex; gap: 45px; height: 100%; }
.nav-links li.dropdown { position: relative; padding: 0; height: 100%; display: flex; align-items: center; }
.nav-links .drop-btn { font-weight: 500; font-size: 1.15rem; color: var(--text-dark); display: block; position: relative; }
.nav-links .drop-btn::after {
    content: ''; position: absolute; bottom: -5px; left: 0; width: 0%; height: 2px; background: var(--accent-color); transition: 0.3s;
}
.nav-links li.dropdown:hover .drop-btn::after { width: 100%; }
.nav-links li.dropdown:hover .drop-btn { color: var(--accent-color); }
.dropdown-menu {
    position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
    background: white; min-width: 220px; box-shadow: 0 10px 30px rgba(0,0,0,0.15) !important;
    border-radius: 10px; padding: 15px 0; opacity: 0; visibility: hidden; transition: all 0.3s ease;
    z-index: 1000; border-top: 3px solid var(--accent-color);
}
.nav-links li.dropdown:hover .dropdown-menu { opacity: 1; visibility: visible; top: 100%; }
.dropdown-menu li { display: block; }
.dropdown-menu li a { display: block; padding: 12px 25px; font-size: 1rem; color: #555; transition: 0.2s; font-weight: 500; }
.dropdown-menu li a:hover { background: #f8f9fa; color: var(--primary-color); padding-left: 25px; }
.header-right { display: flex; align-items: center; }
.btn-nav-reg {
    background: var(--primary-color); color: var(--white) !important; padding: 14px 35px; border-radius: 50px; font-weight: 800; font-size: 1rem; transition: 0.3s; white-space: nowrap; border: none;
}
.btn-nav-reg:hover { background: var(--accent-color); transform: translateY(-2px); }
.mobile-menu-btn { display: none; font-size: 1.5rem; cursor: pointer; color: var(--text-dark); margin-left: 15px; }
















/* S : slide Menu*/
.slideMenuWrap{width:100%; max-width:1000px; height:100%; float:left; position:fixed; top:0px; z-index:80; background:#fff; opacity:1; display:none;}
.slideMenu{width:100%; max-width:1000px; position:absolute; z-index:90; background:#fff; top:0; left:0; display:none; padding-top:120px;}

.slideMenu .top{width:100%; float:left; margin-top:90px; background:#04334b; position:relative; border-top:1px solid #f1f1f1; padding:10px 0; border-bottom:1px solid #f1f1f1; text-align:center; display:none;}
.slideMenu .top a{display:inline-block; padding:0 10px; border-left:1px solid #e1e1e1; text-align:center; color:#fff; background:#04334b; font-size:14px;}
.slideMenu .top a:first-child{border-left:none;}


@media screen and (max-width:480px){

	.slideMenu{padding-top:60px;}

	.slideMenu .top{margin-top:70px;}


}



.slideMenu ul.menu{width:100%; margin-left:0%; float:left; margin-top:22px;}
.slideMenu ul.menu li{width:100%; float:left; background:#fff; padding:0; position:relative;}
/*.slideMenu ul.menu li:last-child{border-bottom:none;}*/

.slideMenu ul.menu li a{width:94%; margin-left:3%; border-top:1px solid var(--main); float:left; box-sizing:border-box; padding:10px 20px; line-height:30px; font-size:18px; color:var(--main); font-weight:bold; position:relative; text-align:left;}
.slideMenu ul.menu li.on > a{color:var(--main);}
.slideMenu ul.menu li.on{color:var(--main);}

.slideMenu ul.menu li span.viewSub{display:none;}

.slideMenu ul.sub{display:none; margin-top:0; /*border-top:1px solid #04334b;*/ float:left; width:94%; margin-left:3%; padding:0px 20px 10px;}
.slideMenu ul.sub li{width:100%; float:left; border-bottom:none; padding:0;}

.slideMenu ul.sub li a{width:100%; display:inline-block; border:none; margin-left:0%; margin-right:0%; padding:5px 0; line-height:20px; font-size:15px; color:var(--main); font-family: 'Nanum Gothic', sans-serif; font-weight:normal;}

.slideMenu .bottom{width:100%; float:left; padding:20px 0; background:#fff; position:relative; text-align:center; }
.slideMenu .bottom a{display:inline-block; padding:5px 10px; border:1px solid var(--main); text-align:center; color:var(--main); font-size:16px; margin:0 3px}

/* E : slide Menu*/






/* foot */

#partnerWrap{width:100%; background:#fff; padding:20px 0 0 0; position:relative;}
/*.partner{width:96%; margin-left:2%; float:left; padding:5px 0;}*/
.partner span{display:inline-block; width:20%; color:#fff; font-size:18px; font-weight:600; line-height:30px; text-align:center; float:left;}
/*.partner img{width:60%; display:inline-block; float:left;}
.partner a{width:60%; display:inline-block;}
.partner a img{width:50%; display:inline-block; float:left;}*/

.partner{width:96%; margin-left:2%; padding:0px 0; display:table;}
.partner .ptnKind{display:table-cell; width:22%; color:#fff; font-size:18px; font-weight:600;  text-align:center; vertical-align:top; padding-top:3px;}
.partner .ptnKind .ptnKindbg{width: 60px; height: 30px; line-height: 30px; background: var(--main); border-radius: 20px; margin-left: 15px;}
.partner .ptn{display:table-cell; width:100%; color:#fff; font-size:18px; font-weight:600; /*line-height:30px;*/ text-align:left; vertical-align:top; padding: 0 0 0 20px;}
.partner .ptn img{height:40px;}
.partner .runkof img{height:20px !important; margin-top: 3px;}

#footWrap{width:100%; background:var(--main); padding:20px 0 50px 0 ; position:relative; z-index:2; margin-top: 20px;}
#footWrap .foot{width:96%; margin-left:2%;}
#footWrap .foot .address{width:100%; line-height:24px; color:#a9a9a9; font-size:17px; text-align:center; font-style:normal;}
#footWrap .foot .copyright{width:100%; line-height:24px; color:#fff; font-size:17px; text-align:center; padding:20px 0px 30px;}
#footWrap .foot .fEmarathon{width:100%; text-align:center;}
#footWrap .foot .fEmarathon img{width:50%; max-width:290px;}

.emaraton{position:relative; margin-top:20px; width:90%; margin-left:5%; float:left;}
.emaraton .emaratonBy{position:relative; width:100%; text-align:center; float:left;}
.emaraton .emaratonBy img{width:50%; max-width:162px;}
.emaraton .emaratonBubble{position:relative; width:100%; float:left; font-size:14px; padding-top:5px; text-align:center; font-size:13px; color:#CCC; display:none;}
.emaraton:hover .emaratonBubble{display:block;}

.goPc{position:absolute; right:5%; bottom:10px; }
.goPc a{display:inline-block; height:30px; line-height:30px; width:60px; border:1px solid #fff; color:#fff; font-size:14px; text-align:center;}

@media screen and (max-width:640px){
	.partner span{font-size:16px;}

	.partner .ptnKind{font-size:16px;}

	#footWrap .foot .address{font-size:15px;}
	#footWrap .foot .copyright{font-size:15px;}

}

@media screen and (max-width:480px){
	.partner span{font-size:14px; line-height:20px;}

	.partner .ptnKind{font-size:14px; /*line-height:20px;*/}
	/*.partner .ptn img{height:45px; margin-top: -4px;}*/

	#footWrap .foot .address{font-size:13px;}
	#footWrap .foot .copyright{font-size:13px; padding:15px 0px 25px;}
}

@media screen and (max-width:320px){
	.partner span{font-size:12px;}

	.partner .ptnKind{font-size:12px;}

	#footWrap .foot .address{font-size:12px;}
	#footWrap .foot .copyright{font-size:12px; padding:10px 0px 20px;}
}


/* bottom */
#bottom{width:100%; float:left; background:#363636; color:#fff; padding:20px 0; position:relative; z-index:2; text-align:center; margin-top:30px;}
.bottomTxt01{width:100%; float:left; padding-bottom:20px; color:#fff; font-size:18px; font-weight:600;}
.bottomTxt02{width:100%; float:left; padding-bottom:20px; color:#fff; font-size:30px; font-weight:600;}
.bottomTxt03{width:100%; float:left; color:#fff; font-size:16px;line-height:24px;}
.bottomTxt03 span{font-weight:600;}

@media screen and (max-width:640px){
	.bottomTxt01{font-size:17px; padding-bottom:15px;}
	.bottomTxt02{font-size:24px; padding-bottom:15px;}
	.bottomTxt03{font-size:14px;}
}

@media screen and (max-width:480px){
	.bottomTxt01{font-size:16px; padding-bottom:10px;}
	.bottomTxt02{font-size:20px; padding-bottom:10px;}
	.bottomTxt03{font-size:12px;}
}


#mainContWrap{width:100%; margin-top:70px;}
#subContWrap{width:95%; padding:0 0 30px; min-height:400px; margin: 0 auto;}

#subTitWrap{width: 100%;
    margin-top: 90px;
    box-sizing: border-box;
    padding: 50px 0 30px 0;
    color: #292929;
    font-size: 29px;
    font-weight: 700;
    text-align: center;}

@media screen and (max-width:480px){
	#mainContWrap{margin-top:70px;}
	#subContWrap{margin: 0 auto;}
	#subTitWrap{margin-top:0px;}
}


/* sub page Common*/
#subTopWrap{width:100%; float:left; display:none;}
.subTopTitWrap{width:100%; float:left; height:145px; border-top:1px solid #000002; background:url(../images/subTopBg01.jpg);}
.subTopTitWrap .subTopTit{width:100%; padding-top:40px; color:#fff; font-family: Nanum Square,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; text-align:center; font-weight:bold; font-size:40px;}
.subTopTitWrap .subTopTit span{font-weight:normal; font-size:20px; line-height:40px;}

.subGnbWrap{width:100%; float:left; /*height:40px;*/ border-bottom:1px solid #e1e1e1; text-align:center;}
.subGnbWrap .homeIcon{display:inline-block; width:40px; text-align:center; height:40px; line-height:40px; border-left:1px solid #e1e1e1; position:absolute; top:0; left:50%; margin-left:-212px;}
.subGnbWrap .homeIcon img{vertical-align:middle;}
.subGnbWrap .subMenu01Wrap{display:inline-block; width:190px; text-align:center; height:40px; line-height:40px; border-left:1px solid #e1e1e1; position:relative; margin-left:41px;}
.subGnbWrap .subMenu02Wrap{display:inline-block; width:190px; text-align:center; line-height:24px; border-left:1px solid #e1e1e1; border-right:1px solid #e1e1e1; position:relative; float:none;}
.subGnbWrap .submmChoose{width:190px; padding-left:20px; background:url(../images/bletDown_01.png) no-repeat 170px 12px; font-family: Nanum Square,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; text-align:left; font-size:16px;}
.subGnbWrap .submmArea{width:220px; height:250px; position:absolute; top:45px; left:-10px; z-index:10; display:none;}
.subGnbWrap .submmList{width:190px; background:rgba(255,255,255,1); font-family: Nanum Square,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; text-align:left; font-size:16px; position:absolute; top:40px; left:0; z-index:20; display:none;}
.subGnbWrap .submmList li{width:170px; padding-left:20px; line-height:30px; color:#333; position:relative;}
.subGnbWrap .submmList li a{color:#333; font-family: Nanum Square,"나눔고딕", NanumGothic, Malgun Gothic, "돋움", Dotum, AppleGothic, sans-serif !important; line-height:30px; font-size:16px;}
.subGnbWrap .submmList li a:hover{color:#color:#0b8de5;}
.subGnbWrap .submmList li.on a{color:#0b8de5;}





/* =========================================
   [10] Sponsors
   ========================================= */
#sponsors { background: var(--white); padding: 50px 0; border-top: 1px solid #eee; }
.sponsor-container { background: var(--white); padding: 0; }
.sponsor-row { display: flex; align-items: center; border-bottom: 1px solid #eee; padding: 30px 0; }
.sponsor-row:last-child { border-bottom: none; padding-bottom: 0; }
.sponsor-row:first-child { padding-top: 0; }

.sponsor-label {
    width: 140px;
    /* [수정] 폰트 사이즈 및 굵기 조정 (너무 두껍지 않게) */
    font-weight: 700;  /* 기존 900 -> 700 */
    font-size: 1.4rem; /* 기존 1.2rem -> 1.1rem */
    color: var(--text-dark);
    flex-shrink: 0;
}

.sponsor-logos { display: flex; flex-wrap: wrap; gap: 30px; align-items: center; flex: 1; }
.sponsor-img { height: 45px; width: auto; object-fit: contain; }

/* =========================================
   [11] Footer & Others
   ========================================= */
footer { background: #1a1f26; color: #8d97a5; padding: 70px 0; text-align: center; font-size: 0.95rem; line-height: 1.8; }
.footer-address strong { color: #fff; font-weight: 700; margin-right: 10px; }
.footer-copyright { margin-top: 25px; color: #666; font-size: 0.9rem; }
.footer-powered { margin-top: 8px; font-size: 0.85rem; color: #666; font-style: italic; }
.fade-in { opacity: 0; transform: translateY(40px); transition: opacity 0.8s cubic-bezier(0.215, 0.610, 0.355, 1), transform 0.8s cubic-bezier(0.215, 0.610, 0.355, 1); }
.fade-in.visible { opacity: 1; transform: translateY(0); }

/* 모바일 메뉴 */
.mobile-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); z-index: 1999; opacity: 0; visibility: hidden; transition: 0.3s; }
.mobile-overlay.active { opacity: 1; visibility: visible; }
.mobile-nav-container { position: fixed; top: 0; right: -100%; width: 100%; height: 100%; background: white; z-index: 2000; transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1); display: flex; flex-direction: column; }
.mobile-nav-container.active { right: 0; }
.mobile-header { padding: 20px 25px; border-bottom: 1px solid #eee; display: flex; justify-content: space-between; align-items: center; }
.mobile-title { font-weight: 900; font-size: 1.4rem; color: var(--primary-color); letter-spacing: -0.5px; }
.btn-close { background: none; border: none; font-size: 2rem; cursor: pointer; color: #333; }
.mobile-body { flex: 1; overflow-y: auto; padding: 0; background: #fff; }
.mobile-body ul { list-style: none; padding: 0; margin: 0; }
.mobile-utility { display: flex; justify-content: space-between; align-items: center; padding: 20px 25px; background: #f8f9fa; border-bottom: 1px solid #e1e8ed; }
.mobile-utility .auth-links, .mobile-utility .lang-switch { margin: 0; font-size: 0.95rem; color: #555; font-weight: 600; }
.mobile-utility .sep { color: #ccc; margin: 0 10px; font-size: 0.8rem; }
.mobile-utility a:hover { color: var(--primary-color); }
.mobile-utility .lang-btn { padding: 5px 10px; font-size: 0.95rem; color: #999; font-weight: 600; transition: all 0.3s ease; }
.mobile-utility .lang-btn.active { color: var(--primary-color); font-weight: 800; background: #eef5fc; border-radius: 4px; }
.mobile-body .nav-links { display: flex; flex-direction: column; gap: 0; height: auto; }
.mobile-body .nav-links li.dropdown { display: block; height: auto; border-bottom: 1px solid #f0f0f0; width: 100%; }
.mobile-body .drop-btn { padding: 15px 25px; font-size: 1.2rem; font-weight: 700; color: var(--text-dark); width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; background: #fff; white-space: nowrap; box-shadow: none !important; }
.mobile-body .drop-btn::after { position: static !important; width: auto !important; height: auto !important; background: none !important; content: '\f078'; font-family: 'Font Awesome 5 Free'; font-weight: 900; font-size: 0.9rem; color: #ddd; transition: transform 0.3s; margin-left: 10px; }
.mobile-body .drop-btn.open { color: var(--accent-color); background: #fbfbfb; }
.mobile-body .drop-btn.open::after { transform: rotate(180deg); color: var(--accent-color); }
.mobile-body .nav-links li.dropdown:hover .drop-btn::after { width: auto !important; }
.mobile-body .dropdown-menu { position: static !important; transform: none !important; box-shadow: none !important; border: none !important; border-radius: 0 !important; opacity: 1 !important; visibility: visible !important; width: 100%; background: #f8f9fa; display: none; padding: 10px 0; border-top: 1px solid #eee; }
.mobile-body .dropdown-menu.show { display: block; }
.mobile-body .dropdown-menu li a { padding: 15px 35px; font-size: 1rem; color: #666; display: block; width: 100%; }
.mobile-body .dropdown-menu li a:hover, .mobile-body .dropdown-menu li a:active { color: var(--primary-color); background: #eef2f5; }


/* =========================================
   [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; }
	.mobile-body .nav-links li.dropdown:last-child{padding-bottom:80px;}



    /* 8. 후원사 */
    .sponsor-container { padding: 10px 0; }
    .sponsor-row {
        flex-direction: column; align-items: center; gap: 10px; text-align: center; padding: 15px 0;
    }
    .sponsor-label {
        width: 100%; border-bottom: 2px solid var(--accent-color);
        padding-bottom: 8px; text-align: center;
        font-size: 1.4rem;
    }
    .sponsor-logos { justify-content: center; width: 100%; gap: 15px; }
    .sponsor-img { height: 35px; }

    /* 9. 모바일 하단 고정바 (Sticky Bar) */
    .mobile-sticky-bar {
        display: flex !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        background: rgba(255, 255, 255, 0.98);
        backdrop-filter: blur(10px);
        padding: 12px 15px;
        padding-bottom: max(12px, env(safe-area-inset-bottom));
        box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
        z-index: 9999;
        gap: 10px;
        box-sizing: border-box;
    }
    .btn-sticky-split {
        flex: 1; height: 50px; border-radius: 50px; font-weight: 700; font-size: 1rem;
        box-shadow: 0 4px 10px rgba(0,0,0,0.1) !important;
        display: flex; justify-content: center; align-items: center;
        cursor: pointer;
    }
    .btn-apply { background: #005bac; color: white; border: none; }
    .btn-check { background: #fff; color: #555; border: 1px solid #ddd; }

    footer {
        padding: 40px 0 100px;
        font-size: 0.8rem;
        text-align: center;
        line-height: 1.6;
    }
    /* Footer 텍스트 색상 및 마진 조정 (보내주신 HTML 기준) */
    .footer-address { margin-bottom: 15px; color: #555; }
    .footer-copyright { margin-bottom: 5px; color: #888; }
    .footer-powered { color: #ccc; font-size: 0.75rem; }

    /* [핵심] PC에서만 보이는 요소 (| 기호 숨기기) */
    .pc-only {
        display: none;
    }

    /* [핵심] 모바일에서 줄 바꿈 (블록 요소로 변경) */
    .m-block {
        display: block;
    }
	.btn-apply{color: white !important;}
}

/* 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; }
}
