@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Noto+Sans+KR:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100..900&display=swap');
#site {
    font-family: "Noto Sans KR", "Inter","Apple SD Neo Gothic", "Malgun Gothic", "Gulim", sans-serif;
    padding-top: 100px;
}
#site:has(#main_wrapper) {
    padding-top: 0px;
}
@media (max-width: 767px) {
    #site {
        padding-top: 66px;
    }
}

ol,
ul,
li {
    list-style: none;
    list-style-position: inside;
    margin: 0;
    padding: 0;
}

p,
.table {
    margin: 0;
}
a,
a:hover,
a:focus {
    text-decoration: none;
}

#site > .container:not(.agreement_container, .privacy_container, .mypage_container) {
    width: 100%;
    padding: 0;
}

:root {
    --page-point-color: #552f86;
}

/* ------------ 항목 삭제 ------------ */
.navbar .caret {
    display: none;
}
.clip {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    clip-path: polygon(0 0, 0 0, 0 0);
}

/* ------------ 상단 메뉴 ------------ */
.navbar.navbar-inverse > .container{width: auto;height: 10rem;max-width: 100%;padding: 0 5rem;display: flex;align-items: center;justify-content: space-between;flex-wrap: wrap;}
.navbar.navbar-inverse > .container:before, .navbar.navbar-inverse > .container:after {display: none;}
.menu_img img{height: 35px;}
.navbar.navbar-inverse {
    background-color: #fff;
    border-bottom: 0;
    box-shadow: 0px 1px 7px rgba(0, 0, 0, 0.08);
}
.navbar-header .navbar-brand {
    display: block;
    padding: 0;
    font-size: 20px;
    margin-left: 0 !important;
    height: auto;
    width: 100%;
}
.navbar-header .navbar-brand img {
    display: inline-block;
    vertical-align: bottom;
    height: 44px;
}
html:not(.logined) .navbar-nav > #gnbauth{ display: none;}
.nav.navbar-nav > li > a {
    display: block;
    height: 100%;
    padding: 4rem 4rem 4rem;
    font-size: 2rem;
    color: #000;
    font-weight: 600;
}
.nav.navbar-nav > li:hover > a,
.nav.navbar-nav > li.open > a,
.nav.navbar-nav > li:focus > a,
.nav.navbar-nav > li > a:focus {
    color: #072797 !important;
    background: none !important;
}
.nav.navbar-nav li .dropdown-menu {
    transform: translate(-50%, 0);
    left: 50%;
    right: 0;
    width: 100%;
    text-align: center;
    border-radius: 0;
    border: 0;
    padding: 0;
    overflow: hidden;
    transition: all 0.3s ease;
    height: 0;
    box-shadow: none;
    min-width: auto;
    background: none;
    padding-top: 18px;
}
.navbar-inverse .navbar-nav .dropdown .dropdown-menu,
.navbar-inverse .gnb {
    display: block !important;
}
.nav.navbar-nav li .dropdown-menu li a {
    padding-top: 6px;
    padding-bottom: 6px;
    font-weight: 500;
    color: #666;
}
.dropdown-menu > li > a:focus, .dropdown-menu > li > a:hover {
    background: none !important;
}
.nav.navbar-nav li .dropdown-menu li:hover a {
    color: #072797 !important;
    background: none !important;
    font-weight: 600;
}
.navbar.navbar-inverse .gnb {
    transition: all 0.3s ease;
    height: 0;
    background: #fafafa;
    border-top: 1px solid #eee;
}
@media (min-width: 1400px) {
    .container {
        width: 1200px;
    }
}
@media (max-width: 767px) {
    .menu_img {
        position: absolute;
        top: 23px;
        right: 60px;
    }
    .menu_img img {
        height: 20px;
    }
    .navbar.navbar-inverse > .container{
        display: block;
        padding: 0 15px;
        height: 100%;
    }
    .navbar-inverse .navbar-brand {
        padding: 5px 15px;
        margin: 8px 0;
        width: inherit;
    }
    .navbar-inverse .navbar-brand img {
        width: 70px;
        margin-top: 5px;
        height: 100%;
    }
    .navbar-inverse .navbar-nav > li > a {
        padding: 15px;
    }
    .navbar-inverse .navbar-nav > li > a,
    .navbar-inverse .navbar-nav > li > a:focus {
        font-size: 17px;
    }
    .navbar-inverse .navbar-nav > li > a::before {
        content: none;
    }
    .navbar-inverse .navbar-nav .dropdown .dropdown-menu {
        transform: translate(0, 0);
        padding: 0;
    }
    .navbar-inverse .navbar-nav .dropdown .dropdown-menu,
    .navbar-inverse .gnb {
        display: none !important;
    }
    .navbar-inverse .navbar-nav .dropdown.open .dropdown-menu {
        display: block !important;
        height: 100% !important;
        text-align: left;
        background: rgb(245, 245, 245);
        border-radius: 0;
    }

    .navbar-inverse .navbar-toggle {
        border: 0;
        padding: 18px 0;
    }
    .navbar-inverse .navbar-toggle .icon-bar {
        background-color: #333;
        transition: ease-in-out 0.15s all;
        opacity: 1;
        position: relative;
    }
    .navbar-inverse .navbar-toggle:hover,
    .navbar-inverse .navbar-toggle:focus {
        background: transparent;
    }
    .navbar-inverse .navbar-toggle:hover .icon-bar,
    .navbar-inverse .navbar-toggle:focus .icon-bar {
        background-color: #000;
    }
    .navbar-inverse .navbar-collapse,
    .navbar-inverse .navbar-form {
        border-color: transparent;
        overflow-x: hidden;
    }

    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(1) {
        transform: rotate(45deg);
        top: 6px;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(2) {
        opacity: 0;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(3) {
        transform: rotate(-45deg);
        top: -6px;
    }
}

@media (min-width: 768px) {
    .navbar-inverse .navbar-nav .dropdown-menu > li > a {
        padding: 12px 15px;
        text-align: center;
        font-size: 16px;
        color: #fff;
        border-bottom: 1px solid rgba(255, 255, 255, 0.11);
    }
}

/* ------------  슬라이드 ------------  */
.carousel-control.left,
.carousel-control.right {
    background-image: none;
}

.carousel-control.left .glyphicon::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: rotate(225deg);
}
.carousel-control.right .glyphicon::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
}
#mainCarousel .carousel-inner .item {
    height: 100vh;
    height: calc(100vh - 232px);
}
#mainCarousel .carousel-inner .item::before {
    content: "";
    width: 100%;
    height: 100%;
    background: #000;
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0.35;
}
.carousel-indicators {
    margin: 0;
    max-width: 100%;
    transform: translateX(-50%);
}
.carousel-indicators li {
    width: 60px;
    height: 5px;
    background-color: #fff;
    opacity: 0.3;
    margin: 0 7px 0 0;
    border-radius: 10px;
    transition: ease-in-out 0.15s all;
}
.carousel-indicators li.active {
    width: 60px;
    height: 5px;
    margin: 0 7px 0 0;
    opacity: 1;
}

