@charset "utf-8";
/* TOURMUCH // Maker : H.J Jeon // E-Mail : jinia21@naver.com // Site : tourmuch.com */

html::-webkit-scrollbar {width: 8px;}
html::-webkit-scrollbar-thumb {background-color: var(--color-point); border-radius: 10px;}

html, body {
    word-break: keep-all;

    --max-width-xs: 768px;
    --max-width-sm: 1024px;
    --max-width-md: 1240px;
    --max-width-lg: 1440px;
    --max-width-full: 1640px;

    --font-size-xs: clamp(0.75rem, 3vw, 0.875rem);
    --font-size-sm: clamp(0.875rem, 3vw, 1rem);
    --font-size-md: clamp(1rem, 3vw, 1.125rem);
    --font-size-lg: clamp(1.125rem, 3vw, 1.25rem);
    --font-size-xl: clamp(1.25rem, 3vw, 1.5rem);

    --rounded-sm: 3px;
    --rounded-md: 5px;
    --rounded-lg: 8px;

    --clear-space-md: 10px;
    --clear-space-lg: 16px;
}

body.noSmoothScroll {
    overflow: hidden;
}

img { max-width: 100%; object-fit: cover; }

#wrapper {
    --header-height: 80px;

    position: relative;
    min-height: 100vh;
    padding-bottom: var(--header-height);
}

.max-width-xs { max-width: var(--max-width-xs); margin: 0 auto; }
.max-width-sm { max-width: var(--max-width-sm); margin: 0 auto; }
.max-width-md { max-width: var(--max-width-md); margin: 0 auto; }
.max-width-lg { max-width: var(--max-width-lg); margin: 0 auto; }

.font-size-xs { font-size: var(--font-size-xs) !important; }
.font-size-sm { font-size: var(--font-size-sm) !important; }
.font-size-md { font-size: var(--font-size-md) !important; }
.font-size-lg { font-size: var(--font-size-lg) !important; }
.font-size-xl { font-size: var(--font-size-xl) !important; }

.dark-overlay {
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(var(--color-black-rgb),0.5);
    backdrop-filter: blur(5px);
    z-index: 1800;
    opacity: 0;
    transition: opacity 0.25s ease-in-out, visibility 0.25s;
    content: '';
}

.dark-overlay.open {
    visibility: visible;
    opacity: 1;
}

.basic-box {
    position: relative;
    padding: 1rem;
    background-color: var(--color-box-basic);
    box-shadow: 0 5px 5px -5px rgba(var(--color-black-rgb),0.2);
    border-radius: var(--rounded-lg);
    /* box-shadow: 0 0 0 1px #e3e5e8,0 1px 2px 0 rgba(0,0,0,.04); */
}

h2.tit-h2 {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 2rem;
    text-align: center;
}

h2.tit-h2 small {
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: var(--font-weight-regular);
    color: var(--color-blue);
}

h2.tit-h2 .tit {
    font-family: var(--font-point);
    font-weight: var(--font-weight-medium);
    font-size: clamp(2.25rem, 3vw, 4rem);
    letter-spacing: -.5pt;
}

h3.tit-h3 .tit {
    font-weight: var(--font-weight-semibold);
    font-size: clamp(1.25rem, 3vw, 1.5rem);
}

h3.tit-h3 .more-btn {
    gap: 10px;
    font-size: clamp(0.875rem, 3vw, 1rem);
    font-weight: var(--font-weight-regular);
    color: var(--color-gray);
    transition: .3s ease-in-out;
}

.tab-mnu {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin: 0 auto;
    margin-bottom: 2rem;
}

.tab-mnu ul {
    display: flex;
    justify-content: center;
    align-items: stretch;
    width: 100%;
    padding: 5px;
    background-color: var(--color-background);
    border-radius: 10px;
}

.tab-mnu.bg-ver ul {
    background-color: var(--color-box-basic);
}

.tab-mnu ul.tab2 {
    max-width: 500px;
}

.tab-mnu ul.tab2 li {
    width: 50%;
}

.tab-mnu ul.tab3 {
    max-width: 730px;
}

.tab-mnu ul.tab3 li {
    width: 33.3333%;
    height: 100%;
}

.tab-mnu ul li .tab-mnu-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1.2;
    padding: 10px;
    text-align: center;
    color: var(--color-gray);
    font-size: clamp(1.125rem, 2.5vw, 1.5rem);
    border-radius: 5px;
    transition: .2s;
}

.tab-mnu ul li .tab-mnu-btn:hover,
.tab-mnu ul li .tab-mnu-btn.selected {
    background-color: var(--color-blue-deep);
    color: var(--color-white);
    font-weight: var(--font-weight-bold);
}

.tab-mnu .comment {
    font-size: clamp(0.875rem, 3vw, 1rem);
    color: var(--color-gray);
    font-weight: var(--font-weight-regular);
    letter-spacing: -.5pt;
}

.basic-tbl th,
.basic-tbl td {
    padding: 5px 10px;
    border: 1px solid var(--color-line-basic);
    background-color: var(--color-background);
    font-size: clamp(0.875rem, 3vw, 1rem);
}

.basic-tbl th,
.basic-tbl td {
}

.basic-tbl thead th {
    background-color: var(--color-box-basic);
    font-weight: var(--font-weight-medium);
}

.basic-tbl tbody th {
    background-color: var(--color-box-basic);
    color: var(--color-basic);
}

.basic-tbl tbody td {
    color: var(--color-gray-deep);
}

@media screen and (min-width: 767px) {
    #wrapper {
        --header-height: 80px;
    }

    .basic-box {
        padding: 2rem;
    }

    h2.tit-h2.in-loca {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    .tab-mnu ul {
        border-radius: 50px;
    }

    .tab-mnu ul li .tab-mnu-btn br {
        display: none;
    }

    .tab-mnu ul li .tab-mnu-btn {
        padding: 15px;
        border-radius: 50px;
    }
}

