@charset "utf-8";

/*
	** MAIN CSS
*/

.main-section {
    padding: 140px 0;
    min-height: calc(100vh + 60px);
    font-family: var(--secondary-font);
}
.main-section .main-title-box.center {
    text-align: center;
}
.main-section .main-title {
    font-size: 2.5em;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 40px;
}
.main-section .main-title strong {
    display: block;
    font-size: 1.6em;
    font-weight: 700;
}
.main-section .main-desc {
    font-size: var(--font-size-28);
    line-height: 1.6;
    margin-bottom: 10px;
}
.main-section .main-title span {
    position: relative;
    font-size: inherit;
    font-weight: inherit;
    z-index: 1;
}
.main-section.main-grade .main-title span {color: var(--secondary-color);}
.main-section.main-subject .main-title span {color: #00d5ff;}
.main-section.main-type .main-title span {color: #857cf6;}
.main-section.main-map .main-title span {color: #4a7df3;}
.main-section .main-title span::before,
.main-section .main-title span::after {
    content: "";
    position: absolute;
}
.main-section:is(.main-grade, .main-subject, .main-type) .main-title span::before {
    left: -35px;
    top: -15px;
    width: 38px;
    height: 44px;
    opacity: 0.3;
    background: url("../img/main/main-title-img01.svg") no-repeat center;
}
.main-section:is(.main-grade, .main-subject, .main-type) .main-title span::after {
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 3px;
    opacity: 0.2;
    background: url("../img/main/main-title-img02.svg") repeat-x left;
}
.main-section.main-grade .main-title span::before,
.main-section.main-grade .main-title span::after {
    filter: invert(57%) sepia(91%) saturate(478%) hue-rotate(93deg) brightness(95%) contrast(91%);
}
.main-section.main-type .main-title span::before,
.main-section.main-type .main-title span::after {
    filter: invert(58%) sepia(97%) saturate(2939%) hue-rotate(215deg) brightness(96%) contrast(102%);
}
.main-section.main-map .main-title span::before {
    z-index: -1;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 197px;
    height: 161px;
    background: url("../img/main/map-title-img.png") no-repeat center / contain;
}
@media all and (max-width: 1299px) {
    .main-section .main-title {
        font-size: 2.25em;
    }
    .main-section .main-desc {
        font-size: var(--font-size-24);
    }
}
@media all and (max-width: 1023px) {
    .main-section {
        padding: 100px 0;
        min-height: auto;
    }
    .main-section .main-title {
        font-size: var(--font-size-28);
        margin-bottom: 30px;
    }
    .main-section .main-desc {
        font-size: var(--font-size-20);
    }
    .main-section.main-map .main-title span::before {
        width: 130px;
        height: 106px;
    }
}
@media all and (max-width: 767px) {
    .main-section {
        padding: 70px 0;
    }
    .main-section .main-title {
        font-size: var(--font-size-18);
        margin-bottom: 20px;
    }
    .main-section .main-desc {
        font-size: var(--font-size-16);
    }
    .main-section:is(.main-grade, .main-subject, .main-type) .main-title span::before {
        left: -16px;
        top: -8px;
        width: 20px;
        height: 23px;
    }
    .main-section:is(.main-grade, .main-subject, .main-type) .main-title span::after {
        bottom: -3px;
        height: 2px;
    }
    .main-section.main-map .main-title span::before {
        width: 90px;
        height: 74px;
    }
}



.main-visual-slide {
    width: calc(100% - 40px);
    max-width: 1706px;
    margin: 0 auto;
}
.main-visual-slide .img-box {
    border-radius: 20px;
    overflow: hidden;
}
.main-visual-slide .img-box img {
    width: 100%;
}
.main-visual-slide .text-box {
    position: absolute;
    z-index: 5;
    top: 50%;
    left: 50%;
    width: 100%;
    transform: translate(-50%,-50%);
    text-align: center;
}
.main-visual-slide .text-box :is(.text, .title, .lnk) {
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    transition: all 0.5s ease-in-out;
}
.main-visual-slide .text-box .text {
    display: inline-block;
    margin-bottom: 10px;
    padding: 10px 45px 7px;
    border-radius: 99px;
    background: #ff939d;
    font-size: var(--font-size-30);
    font-family: "BMJUA", sans-serif;
    transition-delay: 0.5s;
}
.main-visual-slide .text-box .title {
    font-size: 5em;
    font-family: "Katuri", sans-serif;
    transition-delay: 0.65s;
    position: relative;
    z-index: 0;
}
.main-visual-slide .text-box .title::before {
    content: attr(data-visual-title);
    position: absolute;
    z-index: -1;
    -webkit-text-stroke: 10px #fff;
}
.main-visual-slide .text-box .lnk {
    display: inline-flex;
    align-items: center;
    margin-top: 45px;
    padding: 7px 20px;
    border-radius: 99px;
    border: 2px solid #000;
    background: #fff;
    font-size: var(--font-size-20);
    font-weight: 600;
    transition-delay: 0.8s;
}
.main-visual-slide .text-box .lnk .icon-custom {
    margin-left: 20px;
}
.main-visual-slide .swiper-slide-active .text-box :is(.text, .title, .lnk) {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
}
.main-visual-slide .swiper-pagination {
    left: 50% !important;
    bottom: 50px !important;
    transform: translateX(-50%);
    width: auto;
}
.main-visual-slide .swiper-pagination-bullet {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    font-size: var(--font-size-18);
    font-weight: 600;
    background: #fff;
    box-shadow: 5px 5px 10px rgba(0,0,0,0.2);
    opacity: 1;
}
.main-visual-slide .swiper-pagination-bullet-active {
    background: #ff939d;
}
.main-visual-slide .progress {
    position: absolute;
    transform: rotate(-90deg);
}
.main-visual-slide .circle {
    fill: none;
    stroke: #000;
    stroke-width: 2px;
    stroke-linecap: round;
    stroke-dasharray: 145.6px;
    stroke-dashoffset: 145.6px;
}
.main-visual-slide .swiper-pagination-bullet-active .circle {
    animation: progress 5s;
}
@keyframes progress {
    0% {stroke-dashoffset: 145.6px;}
    100% {stroke-dashoffset: 0;}
}
@media all and (max-width: 1299px) {
    .main-visual-slide .text-box .text {
        font-size: var(--font-size-26);
    }
    .main-visual-slide .text-box .title {
        font-size: 4.25em;
    }
    .main-visual-slide .text-box .lnk {
        margin-top: 30px;
        font-size: var(--font-size-17);
    }
    .main-visual-slide .swiper-pagination {
        bottom: 20px !important;
    }
}
@media all and (max-width: 1023px) {
    .main-visual-slide .text-box .text {
        padding: 8px 35px 5px;
        font-size: var(--font-size-22);
    }
    .main-visual-slide .text-box .title {
        font-size: 3.75em;
    }
    .main-visual-slide .text-box .title::before {
        -webkit-text-stroke: 8px #fff;
    }
    .main-visual-slide .swiper-pagination {
        display: none;
    }
}
@media all and (max-width: 767px) {
    .main-visual-slide .text-box .text {
        padding: 7px 20px 4px;
        font-size: var(--font-size-15);
    }
    .main-visual-slide .text-box .title {
        font-size: var(--font-size-28);
    }
    .main-visual-slide .text-box .title::before {
        -webkit-text-stroke: 6px #fff;
    }
    .main-visual-slide .text-box .lnk {
        margin-top: 10px;
        padding: 6px 15px;
        font-size: var(--font-size-14);
    }
}


.main-grade {
    overflow: hidden;
}
.main-grade .list-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px;
    margin-top: 80px;
}
.main-grade .list-box li {
    flex: 0 0 calc((100% - 90px) / 4);
}
.main-grade .list-box .item {
    display: block;
    padding: 60px 0;
    text-align: center;
    color: #fff;
    border-radius: 35px;
    overflow: hidden;
    transition: var(--transition);
}
.main-grade .list-box .item:hover {
    transform: translateY(-5px);
    box-shadow: 10px 10px 25px rgba(0,0,0,0.1);
}
.main-grade .list-box .item1 {background: linear-gradient(#00ed96, #00db64);}
.main-grade .list-box .item2 {background: linear-gradient(#0ed5f9, #00c4f8);}
.main-grade .list-box .item3 {background: linear-gradient(#4b7ef4, #4175eb);}
.main-grade .list-box .item4 {background: linear-gradient(#ffcd30, #f5c325);}
.main-grade .list-box .item5 {background: linear-gradient(#887ffa, #8178f1);}
.main-grade .list-box .img {
    margin-bottom: 30px;
}
.main-grade .list-box .img img {
    filter: drop-shadow(5px 5px 10px rgba(0,0,0,0.2));
}
.main-grade .list-box .item:hover .img {
    animation: nod 0.6s ease-in-out 2 alternate both;
}
@keyframes nod {
    0% {transform:rotate(0);}
    50% {transform:rotate(-5deg);}
    100% {transform:rotate(0);}
}
.main-grade .list-box .text {
    margin-bottom: 10px;
    font-size: 1.2em;
    font-weight: 300;
}
.main-grade .list-box .title {
    font-size: 2em;
    font-weight: 700;
    word-break: keep-all;
}
@media all and (max-width: 1299px) {
    .main-grade .list-box .item {
        padding: 50px 0;
    }
    .main-grade .list-box .img img {
        width: 140px;
    }
    .main-grade .list-box .text {
        font-size: var(--font-size-22);
    }
    .main-grade .list-box .title {
        font-size: 2.25em;
    }
}
@media all and (max-width: 1023px) {
    .main-grade .list-box {
        margin-top: 60px;
    }
    .main-grade .list-box li {
        flex: 0 0 calc((100% - 30px) / 2);
    }
    .main-grade .list-box .item {
        padding: 40px 0;
    }
    .main-grade .list-box .img img {
        width: 110px;
    }
    .main-grade .list-box .text {
        margin-bottom: 8px;
        font-size: var(--font-size-18);
    }
    .main-grade .list-box .title {
        font-size: var(--font-size-28);
    }
}
@media all and (max-width: 767px) {
    .main-grade .list-box {
        gap: 10px;
        margin-top: 40px;
    }
    .main-grade .list-box .item {
        padding: 20px 10px;
        height: 100%;
        border-radius: 25px;
    }
    .main-grade .list-box .img {
        margin-bottom: 10px;
    }
    .main-grade .list-box .img img {
        width: 65px;
    }
    .main-grade .list-box .text {
        display: none;
    }
    .main-grade .list-box .title {
        min-height: 47px;
        align-content: center;
        font-size: var(--font-size-18);
        font-weight: 600;
    }
}


.main-subject {
    position: relative;
    z-index: 1;
    background: var(--primary-color);
    overflow: hidden;
}
.main-subject::before {
    content: "";
    position: absolute;
    z-index: -1;
    left: 0;
    bottom: 60px;
    width: 386px;
    height: 269px;
    background: url("../img/main/subject-bg01.png") no-repeat center;
}
.main-subject::after {
    content: "";
    position: absolute;
    z-index: -1;
    top: 360px;
    right: -40px;
    width: 336px;
    height: 334px;
    background: url("../img/main/subject-bg02.png") no-repeat center;
}
.main-subject .container {
    position: relative;
}
.main-subject .main-title-box {
    color: #fff;
}
.main-subject-slide {
    margin-top: 150px;
}
.main-subject-slide .swiper {
    padding: 10px 0;
}
.main-subject-slide .item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0 10px;
    height: 226px;
    padding: 0 5% 0 10%;
    background: #fff;
    border-radius: 30px;
    overflow: hidden;
    transition: var(--transition);
}
.main-subject-slide .item:hover {
    transform: translateY(-10px);
}
.main-subject-slide .title {
    flex: 1 1 0;
    font-size: 2.25em;
    font-weight: 600;
    word-break: keep-all;
}
.main-subject-slide .img {
    flex: 0 0 38%;
}
.main-subject-slide .slide-control {
    position: absolute;
    top: 140px;
    right: 20px;
    display: flex;
    justify-content: space-between;
    gap: 0 22px;
}
.main-subject-slide :is(.swiper-button-prev, .swiper-button-next) {
    position: initial;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 156px;
    height: 68px;
    margin: 0;
    border-radius: 99px;
    border: 1px solid #fff;
    background: url("../img/main/slide-arrow.png") no-repeat center;
    transition: var(--transition);
}
.main-subject-slide .swiper-button-next {
    transform: rotate(180deg);
}
.main-subject-slide .swiper-button-prev::after,
.main-subject-slide .swiper-button-next::after {
    display: none;
}
@media all and (max-width: 1299px) {
    .main-subject-slide .title {
        font-size: 2em;
    }
}
@media all and (max-width: 1023px) {
    .main-subject-slide {
        margin-top: 100px;
    }
    .main-subject-slide .item {
        height: 180px;
    }
    .main-subject-slide .title {
        font-size: var(--font-size-26);
    }
    .main-subject-slide .slide-control {
        top: 100px;
        gap: 0 10px;
    }
    .main-subject-slide :is(.swiper-button-prev, .swiper-button-next) {
        width: 120px;
        height: 50px;
        background-size: 40px;
    }
}
@media all and (max-width: 767px) {
    .main-subject-slide {
        margin-top: 40px;
    }
    .main-subject-slide .item {
        height: 120px;
        border-radius: 20px;
    }
    .main-subject-slide .title {
        font-size: var(--font-size-20);
    }
    .main-subject-slide .img {
        max-width: 86px;
    }
    .main-subject-slide .slide-control {
        position: initial;
        justify-content: flex-end;
        gap: 0 5px;
    }
    .main-subject-slide :is(.swiper-button-prev, .swiper-button-next) {
        width: 80px;
        height: 38px;
        background-size: 26px;
        margin-bottom: 10px;
    }
}
.main-subject .list-box {
    display: flex;
    justify-content: center;
    gap: 0 40px;
    margin-top: 120px;
}
.main-subject .list-box li {
    flex: 1 1 0;
    height: 310px;
    padding: 45px 30px;
    background: #fff;
    border: 5px solid #fff;
    border-radius: 30px;
    text-align: center;
    overflow: hidden;
    transition: 1s ease-in-out;
}
.main-subject .list-box li .img {
    transition: 0.2s ease-in-out;
}
.main-subject .list-box li .title {
    margin-top: 30px;
    font-size: 2.125em;
    font-weight: 600;
    transition: 0.4s ease-in-out;
}
.main-subject .list-box li .lnk-box {
    margin-top: 20px;
    opacity: 0;
    visibility: hidden;
    transition: 0.4s ease-in-out;
}
.main-subject .list-box li .lnk {
    display: block;
    opacity: 1;
    padding: 5px;
    margin-bottom: 4px;
    border-radius: 8px;
    background: #eeeeee;
    font-size: var(--font-size-18);
}
.main-subject .list-box li:hover {
    border-color: #00d5ff;
}
.main-subject .list-box li:hover .img {
    opacity: 0;
}
.main-subject .list-box li:hover .title {
    transform: translateY(-170px);
}
.main-subject .list-box li:hover .lnk-box {
    opacity: 1;
    visibility: visible;
    transform: translateY(-165px);
    transition-delay: 0.1s;
}
.main-subject .list-box li .lnk:hover {
    background: #00d5ff;
}
@media all and (max-width: 1299px) {
    .main-subject .list-box {
        gap: 0 20px;
    }
    .main-subject .list-box li {
        height: 270px;
        padding: 40px 20px;
    }
    .main-subject .list-box li img {
        width: 130px;
    }
    .main-subject .list-box li .title {
        font-size: var(--font-size-26);
    }
    .main-subject .list-box li .lnk {
        font-size: var(--font-size-16);
    }
    .main-subject .list-box li:hover :is(.title, .lnk-box) {
        transform: translateY(-155px);
    }
}
@media all and (max-width: 1023px) {
    .main-subject .list-box {
        margin-top: 60px;
        flex-wrap: wrap;
        gap: 20px 3%;
    }
    .main-subject .list-box li {
        flex: 1 1 48.5%;
    }
}
@media all and (max-width: 767px) {
    .main-subject .list-box {
        margin-top: 40px;
        gap: 15px 3%;
    }
    .main-subject .list-box li {
        height: 240px;
        padding: 50px 10px;
        border-radius: 20px;
        border-width: 3px;
    }
    .main-subject .list-box li img {
        width: 100px;
    }
    .main-subject .list-box li .title {
        font-size: var(--font-size-22);
    }
    .main-subject .list-box li .lnk-box {
        margin-top: 15px;
    }
    .main-subject .list-box li .lnk {
        font-size: var(--font-size-14);
    }
    .main-subject .list-box li:hover :is(.title, .lnk-box) {
        transform: translateY(-145px);
    }
}


.main-type {
    background: url("../img/main/type-bg.png") no-repeat center;
}
.main-type .list-box {
    margin-top: 130px;
    display: flex;
    justify-content: center;
    gap: 0 40px;
}
.main-type .list-box .item {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    padding-top: 60px;
    font-size: 2.5em;
    text-align: center;
    overflow: hidden;
    transition: var(--transition);
}
.main-type .list-box .item1 {background-color: #497cf2;}
.main-type .list-box .item2 {background-color: #887ffa;}
.main-type .list-box .item3 {background-color: #00e683;}
.main-type .list-box .item4 {background-color: #0cd1f8;}
.main-type .list-box .item .text {
    font-weight: 700;
    color: #fff;
    transition: var(--transition);
}
.main-type .list-box .item:hover {
    border-radius: 30%;
    padding-top: 40px;
}
.main-type .list-box .item:hover .text {
    font-size: 1.125em;
}
@media all and (max-width: 1299px) {
    .main-type .list-box {
        gap: 0 20px;
    }
    .main-type .list-box .item {
        width: 230px;
        height: 230px;
        padding-top: 50px;
    }
    .main-type .list-box .item .img {
        width: 180px;
    }
}
@media all and (max-width: 1023px) {
    .main-type .list-box {
        margin-top: 80px;
        flex-wrap: wrap;
        gap: 20px 2%;
    }
    .main-type .list-box li {
        flex: 1 1 49%;
    }
    .main-type .list-box .item {
        width: 100%;
        height: 200px;
        padding-top: 40px;
        border-radius: 30px;
        font-size: 2em;
    }
    .main-type .list-box .item:hover {
        border-radius: 20px;
        padding-top: 20px;
    }
}
@media all and (max-width: 767px) {
    .main-type .list-box {
        margin-top: 40px;
        gap: 10px 2%;
    }
    .main-type .list-box .item {
        height: 150px;
        padding-top: 30px;
        font-size: var(--font-size-24);
    }
    .main-type .list-box .item .img {
        width: 120px;
    }
}


.main-map {
    padding-bottom: 250px;
    background: #91edff url("../img/main/map-bg.png") no-repeat bottom;
    overflow: hidden;
}
.main-map .container {
    position: relative;
}
.main-map .main-title-box {
    position: absolute;
    top: 0;
    left: 20px;
}
.main-map .map-box {
    --map-width: 760px;
    display: flex;
    justify-content: space-between;
    padding-top: 60px;
}
.main-map .map-box .tab {
    flex: 0 0 calc(100% - var(--map-width));
    margin-top: 230px;
}
.main-map .map-box .tab-list {
    position: relative;
}
.main-map .map-box .tab-item {
    flex: 0 0 auto;
    padding: 38px 0 0 50px;
}
.main-map .map-box .tab-item:has(.tab-btn.active) {
    display: none;
}
.main-map .map-box .tab-btn {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    width: 130px;
    height: 130px;
    font-weight: 700;
    border-radius: 50%;
    font-size: var(--font-size-22);
    border: 2px solid #3a6cdf;
    background: #4a7df3;
    color: #fff;
}
.main-map .map-box .tab-btn:hover {
    background: #3a6cdf;
}
.main-map .map-box .tab-btn .icon-custom {
    font-size: var(--font-size-22);
    margin-bottom: 8px;
}
.main-map .map-box .tab-img-box {
    aspect-ratio: 8/9;
    width: 320px;
    padding: 35px 30px;
    border-radius: 25px;
    background: rgba(255,255,255,0.5);
    transition: var(--transition);
}
.main-map .map-box .tab-img-box img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: var(--transition);
}
.main-map .map-box .tab-btn:hover ~ .tab-img-box img {
    filter: drop-shadow(5px 5px 10px rgba(0,0,0,0.025));
    transform: scale(1.05);
}
.main-map .map-box .map-cont {
    flex: 0 0 var(--map-width);
    text-align: center;
    position: relative;
}
.main-map .map-box .map-cont::before,
.main-map .map-box .map-cont::after {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.main-map .map-box .map-cont::before {
    background: url("../img/main/map-cont-bg01.png") no-repeat left top;
}
.main-map .map-box .map-cont::after {
    background: url("../img/main/map-cont-bg02.png") no-repeat right bottom;
}
.map-item {
    position: relative;
    margin: 0 auto;
}
.map-item.map-chuncheon {
    max-width: 740px;
}
.map-item.map-etc {
    max-width: 570px;
}
.map-item .map-img-box {
    position: relative;
}
.map-item .map-img-box .map-img {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
}
.map-item .map-img-box .map-img.active {
    opacity: 1;
    visibility: visible;
}
.map-item .map-img-box .map-initial {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}
.map-item .map-lnk-box {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.map-item .map-lnk-box .map-lnk {
    position: absolute;
    top: var(--custom-top);
    left: var(--custom-left);
    width: var(--custom-width);
    height: var(--custom-height);
}
/* ## 지도 - 춘천 ## */
.lnk-sabuk {--custom-top: 2%; --custom-left: 7%; --custom-width: 48%; --custom-height: 30%;}
.lnk-sinbuk {--custom-top: 24%; --custom-left: 33%; --custom-width: 25%; --custom-height: 18%;}
.lnk-buksan {--custom-top: 10%; --custom-left: 55%; --custom-width: 42%; --custom-height: 44%;}
.lnk-seo  {--custom-top: 31%; --custom-left: 10%; --custom-width: 27%; --custom-height: 35%;}
.lnk-dong {--custom-top: 41%; --custom-left: 46%; --custom-width: 39%; --custom-height: 22%;}
.lnk-dongnae {--custom-top: 55%; --custom-left: 46%; --custom-width: 16%; --custom-height: 13%;}
.lnk-namsan  {--custom-top: 60%; --custom-left: 6%; --custom-width: 38%; --custom-height: 34%;}
.lnk-sindong {--custom-top: 60%; --custom-left: 31%; --custom-width: 16%; --custom-height: 18%;}
.lnk-dongsan {--custom-top: 68%; --custom-left: 42%; --custom-width: 24%; --custom-height: 18%;}
.lnk-nam {--custom-top: 77%; --custom-left: 3%; --custom-width: 29%; --custom-height: 21%;}
/* ## 지도 - 그 외 ## */
.lnk-sinsau  {--custom-top: 2%; --custom-left: 38%; --custom-width: 36%; --custom-height: 45%;}
.lnk-geunhwa {--custom-top: 34%; --custom-left: 6%; --custom-width: 46%; --custom-height: 33%;}
.lnk-gangnam {--custom-top: 64%; --custom-left: 2%; --custom-width: 45%; --custom-height: 35%;}
.lnk-toegye {--custom-top: 69%; --custom-left: 44%; --custom-width: 26%; --custom-height: 24%;}
.lnk-seoksa {--custom-top: 67%; --custom-left: 63%; --custom-width: 34%; --custom-height: 26%;}
.lnk-soyang {--custom-top: 46%; --custom-left: 45%; --custom-width: 17%; --custom-height: 19%;}
.lnk-hupyeong1 {--custom-top: 46%; --custom-left: 61%; --custom-width: 21%; --custom-height: 14%;}
.lnk-hyoja2    {--custom-top: 62%; --custom-left: 56%; --custom-width: 23%; --custom-height: 11%;}
.lnk-hyoja3    {--custom-top: 58%; --custom-left: 69%; --custom-width: 6%; --custom-height: 13%; transform: rotate(312deg);}
.lnk-hupyeong2 {--custom-top: 57%; --custom-left: 73%; --custom-width: 6%; --custom-height: 12%; transform: rotate(320deg);}
.lnk-hupyeong3 {--custom-top: 55%; --custom-left: 79%; --custom-width: 9%; --custom-height: 13%; transform: rotate(332deg);}
.lnk-hyoja1 {--custom-top: 62%; --custom-left: 51%; --custom-width: 11%; --custom-height: 8%;}
.lnk-gyo   {--custom-top: 54%; --custom-left: 58%; --custom-width: 9%; --custom-height: 7%;}
.lnk-joun  {--custom-top: 57%; --custom-left: 53%; --custom-width: 9%; --custom-height: 7%;}
.lnk-yaksa {--custom-top: 62%; --custom-left: 47%; --custom-width: 8%; --custom-height: 6%;}
@media all and (max-width: 1299px) {
    .main-map {
        padding-bottom: 200px;
        background-size: 1300px;
    }
    .main-map .map-box {
        --map-width: 650px;
        padding-top: 120px;
    }
    .main-map .map-box .tab {
        margin-top: 120px;
    }
    .main-map .map-box .tab-btn {
        width: 110px;
        height: 110px;
        font-size: var(--font-size-20);
    }
    .main-map .map-box .tab-img-box {
        width: 260px;
        padding: 25px 20px;
    }
}
@media all and (max-width: 1023px) {
    .main-map .map-box {
        --map-width: 540px;
        padding-top: 150px;
    }
    .main-map .map-box .tab-item {
        padding: 30px 0 0 35px;
    }
    .main-map .map-box .tab-btn {
        width: 95px;
        height: 95px;
        font-size: var(--font-size-16);
    }
    .main-map .map-box .tab-img-box {
        width: 180px;
        padding: 10px;
        border-radius: 15px;
    }
}
@media all and (max-width: 767px) {
    .main-map {
        padding-bottom: 100px;
        background-size: 800px;
    }
    .main-map .map-box {
        display: block;
        padding-top: 130px;
    }
    .main-map .map-box .tab {
        margin-top: 0;
    }
    .main-map .map-box .tab-box {
        margin-bottom: 0;
    }
    .main-map .map-box .tab-item {
        padding: 0;
    }
    .main-map .map-box .tab-btn {
        position: initial;
        width: 78px;
        height: 78px;
        font-size: var(--font-size-14);
        white-space: nowrap;
    }
    .main-map .map-box .tab-btn .icon-custom {
        font-size: var(--font-size-18);
        margin-bottom: 5px;
    }
    .main-map .map-box .tab-img-box {
        display: none;
    }
    .main-map .map-box .map-cont::before,
    .main-map .map-box .map-cont::after {
        background-size: 220px;
    }
}



body:has(.main-wrapper) .footer {
    background: #fff;
}


/* ## popup ## */
.pop-up {
    position: absolute;
    z-index: 9980;
    background: #fff;
    box-shadow: 2px 2px 10px rgba(0,0,0,0.25);
    width: 500px;
    left: 40px;
    top:100px;
}
.pop-up .pop-up-body {
    width: 100%;
    height: 100%;
    cursor: pointer;
}
.pop-up .pop-up-body img {
    width: 100%;
    height: 100%;
}
.pop-up .pop-up-footer {
    width: 100%;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-left: 12px;
    background: #555;
    color: #fff;
    font-weight: 300;
    font-size: var(--font-size-14);
    box-shadow: 2px 2px 10px rgba(0,0,0,0.25);
}
.pop-up .pop-up-close {
    background: #333;
    padding: 0 12px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0 6px;
    color: #fff;
    font-weight: 400;
    border-radius: 0;
    font-size: var(--font-size-16);
}
.pop-up .pop-up-close::before {
    display: block;
    content:"\f00d";
    font-family: "Font Awesome 6 Pro";
    font-weight: 400;
    font-size: var(--font-size-20);
}
.pop-up.pop_window {
    width: 100% !important;
    height: auto !important;
    left: 0 !important;
    margin-left: 0;
    top: 0 !important;
}
.pop-up .checkbox {
    --checkbox-size: 17px;
}
@media all and (max-width:767px) {
    .pop-up {
        width: 90% !important;
        height: auto !important;
        left: 50% !important;
        transform: translateX(-50%);
    }
    .pop-up .pop-up-footer {
        height: 34px;
    }
}


/* ## quick ## */
.quick-menu {
    position: fixed;
    z-index: 20;
    bottom: 100px;
    right: 60px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: var(--transition);
}
.quick-menu .lnk img {
    transition: var(--transition);
}
.quick-menu .lnk:hover img {
    animation: scale 0.6s ease-in-out 1 alternate both;
}
@keyframes scale {
    0% {transform: scale(1);}
    50% {transform: scale(1.05);}
    100% {transform: scale(1);}
}
.quick-menu .btn-top {
    margin: 15px 20px 0 0;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid #eee;
    font-size: var(--font-size-14);
    box-shadow: 0 0 5px rgba(0,0,0,0.2);
    transform: translateY(10px);
    transition: var(--transition);
    transition-delay: 0.1s;
}
.quick-menu.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.quick-menu.active .btn-top {
    transform: translateY(0);
}
@media all and (max-width: 1299px) {
    .quick-menu {
        bottom: 60px;
        right: 30px;
    }
    .quick-menu .lnk img {
        width: 150px;
    }
}
@media all and (max-width: 1023px) {
    .quick-menu {
        bottom: 40px;
        right: 20px;
    }
    .quick-menu .lnk img {
        width: 130px;
    }
    .quick-menu .btn-top {
        margin: 10px 15px 0 0;
    }
}
@media all and (max-width: 767px) {
    .quick-menu {
        bottom: 20px;
        right: 10px;
    }
    .quick-menu .lnk img {
        width: 100px;
    }
    .quick-menu .btn-top {
        margin: 6px 10px 0 0;
        width: 40px;
        height: 40px;
    }
}



.modal-ebook .modal-header {
    z-index: 1;
}
.modal-ebook .modal-title {
    line-height: 1;
    background: url("../img/main/ebook-title-img.png") no-repeat left center / 36px;
    padding-left: 50px;
}
.modal-ebook .modal-title .strong {
    margin-left: 5px;
    font-weight: 600;
    font-size: var(--font-size-20);
    color: var(--primary-color);
}
.modal-ebook .modal-body {
    padding: 70px 40px;
    background: #d2ceff url("../img/main/ebook-bg01.png") no-repeat center top / cover;
}
.modal-ebook .modal-close {
    top: 12px;
    z-index: 1;
}
@media all and (max-width: 1199px) {
    .modal-ebook .modal-body {
        background-size: contain;
    }
}
@media all and (max-width: 768px) {
    .modal-ebook .modal-body {
        padding: 50px 20px;
    }
    .modal-ebook .modal-title {
        background-size:  contain;
        padding-left: 40px;
    }
    .modal-ebook .modal-title .strong {
        font-size: var(--font-size-18);
    }
}

.ebook-wrap {
    max-width: 1480px;
    margin: 0 auto;
}
.ebook-list {
    position: relative;
    margin-bottom: 90px;
    display: flex;
    align-items: flex-end;
    gap: 0 8%;
}
.ebook-list:last-child {
    margin-bottom: 0;
}
.ebook-list::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 8px;
    background: #fff;
    box-shadow: 0 3px 5px rgba(0,0,0,0.2);
}
.ebook-list li {
    text-align: center;
}
.ebook-list .desc {
    color: #454545;
}
.ebook-list .title {
    margin-bottom: 10px;
    font-weight: 600;
    font-size: 1.2em;
}
.ebook-list .lnk {
    display: block;
    min-width: 200px;
    box-shadow: 0 3px 16px rgba(0,0,0,0.2);
    border-radius: 7px;
    overflow: hidden;
    position: relative;
}
.ebook-list .lnk::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.65) url("../img/main/ebook-lnk-img.png") no-repeat center;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
}
.ebook-list .lnk:hover::after {
    opacity: 1;
    visibility: visible;
}
.ebook-list1 {
    padding-left: 25%;
    padding-right: 10%;
    background: url("../img/main/ebook-bg02.png") no-repeat left 10px bottom;
}
.ebook-list1 li:nth-child(3) {
    margin: 0 90px 0 80px;
}
.ebook-list2 {
    padding-right: 20%;
    background: url("../img/main/ebook-bg03.png") no-repeat right 10px bottom / contain;
}
.ebook-list2 li:nth-child(1) {
    margin-left: 5%;
}
@media all and (max-width: 1199px) {
    .ebook-list {
        gap: 0 6%;
    }
    .ebook-list li {
        margin: 0 !important;
    }
    .ebook-list1 {
        background-size: 140px;
    }
    .ebook-list2 {
        background-size: 160px;
    }
}
@media all and (max-width: 1023px) {
    .ebook-list {
        padding: 0 !important;
        gap: 0 30px;
        justify-content: center;
        background: none;
    }
    .ebook-list .lnk {
        min-width: 180px;
    }
}
@media all and (max-width: 768px) {
    .ebook-list {
        gap: 0 15px;
        margin-bottom: 40px;
        justify-content: flex-start;
        overflow-x: auto;
    }
    .ebook-list::after {
        display: none;
    }
    .ebook-list .desc {
        display: none;
    }
    .ebook-list .title {
        font-size: var(--font-size-16);
    }
    .ebook-list .lnk {
        min-width: 130px;
    }
    .ebook-list .lnk::after {
        background-size: 80px;
    }
}