.carousel-caption {
    color: #fff;
    text-shadow: none;
    text-align: left;
    top: 49%;
    bottom: inherit;
    transform: translateY(-50%);
}
.carousel-caption h1 {
    font-size: 80px;
    font-weight: 600;
    margin: 0px;
    margin-bottom: 20px;
}
.carousel-caption p {
    font-size: 30px;
    font-weight: 400;
    letter-spacing: 0;
}
.carousel-caption a {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    margin-top: 70px;
    padding: 10px 0;
    border: 1px solid rgba(255, 255, 255, 0.8);
    color: #fff;
    width: 170px;
    font-size: 16px;
    background: rgba(255, 255, 255, 0.08);
    font-weight: 500;
    text-shadow: none;
    z-index: 1;
    transition: border 0.4s;
    position: relative;
    overflow: hidden;
    text-decoration: none;
}
.carousel-caption a:hover {
    border: 1px solid var(--page-point-color);
}
.carousel-caption a::before {
    background: var(--page-point-color);
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    transition: all 0.5s ease;
    width: 100%;
    height: 0%;
    transform: translate(-50%, -50%) rotate(45deg);
}
.carousel-caption a:hover::before {
    height: 380%;
}

@media (max-width: 767px) {
    #mainCarousel .carousel-inner .item {
        height: 470px;
    }
    .carousel-caption {
        right: 20%;
        left: 20%;
        padding-bottom: 30px;
    }
    .carousel-caption h1 {
        font-size: 44px;
        line-height: 50px;
    }
    #mainCarousel .carousel-caption p {
        font-size: 16px;
    }
    .carousel-control {
        font-size: 14px;
    }
    .carousel-indicators li,
    .carousel-indicators li.active {
        width: 8px;
        height: 8px;
    }
    .carousel-indicators {
        bottom: 30px;
    }
}