@media screen and (min-width: 1023px) {
    h2.tit-h2 .tit {
        font-weight: var(--font-weight-bold);
    }

    h3.tit-h3 .more-btn:hover {
        gap: 1rem;
        color: var(--color-point);
    }

    .tab-mnu {
        margin-bottom: 4rem;
    }

    .tab-mnu ul {
        box-shadow: 3px 10px 3px rgba(var(--color-black-rgb),0.1);
    }
}

@media screen and (min-width: 1239px) {
    #wrapper {
        --header-height: 100px;
    }
}

@media screen and (min-width: 1439px) {
    .basic-box:not(.ver-small) {
        padding: 4rem 3rem;
    }
}


/* Form Box */
[class*="form-box-"] {
    position: relative;
}

input.form-input,
select.form-select {
    position: relative;
    padding: 1.25rem 0.75rem;
    border-color: rgba(var(--color-black-rgb),0.1);
    background-color: var(--color-background);
    border-radius: 0.625rem;
    box-shadow: 0 3px 5px -3px rgba(var(--color-black-rgb),0.1);
    transition: .3s ease-in-out;
}

input.form-input:valid,
input.form-input:focus {
    outline: none;
    border-color: var(--color-gray);
}

[class*="form-box-"] .label-txt {
    position: absolute;
    top: -10px;
    left: 1rem;
    line-height: 20px;
    text-shadow: -2px -2px 0 var(--color-background), 2px -2px 0 var(--color-background), -2px  2px 0 var(--color-background), 2px  2px 0 var(--color-background);
    transition: .3s ease-in-out;
    color: var(--color-basic);
    font-size: 80%;
}

[class*="form-box-"] .cal-btn {
    position: absolute;
    top: calc(50% - 10px);
    right: 1rem;
    line-height: 20px;
    font-size: 1.25rem;
    transition: .3s ease-in-out;
    color: var(--color-gray-light);
}

input.gray-bg-input:not(:focus) {
    background-color: var(--color-hover-gray);
}

input.gray-bg-input + .label-txt {
    left: 1rem;
}

input.gray-bg-input:not(:placeholder-shown) + .label-txt,
input.gray-bg-input:focus + .label-txt {
    left: 0rem;
}

.pw-toggle-btn {
    position: absolute;
    top: 1.25rem;
    right: 0;
    color: var(--color-gray);
    opacity: 0.5;
}

.pw-toggle-btn.view {
    opacity: 1;
    color: var(--color-basic);
}


/* 상단 헤더 */
#header {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;

    overflow: hidden;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-right: 0.5rem;
    background-color: rgba(var(--color-point-rgb),0.9);
    backdrop-filter: blur(5px);
    color: var(--color-white);
    z-index: 1000;
}

#header .dday-count-display {
    flex-shrink: 0;
    position: relative;
    height: var(--header-height);
    line-height: var(--header-height);
    padding: 0 2rem 0 1.5rem;
    background-color: var(--color-aqua);
    color: var(--color-white);
    font-weight: 900;
    font-size: 1.5rem;

    clip-path: polygon(
        0% 0%,       /* 1. 좌상단 (x y) */
        calc(100% - 1rem) 0%, /* 2. 우상단 (오른쪽에서 25px 안으로 들어온 지점) */
        100% 100%,   /* 3. 우하단 (오른쪽 끝 하단) */
        0% 100%      /* 4. 좌하단 */
    );
    -webkit-clip-path: polygon(0% 0%, calc(100% - 1rem) 0%, 100% 100%, 0% 100%);
    text-shadow: 0 1px 2px rgba(var(--color-black-rgb),0.1);
    transition: .3s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#header .dday-count-display:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--color-blue);

    clip-path: polygon(
        0% 0%,
        100% 0%,
        calc(100% - 1rem) 100%,
        0% 100%
    );
    content: '';
}

#header .dday-count-display em {
    position: relative;
    display: block;
}

#header .gnb {
    flex-grow: 1;
    display: none;
    overflow: hidden;
    padding: 0 1rem;
}

#header .gnb ul li {
    position: relative;
    width: auto;
}

#header .gnb ul li:first-child {
    display: none !important;
}

#header .gnb ul li:not(:last-child):before {
    position: absolute;
    top: calc(50% - 3px);
    right: -3px;
    width: 6px;
    height: 6px;
    background-color: rgba(var(--color-white-rgb),0.2);
    border-radius: 50%;
    content: '';
}

#header .gnb ul li .gnb-mnu-btn {
    position: relative;
    display: block;
    height: var(--header-height);
    line-height: var(--header-height);
    padding: 0 1rem;
    color: var(--color-white);
    font-family: var(--font-point);
    font-size: 1rem;
    text-shadow: 0 1px 2px rgba(var(--color-black-rgb),0.1);
    transition: .3s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#header .gnb ul li .gnb-mnu-btn.active {
    color: var(--color-lime);
}

#header .participate {
    flex-shrink: 0;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    z-index: 1100;
    transition: .3s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#header .participate .participate-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    padding: 0 0.5rem;
    height: var(--header-height);
    font-family: var(--font-point);
    color: var(--color-white);
}

#header .participate .participate-btn span.ico {
    width: 20px;
    font-size: 0;
}

@media screen and (min-width: 374px) {
    #header .dday-count-display {
        font-size: 1.875rem;
    }

    #header .participate .participate-btn {
        padding: 0 1rem;
    }
}

@media screen and (min-width: 767px) {
    #header {
        padding-right: 1rem;
    }

    #header .dday-count-display {
        padding: 0 3rem 0 2.5rem;
        font-size: 2rem;
    }
}