/* ------------ footer ------------ */
#site footer {
    margin-top: 0px;
    color: #ccc;
}
#site footer .footer-link {
    background: #333333;
    margin: 0 0 30px;
    border-bottom: 1px solid #444;
}
#site footer .footer-link ul li {
    position: relative;
}

#site footer .footer-link ul li + li:before {
    content: '';
    display: block;
    width: 1px;
    height: 13px;
    background: #555;
    position: absolute;
    left: -16px;
    top: 5px;
}
#site footer .footer-link ul{display: flex;margin: 15px 0;}
#site footer .footer-link ul li a{
    color: #aaa;
    margin-right: 16px;
    padding-right: 16px;
    font-size: 14px;
}
#site footer .footer-link ul li:last-child a{border: 0;margin: 0;padding: 0;}
#site footer .footer-inner {
    padding: 40px 0;
    background: #333;
}
.footer-link {
    background: #f8f8f8;
    margin: 0 0 40px;
}
#site footer .footer-info ul {
    position: relative;
    margin: 0;
    padding: 0;
}
#site footer .footer-info ul li:first-child {
    color: #ccc;
    margin-bottom: 3px;
}
#site footer .footer-info ul li {
    list-style: none;
    display: inline-block;
    font-size: 15px;
    margin-right: 15px;
    line-height: 21px;
}
#site footer .footer-info .logo > img {
    opacity: 0.5;
    margin: auto;
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
    padding-right: 50px;
}
#site footer .footer-info .info {
    flex-direction: column;
    padding: 0 15px;
}
#site footer .footer-info ul .copy {
    font-size: 12px;
    color: #777;
    letter-spacing: 0;
    margin-top: 7px;
}
#site footer .footer-info ul .login-g {
    float: right;
}
#site footer .footer-info ul .login-g a {
    color: #fff;
    opacity: 0.4;
    border: 1px solid #aaa;
    padding: 5px 15px;
    font-weight: 300;
    text-decoration: none;
    font-size: 12px;
    transition: opacity 0.2s ease;
}
#site footer .footer-info ul .login-g:hover a {
    opacity: 0.9;
}
#scrolltop{
    position:fixed;
    z-index: 1000;
    right:50px;
    bottom:50px;
    font-size: 15px;
    text-align:center;
    width: 68px;
    height: 68px;
    color:#fff;
    background:linear-gradient(to right,  #7a2b9a 25%,#24356b 100%);
    border-radius: 50%;
    box-shadow:0 0 10px rgba(0,0,0,0.2);
    cursor: pointer;
    font-weight: 700;
}
#scrolltop .inner{
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    line-height:1;
    letter-spacing: 0.02em;
}
#scrolltop .inner i{
    font-size: 20px;
}
@media (max-width: 767px) {
    #site footer .footer-info ul li,
    #site footer .footer-info ul li:first-child {
        font-size: 13px;
    }
    #site footer .footer-info .logo > img {
        width: 40%;
        margin: 0 0 20px;
    }
}

/* ------------ sub 헤더 ------------ */
.sub_header {
    height: 340px;
    position: relative;
    color: #fff;
    text-align: center;
    background: #333 url("/public/img/sub/sub_header.jpg") no-repeat bottom center;
    background-size: cover;
}
.sub_header::before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.4);
}
.sub_header h2 {
    font-size: 50px;
    line-height: 1;
    margin-top: 0;
    text-align: center;
    font-weight: 600;
    color: #fff;
    letter-spacing: 1px;
}
.sub_header .container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
@media (max-width: 767px) {
    .sub_header {
        height: 150px;
    }
    .sub_header h2 {
        font-size: 30px;
        margin: 0;
        line-height: 1.2;
    }
}

/* ------------ 서브 메뉴 ------------ */
.sub_menu {
    position: relative;
    z-index: 10;
    border-bottom: 1px solid #eee;
    background: transparent;
    margin-top: -58px;
}
.sub_menu ul {
    display: flex;
    justify-content: center;
}
.sub_menu ul > li {
    flex: 1;
    text-align: center;
}
.sub_menu ul > li > a {
    padding: 4px 0;
    font-size: 17px;
    font-weight: 600;
    color: #888;
    letter-spacing: 0;
    line-height: 50px;
    text-decoration: none;
    background: #f4f4f4;
    transition: 0.3s;
}
.sub_menu ul > li:last-child > a {
    background: #f9f9f9;
}
.sub_menu ul > li > a::before {
    content: "";
    display: block;
    position: absolute;
    width: 0px;
    height: 0px;
    border-bottom: 8px solid #60198a;
    border-left: 10px solid #fff;
    border-right: 10px solid #fff;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%) rotate(180deg);
    opacity: 0;
    transition: 0.3s;
}
.sub_menu ul > li.active > a::before, .sub_menu ul > li > a:hover::before {
    opacity: 1;
    border-bottom: 8px solid #433284;
}
.sub_menu .nav li.active a, .sub_menu .nav li a:hover {
    background-color: #60198a;
    color: #fff;
    background: linear-gradient(135deg, #732c9a 0%, #463185 50%, #25356c 100%);
}
.sub_menu .nav li:hover a {
    background-color: #4c1f8c;
    color: #fff;
}

@media (max-width: 767px) {
    .sub_menu {
        border-bottom: 0px;
        margin-top: 15px;
    }
    .sub_menu ul {
        flex-wrap: wrap;
        gap: 0;
    }
    .sub_menu ul > li {
        flex: 1 1 48%;
        padding: 3px;
    }
    .sub_menu ul > li::after,
    .sub_menu ul > li > a::after {
        content: none;
    }
    .sub_menu ul > li > a {
        height: 42px;
        padding: 10px 15px;
        font-size: 14px;
        line-height: inherit;
        transition: all 0.2s;
        border: 1px solid #ddd;
    }
    .sub_menu .nav li.active a,
    .sub_menu .nav li:hover a {
        background-color: var(--page-point-color) !important;
        color: #fff;
        border: 1px solid var(--page-point-color);
    }
}

/* ------------ main ------------  */
#se01 .inner {
    display: flex;
    gap: 90px;
    height: 400px;
    padding: 70px 0;
}
#se01 .left {
    flex: 1;
}

#se01 .right {
    flex: 1;
    display: flex;
    gap: 40px;
}
#se01 .right a {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border: 2px solid transparent;
    text-align: center;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
    transition: all 0.4s cubic-bezier(0.1, 0, 0.3, 1);
    color: #333;
}
#se01 .right a:hover {
    border: 2px solid var(--page-point-color);
    color: var(--page-point-color);
    transform: translateY(-10px);
}
#se01 .right a p {
    font-size: 22px;
    font-weight: 700;
}
#se01 .right a span {
    font-size: 50px;
    margin-top: 30px;
    font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;
}