@media screen and (min-width: 1239px) {
    #header {
        padding-right: 0;
    }

    #header .gnb {
        display: block;
    }

    #header .participate .participate-btn {
        flex-direction: column;
        padding: 0 2rem;
        border-left: 1px solid rgba(var(--color-white-rgb),0.2);
        background-color: var(--color-green);
    }

    #header .participate .participate-btn span.ico {
        width: 30px;
    }
}

@media screen and (min-width: 1439px) {
    #header .dday-count-display {
        padding: 0 5rem 0 3rem;
        font-size: 3rem;
    }

    #header .gnb ul li .gnb-mnu-btn {
        padding: 0 1.25rem;
    }
}

@media screen and (min-width: 1639px) {
    #header .gnb ul li .gnb-mnu-btn {
        font-size: 1.25rem;
    }
}


/* 하단 푸터 */
#footer {
    position: relative;
    padding: 2rem 1rem 4rem;
    background-color: var(--color-background);
    background-image: url("../../img/foot_bg_m.png");
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 100% auto;
    transition: .3s;
}

#footer:after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: rgba(var(--color-point-rgb),0.1);
    content: '';
}

#footer .inner {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

#footer h2 {
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: var(--font-weight-medium);
}

#footer .foot-content h1 {
    width: 90%;
    max-width: 450px;
    margin-bottom: 1rem;
    font-size: 0;
}

#footer .foot-content ul {
    flex-wrap: wrap;
    gap: 0.25rem 2rem;
    max-width: 1000px;
    font-size: clamp(0.875rem, 2vw, 1.125rem);
    color: var(--color-gray);
}

#footer .foot-content ul li span {
    color: var(--color-basic);
    font-weight: var(--font-weight-medium);
}

@media screen and (min-width: 767px) {
    #footer {
        padding: 3rem 2rem 5rem;
        background-image: url("../../img/foot_bg.png");
    }
}

@media screen and (min-width: 1039px) {
    #footer {
        padding-bottom: 6rem;
    }
}

@media screen and (min-width: 1239px) {
    #footer {
        padding-inline: 3rem;
    }

    #footer .inner {
        flex-direction: row;
        align-items: flex-start;
        gap: 4rem;
    }

    #footer h2 {
        flex-shrink: 0;
        transform: translateY(-7px);
    }

    #footer .foot-content {
        flex-grow: 1;
    }

    #footer .foot-content h1 {
        margin-bottom: 2rem;
    }
}

@media screen and (min-width: 1439px) {
    #footer {
        padding-inline: 4rem;
        padding-block: 4rem 10rem;
        background-repeat: repeat-x;
        background-size: 1920px auto;
    }
}


/* 콘텐츠 공통 */
.fw-content {
    position: relative;
    overflow: hidden;
    /* min-height: calc(100vh - var(--header-height)); */
    padding: 3rem 1rem;
    transition: .3s;
}

.fw-content .inner {
    position: relative;
}

.fw-content h3.won-tit em {
    display: inline-block;
    padding: 6px 20px;
    background-color: var(--color-blue-deep);
    color: var(--color-white);
    font-size: clamp(1rem, 4vw, 1.5rem);
    font-weight: var(--font-weight-medium);
    border-radius: 40px;
}

.jum-ul li {
    position: relative;
    line-height: 1.4;
    padding-left: 15px;
    color: var(--color-gray);
    font-size: clamp(0.875rem, 3vw, 1rem);
}

.jum-ul li:not(:first-child) {
    margin-top: 0.5rem;
}

.jum-ul li:before {
    position: absolute;
    top: 10px;
    left: 0;
    width: 4px;
    height: 4px;
    background-color: var(--color-gray);
    border-radius: 50%;
    content: '';
}

@media screen and (min-width: 767px) {
    .fw-content {
        padding: 4rem 2rem;
    }

    .jum-ul li:before {
        top: 12px;
    }
}

@media screen and (min-width: 1023px) {
    .fw-content h3.won-tit em {
        padding: 8px 40px;
        font-size: 1.25rem;
    }
}

@media screen and (min-width: 1239px) {
    .fw-content {
        padding: 6rem 3rem;
    }
}

@media screen and (min-width: 1439px) {
    .fw-content {
        padding: 6rem 4rem;
    }
}


/* 최상단 이미지 */
.fw-top {
    position: relative;
    overflow: hidden;
    font-size: 0;
}

.fw-top .fw-top-img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-image: url("../../img/main_top_img.jpg?datetime=20250903T165200");
    background-position: top center;
    background-repeat: no-repeat;
    background-size: cover;
}

@media screen and (min-width: 767px) {
    .fw-top {
        height: 100vh;
    }

    .fw-top figure {
        display: none;
    }
}

@media screen and (min-width: 1239px) {
}

@media screen and (min-width: 1439px) {
    .fw-top {
        height: 1040px;
    }
}



/* 대회 취지 */
.fw-purpose {
    background-color: var(--color-box-basic);
    font-size: clamp(1rem, 2.5vw, 1.5rem);
}

.fw-purpose .skechers-markbox {
    padding: 2rem 3rem;
    background-color: var(--color-blue-deep);
    text-align: center;
    font-size: 0;
}

.fw-purpose .skechers-markbox img {
    width: 80%;
    max-width: 487px;
}

.fw-purpose .inner dl:not(:first-child) {
    margin-top: 40px;
}

.fw-purpose .fw-content {
    position: relative;
    background: url("../../img/purpose_bg.png") no-repeat center/cover;
}

.fw-purpose .fw-content:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(var(--color-blue-deep-rgb),0.6);
    content: '';
}

.fw-purpose .inner {
    position: relative;
    color: var(--color-white);
}

.fw-purpose .inner dl dt {
    text-align: center;
    font-size: 0;
}