/* ------------ 공통 ------------  */
.content {
    padding: 100px 0 110px;
}
.content + .content {
    padding-top: 50px;
}
.content:last-child {
    padding-bottom: 130px;
}
.content_box {
    padding: 30px 0 50px;
}
.content_box + .content_box {
    padding-top: 0px;
}
.content_box:last-child {
    padding-bottom: 0;
}
.page_tit {
    position: relative;
    margin: 90px 0 0;
    text-align: center;
}
.page_tit h3 {
    margin: 0 0 0;
    font-size: 42px;
    font-weight: 600;
    color: #111;
    letter-spacing: -0.025em;
}
.sub_tit {
    position: relative;
}
.sub_tit h4 {
    font-size: 26px;
    font-weight: 600;
    margin-top: 0;
    margin-bottom: 30px;
    padding-left: 20px;
}
.sub_tit::before {
    content: "";
    width: 3px;
    height: 20px;
    background-color: var(--page-point-color);
    left: 0;
    position: absolute;
    top: 6px;
}
.content_box h5 {
    padding-left: 12px;
    line-height: 1.5em;
    position: relative;
    font-size: 20px;
    font-weight: 600;
    color: var(--page-point-color);
    margin-top: 0;
}
.content_box h5::before {
    content: "";
    top: 13px;
    left: 1px;
    width: 5px;
    height: 5px;
    position: absolute;
    background: var(--page-point-color);
    border-radius: 50%;
}
.list-dot > li {
    padding-left: 12px;
    font-size: 16px;
    line-height: 1.5em;
    position: relative;
}
.list-dot > li::before {
    content: "";
    top: 10px;
    left: 1px;
    width: 5px;
    height: 5px;
    position: absolute;
    background: #777;
    border-radius: 50%;
}
.list-dash > li {
    padding-left: 12px;
    font-size: 16px;
    line-height: 1.5em;
    position: relative;
}
.list-dash > li::before {
    content: "";
    top: 10px;
    left: 1px;
    width: 5px;
    height: 2px;
    position: absolute;
    background: #777;
    border-radius: 20px;
}
.list-num,
.list-num-basic {
    counter-reset: number 0;
}
.list-num > li,
.list-num-basic > li {
    padding-left: 32px;
    font-size: 18px;
    line-height: 2em;
    position: relative;
    list-style: none;
}
.list-num > li::before {
    counter-increment: number 1;
    content: counter(number);
    top: 3px;
    left: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    background: var(--page-point-color);
    color: #fff;
    border-radius: 50%;
    width: 25px;
    height: 25px;
}
.list-num-basic > li::before {
    counter-increment: number 1;
    content: counter(number) ".";
    top: 7px;
    left: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    color: #333;
    width: 20px;
    height: 20px;
}
.box-area {
    margin-bottom: 80px;
}
.img_area .business_img_area {
    margin-top: 50px;
}
/* login */
.member_wrapper {
    padding-top: 100px;
    padding-bottom: 200px;
}
.member_wrapper h1 {
    margin-top: 0;
    border-bottom: 0;
}
.privacy_body {
    font-size: 15px;
}

/* board, form */
.btn.btn-primary {
    background-color: var(--page-point-color);
    border: 1px solid var(--page-point-color);
}
.btn.btn-primary:hover,
.btn.btn-primary:focus {
    background-color: var(--page-point-color);
}
input + #list_btn {
    display: none;
}
.board_wrapper{margin-top: 0;}
.table.table_default thead th {
    background: #fff;
    font-size: 16px;
}
.table.table_default tbody .subject a {
    font-size: 17px;
}
@media (max-width: 767px) {
    .page_tit h3 {
        font-size: 32px;
    }
    .content {
        padding: 80px 0 90px;
    }
    .content:last-child {
        padding-bottom: 110px;
    }
    .board_wrapper .table colgroup,
    .board_wrapper .table tr .num,
    .board_wrapper .table tr .hits {
        display: none;
    }
    .board_wrapper .table.table_default tr th,
    .board_wrapper .table.table_default tr td {
        padding: 10px;
        font-size: 12px;
    }
    .board_wrapper .table.board_write_table :where(.input-group, .form-control) {
        width: 100%;
    }
    .table.table_default tbody .subject a {
        font-size: 13px;
    }
    .board_wrapper .table .subject {
        width: 45%;
    }
    .board_write_table #captcha {
        margin-bottom: 10px;
        height: inherit;
    }

    .member_wrapper {
        padding-top: 100px;
        padding-bottom: 200px;
    }
    .member_wrapper .login_extra ul {
        display: flex;
        flex-direction: column;
        gap: 7px;
    }
    .member_wrapper .login_extra ul li + li::before {
        content: none;
    }
}

/* ------------ main ------------  */
#fp-nav.fp-right ul li:last-child {
    display: none;
}
.fp-warning,
.fp-watermark,
.fp-watermark a {
    display: none;
}
#fp-nav ul li a span,
.fp-slidesNav ul li a span {
    background: #888 !important;
}
#se01 {
    padding-top: 100px;
}
.main_page_tit {
    margin: 0 0 6rem;
}
.main_page_tit h3 {
    font-size: 5.4rem;
    color: #000;
    line-height: 1;
    margin: 0 0 3rem;
    font-weight: 700;
    letter-spacing: -0.035em;
}
.main_page_tit h3 small {
    display: block;
    margin-bottom: 15px;
    color: #000;
    font-size: 75%;
}
.main_page_tit h3 img {
    width: 180px;
    margin-top: 30px;
}
.main_page_tit h3 span {
    font-size: 1.9rem;
    font-weight: 450;
    color: #333;
    display: block;
    letter-spacing: -0.045em;
    margin-top: 30px;
    line-height: 1.7;
}

.list_logo {
    /* position: absolute;
    bottom: 0; */
    background: #fff;
    padding: 40px;
    display: flex;
    justify-content: center;
    width: 100%;
    gap: 20px;
    z-index: 1;
}
#se02 {
    background: #f2f2f2 url(/public/img/main/se02_bg2.jpg) no-repeat left bottom;
}
#se02 .main_page_tit {
    margin-bottom: 120px;
}
#se02 .main_page_tit h3::after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: #333;
    margin: 70px 0 0;
    display: none;
}
#se02 .main_page_tit h3 {
    margin-bottom: 0;
}
#se02 .main_page_tit h3 small {
    font-weight: 600;
    font-size: 34px;
}
.se02_content {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 80px;
    margin-top: 50px;
    position: relative;
}
.se02_content .txt_area {
}

.se02_content .txt_area p {
    font-size: 20px;
    word-break: keep-all;
    letter-spacing: -0.034em;
    line-height: 1.6em;
}
.se02_content .txt_area p strong {
    font-size: 25px;
    margin-right: 2px;
    font-weight: 900;
}
.se02_content .txt_area p + p {
    margin-top: 40px;
}
.se02_content .txt_area .img_area {
    margin-left: -100px;
    width: 110%;
}

.se02_content > .img_area {
    /* position: absolute; */
    /* right: -50px; */
    /* top: 10px; */
}
.full-program {
    background: url(/public/img/main/main03.jpg) no-repeat center / cover;
}
.se03_content {
    display: flex;
    gap: 50px;
}
.menu_nav {
    width: 30%;
}
.menu_nav .nav {
    display: flex;
    flex-direction: column;
}
.menu_nav .nav li {background: rgba(255, 255, 255, 0.35);}
.nav-pills > li + li {
    margin: 0;
    border-bottom: 1px solid #fff;
}
.menu_nav .nav li a {
    font-size: 16px;
    padding: 13px 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: #666666;
    transition: 0.5s;
    z-index: 2;
    letter-spacing: -0.025em;
}
.menu_nav .nav li.active a {
    background: transparent;
    color: #fff;
}
.menu_nav .nav li::before {
    content: "";
    top: 0;
    bottom: 0;
    left: 0;
    height: 100%;
    width: 0%;
    position: absolute;
    background: #643184;
    transition: 0.5s;
    z-index: 1;
}
.menu_nav .nav li:hover::before {
    width: 100%;
}
.menu_nav .nav li.active::before {
    width: 100%;
}
.menu_nav .nav li:hover a {
    color: #fff;
    background-color: transparent;
}
.se03_content .tab-pane .menu_items {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
}
.se03_content .tab-pane .menu_item img {
    border: 1px solid #ddd;
}
.se03_content .tab-pane .menu_item p {
    margin-top: 10px;
    font-size: 17px;
    font-weight: 500;
    text-align: center;
    letter-spacing: -0.034em;
}
#logo_slider .slick-arrow {
    padding: 0;
    background: transparent;
    border: 0;
    position: absolute;
    font-size: 21px;
    z-index: 1;
    transform: translateY(-50%);
    top: 50%;
    color: #000;
}
#logo_slider .slick-arrow::before{content: none;}
#logo_slider .slick-prev {
    right: -18px;
    left: inherit;
}
#logo_slider .slick-next {
    right: -42px;
}
.logo_slide_area {
    border-top: 1px solid #ddd;
}
.logo_slide_area .inner {
    padding: 15px 0;
    position: relative;
}
.logo_slide_area p {
    font-size: 17px;
    font-weight: 700;
    position: absolute;
    transform: translateY(-50%);
    top: 50%;
}
.logo_slide_items {
    margin-right: 50px;
    margin-left: 80px;
}
#se04,#se06 {
    background: url(/public/img/main/main04.jpg) no-repeat center / cover;
}
.notice01_area .board_box_blog{margin-bottom: 0 !important;}
.notice01_area .page-header{display: none;}
.notice01_area .table_blog{
    border-top: 0
    ;margin-bottom: 30px;
    display: flex;
    gap: 210px;
    margin-bottom: 0 !important;
}
.notice01_area .table_blog dd{
    display: flex;
    flex-direction: column;
    border-bottom: 0;
    /* width: calc((100% / 3) - 20px); */
    padding: 0;
}
.notice01_area .table_blog dd:hover{background-color: transparent;}
.notice01_area .table_blog .left{width: 250px;}
.notice01_area .table_blog .left span.thumb{width: 100%;height: 324px;}
.notice01_area .table_blog .right{width: 250px;margin-top: 20px;}
.notice01_area .table_blog .right .info{margin-bottom: 0;font-size: 15px;margin-top: 10px;}
.notice01_area .table_blog .right .text,
.notice01_area .table_blog .right .writer,
.notice01_area .table_blog .right .hits
{display: none;}