.fw-purpose .inner dl dt img {
    width: 30%;
    max-width: 130px;
}

.fw-purpose .inner dl dd {
    margin-top: 20px;
}

.fw-purpose .inner dl dd b,
.fw-purpose .inner dl dd b em {
    position: relative;
}

.fw-purpose .inner dl dd b:before {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 10px;
    background-color: var(--color-blue-deep);
    opacity: 0;
    content: '';
}

.fw-purpose br.pc-br {
    display: none;
}

@media screen and (min-width: 767px) {
    .fw-purpose {
        line-height: 1.4;
        text-align: center;
    }

    .fw-purpose .inner dl dd b:before {
        opacity: 1;
    }

    .fw-purpose br.pc-br {
        display: block;
    }
}

@media screen and (min-width: 1239px) {
    .fw-purpose .skechers-markbox {
        padding: 3rem;
    }
}

@media screen and (min-width: 1439px) {
}



/* 대회요강 */
.fw-introduce {
    position: relative;
    overflow: hidden;
}

.fw-introduce .info-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    font-weight: var(--font-weight-regular);
    font-size: clamp(1.5rem, 4vw, 1.5rem);
}

.fw-introduce .info-list dl {
    position: relative;
}

.fw-introduce .info-list dl dt {
    color: var(--color-blue);
}

.fw-introduce .info-list dl dd {
    font-weight: var(--font-weight-heavy);
}

.fw-introduce .info-list dl dd small {
    font-size: clamp(1rem, 4vw, 1.25rem);
    font-weight: var(--font-weight-medium);
}

.fw-introduce figure {
    width: 70%;
    margin: 0 auto;
    margin-top: 2rem;
    font-size: 0;
}

@media screen and (min-width: 767px) {
    .fw-introduce .info-list {
        gap: 0;
    }

    .fw-introduce .info-list dl {
        position: relative;
        display: flex;
        justify-content: flex-start;
        align-items: flex-start;
        gap: 2rem;
    }

    .fw-introduce .info-list dl:not(:first-child) {
        margin-top: 1rem;
        padding-top: 1rem;
    }

    .fw-introduce .info-list dl:not(:first-child)::before {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: var(--color-line-basic);
        content: '';
    }

    .fw-introduce .info-list dl dt {
        flex-shrink: 0;
        min-width: 100px;
        font-size: 80%;
        padding-top: 6px;
    }

    .fw-introduce .info-list dl dd {
        flex-grow: 1;
    }

    .fw-introduce figure {
        width: 50%;
    }
}

@media screen and (min-width: 1239px) {
    .fw-introduce .info-list dl {
        gap: 4rem;
    }

    .fw-introduce figure {
        position: absolute;
        left: 60%;
        top: 18%;
        width: 500px;
    }
}


/* 프로그램 */
.fw-program {
    position: relative;
    background: linear-gradient(to bottom, var(--color-point) 0%, var(--color-blue) 50%, var(--color-point) 100%);
    background-size: 200% 100%;
    background-position: 0% 50%;
    color: var(--color-white);
}

.fw-program h2.tit-h2 small {
    color: var(--color-lime);
}

.fw-program h2.tit-h2 em {
    color: var(--color-aqua);
}

.fw-program .cont {
    display: flex;
    flex-direction: column;
    gap: 4rem;
}

.fw-program .program-content h3.tit-h3 {
    margin-bottom: 2rem;
    text-align: center;
}

.fw-program .program-content h3.tit-h3 .tit {
    display: inline-block;
    background-color: var(--color-green);
    padding: 0.5rem 2rem;

    clip-path: polygon(
        0% 0%,       /* 1. 좌상단 (x y) */
        92% 0%, /* 2. 우상단 (오른쪽에서 25px 안으로 들어온 지점) */
        100% 100%,   /* 3. 우하단 (오른쪽 끝 하단) */
        8% 100%      /* 4. 좌하단 */
    );
    -webkit-clip-path: polygon(0% 0%, 92% 0%, 100% 100%, 8% 100%);
}