/* ------------ program01 ------------  */
.replay{    
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.replay_area {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #f4f4f4;
    padding: 40px 50px;
    border-radius: 10px;
}
.replay_area .play {
    display: flex;
    align-items: center;
    gap: 30px;
}
.replay_area .play i {
    background: #f00;
    color: #fff;
    width: 100px;
    height: 64px;
    font-size: 18px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    font-size: 27px;
}
.replay_area .play img{width: 100px;}
.replay_area .txt_area .tit {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 6px;
    letter-spacing: -0.034em;
}
.replay_area .txt_area p {
    font-size: 16px;
    letter-spacing: -0.025em;
}
.replay_area .link a i {
    margin-left: 30px;
}
.replay_area .link a {
    background: #333;
    color: #fff;
    padding: 15px 20px;
    width: 150px;
    display: block;
    font-size: 15px;
    line-height: 26px;
    font-weight: 500;
    transition: 0.3s;
    border: 1px solid #333;
}
.replay_area .link a:hover {
    background: transparent;
    border: 1px solid #333;
    color: #333;
    font-weight: 700;
}
.pro_con_items {
    display: grid;
    gap: 20px;
    margin-top: 50px;
    grid-template-columns: repeat(2, 1fr);
}
.pro_con_item .tit {
    text-align: center;
    margin-top: 15px;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.034em;
}
.pro_con_item .img_area {
    border: 1px solid #ddd;
    position: relative;
    cursor: pointer;
    padding: 25px;
}
.pro_con_item .img_area:hover .overlay_box {
    opacity: 1;
}
.color_bg01{background: #ffcdcd;}
.overlay_box {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: rgba(0, 0, 0, 0.75);
    transition: all 0.3s ease;
    z-index: 90;
    transition: 0.3s;
    opacity: 0;
}
.overlay_box p {
    color: #fff;
    transform: translate(-50%, -50%);
    position: absolute;
    text-align: center;
    width: 100%;
    left: 50%;
    top: 50%;
    font-size: 17px;
    line-height: 1.8;
}
.overlay_box p > span{
    font-weight: 500;
    display: inline-block;
    padding: 5px 63px;
    margin-top: 10px;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    color: #fff;
    background: #4d3081;
}

/* ------------ notice01 ------------  */
.table_blog dd {
    padding: 30px 20px;
}
.search_wrap {
    margin-bottom: 30px;
}
.table_blog .right .title a {
    font-size: 20px;
    font-weight: 500;
}
.table_blog .right .title {
    margin-top: 3px;
}
.table_blog .right .text p {
    font-size: 16px;
}
.board_data_view .header_wrap .title {
    font-size: 26px;
    font-weight: 600;
    letter-spacing: -0.034em;
}
.contents_inner p {
    font-size: 16px;
}
#notice01 #board_data_blog2 dd {
    width: 25%;
}
#notice01 #board_data_blog2 dd:has(.no_post) {
    width: 100%;
}
#notice01 .category_wrap{    display: none;}
#notice01 .top .thumb{
    width: 268px;
    height: 350px;
    background-size: cover;
    margin: 0 auto;
}

/* ------------ p_list01 ------------  */
.img_link{position: relative;}
.img_link .overlay_box{background: rgba(0, 0, 0, 0.65);cursor: pointer;}
.img_link .overlay_box p{font-size: 36px; font-weight: 600;}
.img_link:hover .overlay_box{opacity: 1;}

@media (max-width: 991px) {
    #notice01 .top .thumb {
        width: inherit;
        height: 200px;
    }
}
@media (max-width: 767px) {
    .list_logo {
        padding: 15px;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
    #se01 {padding-top: 66px;}
    .img_link .overlay_box p {font-size: 21px;}
    #se02 {
        background: #f2f2f2 url(/public/img/main/se02_bg2.jpg) no-repeat right bottom;
    }
    #se02 .main_page_tit h3 small {
        font-weight: 600;
        font-size: 24px;
    }
    .se02_content {
        margin-top: 0;
        padding: 100px 0;
        display: block;
    }
    .main_page_tit h3 img {
        width: 130px;
        margin-top: 20px;
    }
    .full-program,#se04 {
        padding: 100px 0;
    }
    .main_page_tit h3 {
        font-size: 2.8rem;
    }
    .main_page_tit h3 span {
        margin-top: 15px;
    }
    .se03_content {
        gap: 30px;
        flex-direction: column;
    }
    .menu_nav {
        width: 100%;
    }
    .se03_content .tab-pane .menu_items {
        grid-template-columns: repeat(2, 1fr);
    }
    .se03_content .tab-pane .menu_item p{font-size: 15px;}
    .main_page_tit h3 small {
        font-size: 70%;
    }
    .notice01_area .table_blog{
        flex-direction: column;
        gap: 30px;
    }
    .notice01_area .table_blog .right{margin-top: 0;}
    .logo_slide_area p {
        top: inherit;
        font-size: 16px;
        position: relative;
        transform: inherit;
        margin-bottom: 5px;
    }
    #logo_slider .slick-arrow{display: none !important;}
    .logo_slide_items{margin: 0;}

    #scrolltop {
        right: 20px;
        bottom: 20px;
        font-size: 10px;
        width: 48px;
        height: 48px;
    }
    #scrolltop .inner i {font-size: 15px;}

    .replay_area {
        padding: 30px 40px;
    }
    .replay_area,.replay_area .play{display: block;}
    .replay_area .play img{width: 80px;margin: 0;}
    .replay_area .txt_area .tit{font-size: 21px;margin-top: 20px;}
    .replay_area .link a{
        padding: 10px 15px;
        width: 140px;
        margin-top: 20px;
    }
    .replay_area .play i {
        width: 80px;
        height: 54px;
        font-size: 24px;
        border-radius: 15px;
    }
    .pro_con_item .tit{
        margin-top: 10px;
        font-size: 16px;
    }
    .overlay_box p {
        font-size: 15px;
        line-height: 1.5;
        padding: 0 15px;
    }

    .table_blog .left {
        padding: 0 0 20px;
    }
    .table_blog .left a {
        display: flex;
    }

    #notice01 #board_data_blog2 dd {
        width: 100%;
    }
    #notice01 .top .thumb{
        width: 268px;
        height: 350px;
    }
    .table_blog .right .title a {
        font-size: 18px;
    }
    .table_blog .right .text p {
        font-size: 16px;
    }
    .table_blog dd {
        padding: 30px 10px;
    }

    .notice01_area .table_blog dd{width: 100%;}
    .notice01_area .table_blog .left, .notice01_area .table_blog .right{    margin: 0 auto;}
    .notice01_area :is(.table_video, .table_blog, .table_blog2, .table_pd) a span.thumb + img.thumb{        height: 324px;;}
}
@media (max-width: 500px) {
    .pro_con_items {
        grid-template-columns: repeat(1, 1fr);
    }
}