.program-content.time-table .time-table-list {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.program-content.time-table .time-table-list:before {
    position: absolute;
    top: 0.875rem;
    bottom: 0.875rem;
    left: calc(25% + 2rem);
    width: 1px;
    border-left: 2px dashed rgba(var(--color-white-rgb),0.2);
    content: '';
}

.program-content.time-table .time-table-list dl {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 4rem;
    font-size: clamp(1.125rem, 3vw, 1.5rem);
}

.program-content.time-table .time-table-list dl dt {
    flex-shrink: 0;
    position: relative;
    width: 25%;
    text-align: right;
}

.program-content.time-table .time-table-list dl dt:after {
    position: absolute;
    top: 50%;
    right: -2.5rem;
    width: 1rem;
    height: 1rem;
    background-color: var(--color-lime);
    border-radius: 50%;
    transform: translateY(-50%);
    content: '';
}

.program-content.time-table .time-table-list dl dd {
    flex-grow: 1;
    font-weight: var(--font-weight-semibold);
}

.program-content.special-program .tab-mnu ul li .tab-mnu-btn {
    color: var(--color-white);
}

.program-content.special-program .tab-mnu ul li .tab-mnu-btn:before {
    background-color: var(--color-emerald);
}

.program-content.special-program .experience-content .pic-mov-box {
    overflow: hidden;
    font-size: 0;
    border-radius: 16px;
}

.program-content.special-program .experience-content .pic-mov-box video {
    width: 100%;
}

.program-content.special-program .experience-content p.comment-txt {
    padding: 2rem 1rem;
    font-size: clamp(1.125rem, 3vw, 1.25rem);
}

@media screen and (min-width: 767px) {
    .program-content.time-table .time-table-list:before {
        left: calc(40% + 2.5rem);
    }

    .program-content.time-table .time-table-list dl {
        gap: 5rem;
    }

    .program-content.time-table .time-table-list dl dt {
        width: 40%;
    }

    .program-content.time-table .time-table-list dl dt:after {
        right: -3rem;
    }
}

@media screen and (min-width: 1023px) {
    .fw-program .program-content h3.tit-h3 {
        margin-bottom: 3rem;
    }

    .fw-program .cont {
        flex-direction: row;
        justify-content: space-between;
        align-items: stretch;
    }

    .fw-program .program-content {
        width: 49%;
    }

    .program-content.time-table .time-table-list {
        gap: 3.5rem;
    }

}

@media screen and (min-width: 1239px) {
}

@media screen and (min-width: 1439px) {
    .fw-program .program-content {
        width: 42%;
    }
}


/* 기념품 안내 */
.fw-gift {
    position: relative;
    min-height: calc(100vh - var(--header-height));
    background: url("../../img/bg_texture01.jpg") no-repeat center/cover;
}

.fw-gift h2.tit-h2 {
    margin-bottom: 1rem;
}

.fw-gift h2.tit-h2 small {
}

.fw-gift h2.tit-h2 em {
}

.gongtong-guide-txt {
    line-height: 1.4;
    margin-bottom: 2rem;
    color: var(--color-blue-deep);
    font-weight: var(--font-weight-semibold);
    font-size: clamp(1rem, 3vw, 1.25rem);
}

.gift-content {
    position: relative;
    width: 100%;
    font-size: 0;
}

.gift-content .pakage-image {
    overflow: hidden;
    margin-bottom: 1.5rem;
    border-radius: 10px;
    font-size: 0;
}

.gift-content .pakage-text {
    width: 90%;
    margin: 0 auto;
}

.gift-content picture {
    overflow: hidden;
    display: block;
    border-radius: 1rem;
    font-size: 0;
}

.fw-gift .gift-note {
    padding: 1.5rem;
    margin-top: 2rem;
    background-color: rgba(255,255,255,0.5);
    border-radius: 1rem;
}

.fw-gift .gift-note h4 {
    margin-bottom: 1rem;
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: var(--font-weight-medium);
}

.fw-gift .gift-note ul li {
    color: rgba(var(--color-basic-rgb),0.6);
}

@media screen and (min-width: 767px) {
}

@media screen and (min-width: 1023px) {
    .gongtong-guide-txt {
        line-height: 1.6;
        text-align: center;
    }

    .gongtong-guide-txt b,
    .gongtong-guide-txt em {
        position: relative;
    }

    .gongtong-guide-txt b:before {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 8px;
        background-color: var(--color-lime);
        content: '';
    }

    .gift-slider {
        overflow: hidden;
    }

    .gift-content .in-box {
        display: flex;
        justify-content: space-between;
        align-items: center;
        gap: 30px;
    }

    .gift-content .pakage-image {
        flex-grow: 1;
    }

    .gift-content .pakage-text {
        flex-shrink: 0;
        width: 30%;
        max-width: 400px;
    }
}

@media screen and (min-width: 1239px) {
    .gift-content .pakage-text {
        width: 40%;
    }

    .gift-content picture {
        border-radius: 0;
    }
}

@media screen and (min-width: 1439px) {
    .fw-gift .gift-note {
        padding: 2rem;
    }
}


/* 패키지 내 신발 소개 */
.fw-product {}

.fw-product .product-view-content {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 2%;
    max-width: 800px;
    margin: 0 auto;
    margin-top: 1rem;
}

.fw-product .product-view-content .pvc-btn {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px;
    width: 32%;
    padding: 1rem 0;
    background-color: var(--color-white);
    text-align: center;
    color: var(--color-blue-deep);
    border-radius: 0.5rem;
    transition: .3s ease;
}

.fw-product .product-view-content .pvc-btn:after {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border: 3px solid var(--color-blue-deep);
    border-radius: inherit;
    content: '';
}

.fw-product .product-view-content .pvc-btn em {
    line-height: 1.4;
    font-weight: var(--font-weight-semibold);
    font-size: clamp(1rem, 3vw, 1.5rem);
}

.fw-product .product-view-content .pvc-btn small {
    width: calc(100% - 20px);
    padding: 0.5rem;
    background-color: var(--color-blue-deep);
    color: var(--color-white);
    border-radius: 0.3rem;
    transition: .2s;
}

.fw-product .gift-note {
    padding: 1.5rem;
    margin-top: 2rem;
    background-color: var(--color-box-basic);
    border-radius: 1rem;
}

.fw-product .gift-note h4 {
    margin-bottom: 1rem;
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: var(--font-weight-medium);
}

.fw-product .gift-note ul li {
    color: rgba(var(--color-basic-rgb),0.6);
}

@media screen and (min-width: 1023px) {
    .product-slider {
        overflow: hidden;
    }

    .fw-product .product-view-content .pvc-btn:hover {
        background-color: var(--color-blue-deep);
        transform: translateY(-5px);
        box-shadow: 0 5px 20px -5px rgba(var(--color-black-rgb),0.1);
        color: var(--color-white);
    }

    .fw-product .product-view-content .pvc-btn:hover small {
        background-color: var(--color-box-basic);
        color: var(--color-blue-deep);
    }
}

@media screen and (min-width: 1439px) {
    .fw-product .gift-note {
        padding: 2rem;
    }
}


/* 코스안내 */
.fw-course {
    background: linear-gradient(to bottom, var(--color-brown) 0%, var(--color-sand) 100%);
    /*
    background-image: url("../../img/bg_texture01.jpg");
    background-position: center;
    background-size: auto 100%;
    background-repeat: repeat;
    background-attachment: fixed;
    */
}

.fw-course h2.tit-h2 small {
    color: var(--color-lime);
}

.fw-course h2.tit-h2 em {
    color: var(--color-white);
}

.fw-course .warning-txt {
    margin-top: 1rem;
    color: var(--color-yellow);
}

.course-content {
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
    color: var(--color-white);
}

.course-content .course-box {
    position: relative;
}

.course-content .course-box figure {
    overflow: hidden;
    background-color: rgba(var(--color-white-rgb),0.9);
    backdrop-filter: blur(5px);
    box-shadow: 0 5px 10px -7px rgba(var(--color-black-rgb),0.1);
    border-radius: 16px;
    font-size: 0;
}

.course-content .course-box h3 {
    position: absolute;
    top: -1rem;
    left: -0.5rem;
    padding: 0.5rem 1.5rem;
    background-color: var(--color-basic);
    color: var(--color-white);
    font-size: clamp(1rem, 3vw, 2rem);
    transform: rotate(-12deg);

    clip-path: polygon(
        0% 0%,       /* 1. 좌상단 (x y) */
        92% 0%, /* 2. 우상단 (오른쪽에서 25px 안으로 들어온 지점) */
        100% 100%,   /* 3. 우하단 (오른쪽 끝 하단) */
        8% 100%      /* 4. 좌하단 */
    );
    -webkit-clip-path: polygon(0% 0%, 92% 0%, 100% 100%, 8% 100%);
}

.course-content .course-box .course-guide {
    margin-top: 1rem;
}

.course-content .course-box .course-guide h4 {
    margin-bottom: 10px;
    font-weight: var(--font-weight-bold);
    font-size: 120%;
}

.course-content .course-box .course-guide p {
    font-size: 90%;
}

@media screen and (min-width: 767px) {
    .course-content {
        flex-direction: row;
    }

    .course-content .course-box {
        width: calc(50% - 1rem);
    }
}

@media screen and (min-width: 1239px) {
    .fw-course {
        background-size: cover;
    }

    .fw-course .warning-txt {
        padding-left: 1rem;
        margin-top: 2rem;
    }

    .course-content .course-box h3 {
        top: -2rem;
        left: -1rem;
        padding: 0.5rem 2rem;
    }

    .course-content .course-box figure {
        border-radius: 48px 5px;
    }

    .course-content .course-box .course-guide {
        padding-left: 1rem;
        margin-top: 2rem;
    }
}

@media screen and (min-width: 1439px) {
}


/* 행사장 안내 */
.fw-location {
    overflow: hidden;
    background-color: var(--color-gray-deep);
    color: var(--color-white);
}

.fw-location .visual-mov {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    filter: grayscale(1);
    opacity: 0.1;
    font-size: 0;
}

.fw-location .visual-mov .visual-video {
    height: 100%;
}

.fw-location h2.tit-h2 small {
    color: var(--color-lime);
}

.fw-location h2.tit-h2 em {
    color: var(--color-white);
}

.fw-location .location-content {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.fw-location .location-content .location-map figure {
    overflow: hidden;
    border-radius: 16px;
    font-size: 0;
}

.fw-location .location-content .location-map .map-direct {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
    gap: 10px;
    margin-top: 1rem;
}

.fw-location .location-content .location-map .map-direct .map-link {
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: calc(50% - 5px);
    max-width: 250px;
    background-color: var(--color-background);
    border-radius: 10px;
}

.fw-location .location-content .location-map .map-direct .map-link.map-link-naver {
    background-color: #03C75A;
    color: #FFF;
}

.fw-location .location-content .location-map .map-direct .map-link.map-link-kakao {
    background-color: #FAE100;
}

/*
.fw-location .location-content .location-map .map-direct .map-link:after {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: inherit;
    perspective: 1px;
    transition: .3s;
    content: '';
}
*/

.fw-location .location-content .location-map .map-direct .map-link .ico {
    flex-shrink: 0;
    width: 50px;
    border-right: 1px solid rgba(0,0,0,0.1);
    font-size: 0;
}

.fw-location .location-content .location-map .map-direct .map-link em {
    flex-grow: 1;
    line-height: 1.2;
    padding: 0 16px;
}

.fw-location .location-content .location-info {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.fw-location .location-content .location-info h3.tit-h3 {
    display: inline-block;
    padding: 0.5rem 2rem;
    margin-bottom: 1rem;
    background-color: var(--color-green);
    transform: rotate(-2deg);

    clip-path: polygon(
        0% 0%,       /* 1. 좌상단 (x y) */
        92% 0%, /* 2. 우상단 (오른쪽에서 25px 안으로 들어온 지점) */
        100% 100%,   /* 3. 우하단 (오른쪽 끝 하단) */
        8% 100%      /* 4. 좌하단 */
    );
    -webkit-clip-path: polygon(0% 0%, 92% 0%, 100% 100%, 8% 100%);
}

.fw-location .location-content .info1 p {
    font-size: clamp(1.125rem, 3vw, 1.25rem);
}

.fw-location .location-content .location-info .guide-txt .pin {
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: var(--font-weight-semibold);
    color: var(--color-lime);
}

.fw-location .location-content .location-info .guide-txt .pin small {
    font-weight: var(--font-weight-medium);
}

.fw-location .location-content .bus-list {
    gap: 0.5rem;
}

.fw-location .location-content .bus-list dl {
    align-items: flex-start;
    gap: 1rem;
}

.fw-location .location-content .bus-list dl dt {
    flex-shrink: 0;
    padding-top: 0.2rem;
}

.fw-location .location-content .bus-list dl dd ul {
    flex-wrap: wrap;
    gap: 5px;
}

.fw-location .location-content .bus-list dl dd ul li {
    padding: 0.2rem 1rem;
    border: 1px solid #666;
    font-size: clamp(0.875rem, 3vw, 1rem);
    font-weight: var(--font-weight-bold);
    border-radius: 3px;
}

.fw-location .location-content .bus-list dl.bus-blue dt .ico    { color: #0ea9d4; }
.fw-location .location-content .bus-list dl.bus-blue dd ul li   { border-color: #0ea9d4; color: #0ea9d4; }
.fw-location .location-content .bus-list dl.bus-green dt .ico   { color: #0ed432; }
.fw-location .location-content .bus-list dl.bus-green dd ul li  { border-color: #0ed432; color: #0ed432; }
.fw-location .location-content .bus-list dl.bus-red dt .ico     { color: #d95d1f; }
.fw-location .location-content .bus-list dl.bus-red dd ul li    { border-color: #d95d1f; color: #d95d1f; }

@media screen and (min-width: 767px) {
}

@media screen and (min-width: 1023px) {
    .fw-location .location-content {
        flex-direction: row;
        gap:  4rem;
    }

    .fw-location .location-content .location-map {
        flex-shrink: 0;
        width: 40%;
    }

    .fw-location .location-content .location-info {
        flex-grow: 1;
        gap: 4rem;
    }
}

@media screen and (min-width: 1239px) {
    .fw-location .location-content .location-map {
        flex-shrink: 0;
        width: 47%;
    }
}

@media screen and (min-width: 1439px) {
    .fw-location .visual-mov .visual-video {
        height: 120%;
    }
}


/* 기부처/협찬사 */
.donate-sponsor-box:not(:last-child) {
    margin-bottom: 2rem;
}

.donate-sponsor-box h3 {
    margin-bottom: 1rem;
}

.donate-sponsor-box .ds-list {
    padding: 1rem;
    background-color: var(--color-box-basic);
    border-radius: 0.5rem;
}

.donate-sponsor-box .ds-list ul {
    flex-wrap: wrap;
    align-items: stretch;
    gap: 20px 2%;
}

.donate-sponsor-box .ds-list ul li {
    width: 32%;
}

.donate-sponsor-box .ds-list ul li .ds-link-btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    text-align: center;
    color: var(--color-gray);
    font-size: clamp(0.875rem, 3vw, 1rem);
    cursor: default;
}

.donate-sponsor-box .ds-list ul li .ds-link-btn .logomark {
    overflow: hidden;
    background-color: var(--color-background);
    border-radius: 5px;
    font-size: 0;
}

.donate-sponsor-box .ds-list ul li.comingsoon .ds-link-btn {
    cursor: default;
}

.donate-sponsor-box .ds-list ul li.comingsoon .ds-link-btn .logomark img {
    opacity: 0.3;
}

@media screen and (min-width: 767px) {
    .donate-sponsor-box .ds-list ul {
        gap: 20px 1%;
    }

    .donate-sponsor-box .ds-list ul li {
        width: 24.25%;
    }
}

@media screen and (min-width: 1023px) {
    .donate-sponsor-box .ds-list ul li {
        width: 19.2%;
    }
}

@media screen and (min-width: 1239px) {
    .donate-sponsor-box:not(:last-child) {
        margin-bottom: 4rem;
    }

    .donate-sponsor-box .ds-list {
        padding: 2rem;
    }

    /*
    .donate-sponsor-box .ds-list ul li {
        width: 15.8%;
    }
    */
}


/* 런티켓/러너스테이션 */
.fw-ticket-station {
    background-color: var(--color-blue-deep);
    color: var(--color-white);
}

.fw-ticket-station h2.tit-h2 small {
    color: var(--color-lime);
}

.fw-ticket-station h2.tit-h2 em {
    color: var(--color-white);
}

.fw-ticket-station .tab-mnu ul li .tab-mnu-btn:hover,
.fw-ticket-station .tab-mnu ul li .tab-mnu-btn.selected {
    background-color: var(--color-green);
}

.ticket-station-slider picture {
    display: block;
    overflow: hidden;
    border-radius: 1rem;
    font-size: 0;
}

@media screen and (min-width: 1023px) {
    .ticket-station-slider {
        overflow: hidden;
    }
}


/* 자주 묻는 질문 */
.fw-faq {
    background-color: var(--color-box-basic);
}

.fw-faq .faq-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.fw-faq .faq-list dl {
    background-color: var(--color-background);
    box-shadow: 0 2px 5px rgba(var(--color-point-rgb),0.08);
}

.fw-faq .faq-list dl dt .faq-q-btn,
.fw-faq .faq-list dl dd {
    padding: 1rem;
}

.fw-faq .faq-list dl dt .faq-q-btn {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    text-align: left;
    transition: .3s;
}

.fw-faq .faq-list dl dt .faq-q-btn .q-mark {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    line-height: 40px;
    background-color: var(--color-blue);
    text-align: center;
    color: var(--color-white);
    border-radius: 15px;
}

.fw-faq .faq-list dl dt .faq-q-btn .q-txt {
    flex-grow: 1;
    line-height: 1.2;
    font-weight: var(--font-weight-medium);
}

.fw-faq .faq-list dl dt .faq-q-btn .arrow {
    flex-shrink: 0;
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    opacity: 0.4;
    transition: .3s;
}

.fw-faq .faq-list dl dt .faq-q-btn.on .arrow {
    transform: rotate(180deg);
}

.fw-faq .faq-list dl dt .faq-q-btn.on .q-txt {
    color: var(--color-blue);
}

.fw-faq .faq-list dl dd {
    border-top: 1px solid var(--color-line-light);
    color: var(--color-gray-deep);
    word-break: break-all;
}

@media screen and (min-width: 767px) {
    .fw-faq .faq-list dl dt .faq-q-btn,
    .fw-faq .faq-list dl dd {
        padding: 1.25rem 1.5rem;
    }

    .fw-faq .faq-list dl dd {
        padding-block: 1.5rem;
    }
}

@media screen and (min-width: 1239px) {
    .fw-faq .faq-list dl dt .faq-q-btn,
    .fw-faq .faq-list dl dd {
        padding: 1.25rem 2rem;
    }

    .fw-faq .faq-list dl dd {
        padding-block: 2rem;
    }

    .fw-faq .faq-list dl dt .faq-q-btn {
        gap: 1rem;
    }

    .fw-faq .faq-list dl dt .faq-q-btn .q-txt {
        font-weight: var(--font-weight-semibold);
    }
}

@media screen and (min-width: 1439px) {
    .fw-faq .faq-list dl dd {
        padding-left: calc(2rem + 40px + 1rem);
    }
}


/* 일반 팝업 */
.sticker-popup {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    overflow-y: auto;
    padding: 2rem;
    background-color: rgba(var(--color-blue-deep-rgb),0.8);
    backdrop-filter: blur(5px);
    z-index: 5000;
}

.sticker-popup .popup-con {
    display: block;
    overflow: hidden;
    max-width: 600px;
    margin: 0 auto;
    font-size: 0;
    border-radius: 1rem;
}

.sticker-popup .closebox {
    position: fixed;
    bottom: 2rem;
    left: calc(50% - 50px);
}

.sticker-popup .closebox .popup-close-btn {
    display: block;
    width: 100px;
    height: 50px;
    line-height: 50px;
    background-color: var(--color-white);
    color: var(--color-blue-deep);
    font-size: 2rem;
    text-align: center;
    border-radius: 25px;
}

.sticker-popup .popup-control {
    flex-wrap: wrap;
    width: 100%;
    max-width: 700px;
    gap: 20px;
    margin: 0 auto;
    font-size: 0;
}

.sticker-popup .popup-control li {
    overflow: hidden;
    max-width: 340px;
    border-radius: 0.5rem;
}

.sticker-popup .popup-control.one {
    max-width: 500px;
}

.sticker-popup .popup-control.one li {
    width: 100%;
    max-width: 100%;
}



@media screen and (min-width: 1239px) {
    .sticker-popup {
        padding: 4rem;
    }

    .sticker-popup .popup-control {
        max-width: 920px;
    }

    .sticker-popup .popup-control li {
        max-width: 450px;
    }
}




/* 팝업 리스트 */
.popup-zone {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    justify-content: center;
    align-items: center;
    padding: 20px;
    background-color: rgba(var(--color-black-rgb),0.7);
    backdrop-filter: blur(5px);
    color: var(--color-white);
    z-index: 8000;
}

.popup-zone.open {
    display: flex;
}

.popup-zone .popup-dialog {
    position: relative;
    max-width: 800px;
    overflow: hidden;
}

.popup-zone .popup-head,
.popup-zone .popup-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.popup-zone .popup-head h1 {
    font-size: clamp(1.25rem, 3vw, 2rem);
}

.popup-zone .popup-head .swiper-pagination {
    position: relative;
    bottom: auto;
    top: auto;
    left: auto;
    width: auto;
}

.popup-zone .popup-content {
    padding-block: 20px;
    margin-block: 20px;
    border-top: 1px solid rgba(var(--color-white-rgb),0.2);
    border-bottom: 1px solid rgba(var(--color-white-rgb),0.2);
}

.popup-zone .popup-content .popup-slide a,
.popup-zone .popup-content .popup-slide figure {
    display: block;
    overflow: hidden;
    font-size: 0;
    border-radius: 5px;
}

.popup-zone .popup-foot .popup-btn {
    border-radius: 3px;
}

.popup-zone .popup-foot .swiper-button {
    background-color: transparent;
    border: 1px solid rgba(var(--color-white-rgb),0.3);
    color: var(--color-white);
}

.popup-zone .popup-foot .swiper-button:not(.swiper-button-disabled):hover {
    border: 1px solid rgba(var(--color-white-rgb),1);
    background-color: rgba(var(--color-black-rgb),0.2);
}

.popup-zone .popup-foot .swiper-button.swiper-button-disabled {
    opacity: 0.5;
    cursor: default;
}



/* 준비중 페이지 */
.waiting-page {
    padding: 50px 20px;
}

.waiting-page h3 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.waiting-page h3 figure {
    width: 50%;
    max-width: 250px;
    font-size: 0;
}

.waiting-page h3 em {
    font-size: clamp(2rem, 6vw, 5rem);
    text-transform: uppercase;
    font-weight: var(--font-weight-medium);
    background: linear-gradient(45deg, var(--color-point), var(--color-blue));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.waiting-page p {
    position: relative;
    margin-top: 20px;
    color: var(--color-gray);
    font-size: clamp(1rem, 2.5vw, 1.5rem);
    text-align: center;
}

.waiting-page p br {
    display: none;
}

@media screen and (min-width: 767px) {
    .waiting-page p br {
        display: block;
    }
}

@media screen and (min-width: 1023px) {
    .waiting-page {
        padding: 100px 20px;
    }

    .waiting-page h3 em {
        font-weight: var(--font-weight-light);
    }

    .waiting-page p {
        padding-top: 180px;
        margin-top: 30px;
    }

    .waiting-page p:after {
        position: absolute;
        top: 0;
        left: 50%;
        width: 1px;
        height: 150px;
        background-color: var(--color-line-basic);
        content: '';
    }
}




/* ------------------------------------------------------------ */




@media screen and (min-width: 639px) {
}

@media screen and (min-width: 767px) {
}

@media screen and (min-width: 979px) {
}

@media screen and (min-width: 1023px) {
}

@media screen and (min-width: 1239px) {
}

@media screen and (min-width: 1340px) {
}

@media screen and (min-width: 1439px) {
}

@media screen and (min-width: 1640px) {
}

@media screen and (min-width: 1840px) {
}
