@charset "utf-8";
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css");

#site {
    font-family: "Pretendard Variable", 'notokr', sans-serif;
    padding-top: 101px;
}

.no-js {
    display: none;
}

* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    word-break: keep-all;
}

@media (min-width: 1280px) {
    .container {
        width: 1280px;
    }
}

a {
    text-decoration-line: none;
    color: #000;
    transition: all 0.1s ease;
}

a:hover {
    text-decoration-line: none !important;
}

.btn {
    border-radius: 3px;
    transition: all 0.2s ease;
}

li,
ul {
    list-style: none;
    margin: 0;
}

:is(ol, ul, li, dl) {
    all: unset;
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
}

:is(p, h1, h2, h3, h4, h5, h6, dt, dd) {
    all: unset;
    display: block;
}

:is(p, h1, h2, h3, h4, h5, h6, dt, dd, th, td, li) {
    position: relative;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    line-height: 1;
}

/* 불필요 항목 삭제 */
.navbar .caret {
    display: none;
}

dl::after {
    display: none;
}

.board_wrapper {
    margin-top: 0;
}

:root {
    --page-point-color: #0097d7;
    --input-height: 42px;
}

.navbar-inverse+.container {
    width: 100%;
    margin: 0;
    padding: 0;
}

.navbar-inverse+.agreement_container,
.navbar-inverse+.privacy_container {
    width: 1170px;
    margin: 0 auto;
    padding: 0 15px;
}

/* 상단 로고*/
.navbar-brand {
    height: 32px;
    padding: 0;
}

.navbar-brand>span {
    display: flex;
    align-items: center;
    font-size: 28px;
    color: #4e4f50;
    font-weight: 650;
    letter-spacing: -0.01em;
    position: relative;
}

.navbar-brand>span>span {
    position: relative;
    margin-left: 16px;
    padding-left: 16px;
}

.navbar-brand>span>span::before {
    content: '';
    width: 1px;
    height: 30px;
    background: #e0e0e0;
    display: block;
    position: absolute;
    left: 0;
    top: -4px;
}

.navbar-brand p {
    margin: 0;
    font-size: 20px;
    color: #000;
    font-weight: 600;
}

.navbar-brand p>span {
    display: block;
    font-size: 12px;
    margin-top: 5px;
    font-weight: 300;
}

.navbar-inverse .navbar-brand img {
    height: 31px;
}


/* 상단 메뉴 */
.navbar-inverse {
    background: #fff;
    position: fixed;
    margin-bottom: 0;
    padding: 0;
    transition: all 0.3s ease;
    border-bottom: 1px solid #eee;
}

.navbar-header {
    padding: 0;
    margin-top: 33px;
}

.navbar-inverse .navbar-nav {}

.navbar-inverse .navbar-nav .dropdown {}

.navbar-inverse .navbar-nav .dropdown i {
    line-height: 0;
}

.navbar-inverse .navbar-nav .dropdown .dropdown-menu {}

.navbar-inverse .navbar-nav .dropdown .dropdown-menu>li {}

.navbar-inverse .navbar-nav .dropdown .dropdown-menu>li>a {}

.navbar-inverse .navbar-nav>li>a {
    font-size: 19px;
    font-weight: 700;
    color: #333;
    padding: 40px 30px;
    transition: all 0.2s ease;
    letter-spacing: 0;
}


.navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle,
.navbar-inverse .navbar-nav>li>a:focus,
.navbar-inverse .navbar-nav>li>a:hover {
    color: var(--page-point-color);
}

.navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle {
    background: none;
}

/* 슬라이드*/
#main_wrapper #mainCarousel {
    /* max-width: 1800px; */
    /* margin: 0 auto; */
}

#mainCarousel .carousel-inner .item {
    height: 500px;
}

#mainCarousel .carousel-inner {
    position: relative;
}

#mainCarousel .carousel-inner .item::before {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.1);
}

/* 슬라이드 글자*/
.carousel-caption {
    top: 50%;
    text-shadow: none;
    padding: 0;
    text-align: left;
    left: 17%;
}

.carousel-caption h1 {
    position: relative;
    line-height: 1.3;
    color: #fff;
    font-weight: 700;
    font-size: 32px;
    margin: 0 0 30px;
    text-shadow: 4px 4px 20px rgb(0 69 103 / 30%);
}

.carousel-caption h1 span {
    display: block;
    font-size: 72px;
}

.carousel-caption p {
    margin-bottom: 0;
    font-size: 24px;
    font-weight: 500;
    text-shadow: 2px 2px 8px rgb(0 69 103 / 54%);
    letter-spacing: -0.015em;
}

/* 슬라이드 버튼 */
.carousel-control {
    text-shadow: 0 2px 6px rgba(0, 0, 0, .125);
    transition: ease 0.15s all;
    background: transparent !important;
}

.carousel-control.left .glyphicon::before {
    content: '\f053';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
}

.carousel-control.right .glyphicon::before {
    content: '\f054';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
}

.carousel-indicators {
    bottom: 40px;
}

.carousel-indicators li,
.carousel-indicators li.active {
    width: 10px;
    height: 10px;
    background-color: rgba(255, 255, 255, 0);
    border: 1px solid #fff;
    margin: 0 2px;
    border-radius: 0;
    transition: ease 0.15s all;
}

.carousel-indicators li.active {
    background-color: #fff;
    /* transform: rotate(45deg); */
}

/* 전체 공통 */
.btn-link {
    display: block;
    width: fit-content;
    margin: 0 auto;
    padding: 12px 25px;
    background: #2d3337;
    color: #fff;
    transition: all 0.2s ease;
    border-radius: 3px;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0;
}

.btn-link:hover {
    background: var(--page-point-color);
    border-color: var(--page-point-color);
    color: #fff;
}

/*메인페이지 공통*/
.main-page {}

.main-con {
    padding: 100px 0;
}

@media (min-width:1500px) {
    .main-con>.container {
        /* width: 1350px; */
    }
}

.main-con:first-child {}

.main-h3 {
    font-size: 38px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 60px;
    line-height: 1;
}

.main-h3::after {
    content: '';
    width: 50px;
    height: 3px;
    background: #333;
    display: block;
    margin: 25px auto 0;
}

.board-wrap {}

.board-wrap .bbs-area>div {
    margin-bottom: 0 !important;
    padding: 0;
}

.board-wrap .info .writer,
.board-wrap .info .hits {
    display: none;
}

/* 메인 페이지 학과뉴스*/
.main01-inner {
    display: grid;
    width: 100%;
}

#main01 .main01-inner {
    grid-template-columns: 0.7fr 0.3fr;
}

.bbs-area .contents_inner {
    overflow-y: hidden;
}

.board-wrap.news {
    display: flex;
    flex-direction: column;
    gap: 35px;
    grid-column: span 2;
    /* border-top: 1px solid #e3e3e3; */
    /* padding-top: 50px; */
}

.main-btn {}

.board-wrap.news .page-header {
    /* display: none; */
}

.board-wrap .bbs-area>div>dl {
    margin-bottom: 0 !important;
}

.board-wrap.semi .bbs-area>div>dl {
    display: flex;
    flex-direction: column;
    border-top: 1px solid #e3e3e3;
    margin-top: 40px;
}

.board-wrap.news .bbs-area>div>dl {
    display: grid;
    gap: 30px 30px;
    grid-template-columns: repeat(3, 1fr);
}

.board-wrap .bbs-area>div>dl>dd {
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 25px;
    border: 0;
}

.board-wrap .bbs-area>div>dl>dd::after {
    content: none;
}

.main-con .board-wrap.semi .bbs-area>div>dl>dd {
    /* flex-direction: row; */
    gap: 20px;
    display: grid;
    grid-template-columns: 90px 1fr;
}

.main-con .board-wrap.semi .bbs-area>div>dl>dd::after {
    display: none;
}

.main-con .board-wrap.semi .bbs-area>div>dl>dd+dd {
    border-top: 1px solid #e3e3e3;
    padding-top: 30px;
    margin-top: 30px;
}

.main-con .semina .semi .table_blog .right .subject {
    font-size: 16px;
    font-weight: 600;
}

.main-con .semina .semi .table_blog .right .text p {
    font-size: 14px;
    line-height: 1.45;
    letter-spacing: -0.015em;
    color: #777;
}

.board-wrap .table_blog dd:hover {
    background: unset;
}

.board-wrap .table_blog .left {
    width: 100%;
    height: auto;
    border-radius: 6px;
    overflow: hidden;
}

.board-wrap .table_blog .left a {
    overflow: hidden;
}

.research .table_blog .left span.thumb {
    height: 170px;
    width: 100%;
}

.table_blog .left a {
    border-radius: 6px;
    overflow: hidden;
}

.table_blog .left span.thumb:hover {
    transform: scale(1.1);
}

.research .table_blog .left {
    width: 300px;
}

.board-wrap .table_blog .left span.thumb {
    width: 100%;
    height: 170px;
    object-fit: cover;
    transition: all 0.4s ease;
}

.board-wrap.semi .table_blog .left span.thumb {
    height: 90px;
    /* width: 100px; */
}

.board-wrap.semi .table_blog .right .info {
    margin-top: 10px;
}

.board-wrap .table_blog .left span.thumb:hover {
    transform: scale(1.1);
}

.board-wrap .table_blog .right {
    width: 100%;
    display: flex;
    flex-direction: column;
    padding: 0;
}

.board-wrap .table_blog .right .info {
    order: 3;
    margin: 15px 0 0 0;
}

.board-wrap .table_blog .right .text {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    overflow: hidden;
}

.board-wrap .table_blog .right .title {
    margin-bottom: 18px;
    padding: 0;
    margin: 0 0 15px;
}

.board-wrap .table_blog .right .text p {
    max-height: 105px;
    -webkit-line-clamp: 3;
}

.board-wrap.semi .table_blog .right .text p {
    max-height: 40px;
    -webkit-line-clamp: 2;
}

.board-wrap.semi .table_blog .right .title {
    margin-bottom: 8px;
}

.board-wrap .table_blog .right .title a {
    font-size: 19px;
    font-weight: 700;
    letter-spacing: -0.025em;
}

.table_blog .right .text p {
    font-size: 16px;
    color: #555;
    padding: 0;
    word-break: break-all;
    text-align: justify;
    line-height: 1.7;
    max-height: 85px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
}

.board-wrap .table_blog .right .info .regdate {
    padding: 0;
    opacity: 0.8;
    font-size: 13px;
}

.table_blog .right .subject {
    width: 200px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
    letter-spacing: 0;
    word-break: break-all;
    line-height: 1.33;
    color: #222;
    transition: all 0.1s ease;
}

.research .table_blog .right span.subject {
    word-break: keep-all;
}

.research .table_blog .right .info {
    display: none;
}

.table_blog .right .subject:hover {
    color: var(--page-point-color);
}

/* 메인 페이지 공지사항*/
#main01 {}

#main02 {
    background: #f4f6f7;
    padding: 100px 0 50px;
}

#main01 .main-board {
    gap: 30px 50px;
    /* background: #f4f6f7; */
    /* border-radius: 6px; */
}

.main-con .main-board.semina {
    background: #fff;
    border-left: 1px solid #ddd;
    padding-left: 50px;
}

.main-con .main-board {}

.main-con .main-board.notice {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    padding-right: 50px;
}

.main-con .main-board>div {
    position: relative;
}

.main-con .board_box_list {
    padding: 0;
}

.main-con .board_box_list :where(.hits, .writer) {
    display: none;
}

/* #main01 .notice>div:nth-child(1)::after {
    content: '';
    width: 2px;
    height: 100%;
    position: absolute;
    right: -50px;
    top: 0;
    background: #ffffff;
} */

.main-con .page-header h4 {
    font-size: 26px;
    position: unset;
    letter-spacing: -0.02em;
    color: #222;
}

.main-con .page-header h4 span {
    display: inline-block;
    margin-right: 5px;
    font-weight: 700;
    color: var(--page-point-color);
}

.main-con .page-header {
    /* border-bottom: 1px solid #bdc5c9; */
    border-bottom: 0;
    margin: 0px 0 30px;
    padding: 0;
}

.main-con .page-header .pull-right {
    margin-top: 2px !important;
    opacity: 1;
    line-height: 1;
    border: 1px solid #ddd;
    padding: 3px 7px 5px;
    border-radius: 100px;
}

.main-con .page-header .pull-right i {
    font-size: 10px;
    color: #777;
}

.main-con .page-header .pull-right::after {
    content: 'MORE';
    font-weight: 500;
    font-size: 10px;
    letter-spacing: 0;
    margin-left: 2px;
    color: #888 !important;
}

.type_list span.subject {
    font-size: 16px;
    letter-spacing: -0.01em;
    /* font-weight: 450; */
}

.type_list span.subject:hover {
    color: var(--page-point-color);
}

.type_list span.subject:hover {
    text-decoration: underline;
    text-underline-position: under;
}

.type_list li {
    padding: 8px 0;
    display: grid;
    grid-template-columns: 0.8fr 0.2fr;
}

.type_list li .info span {
    opacity: 0.45;
    font-size: 13px;
}





/* 서브 페이지 공통*/
.board-btn {
    display: block;
    width: fit-content;
    margin-left: auto;
    margin-top: 35px;
    margin-right: 15px;
    padding: 6px 30px;
    background: var(--page-point-color);
    color: #fff;
    border-radius: 80px;
    font-size: 18px;
    font-weight: 600;
    transition: all 0.3s ease;
}
.board-btn:hover{
    color: #fff;
    background: #888;
}
.subpage {}

.sub-header {
    position: relative;
    align-items: center;
    display: flex;
    height: 290px;
    /* display: none; */
    /* max-width: 1720px; */
    margin: 0 auto;
}

.sub-header .bg {
    background: url("/public/img/sub/subBg01.jpg") no-repeat center / cover;
    height: 100%;
    position: absolute;
    content: "";
    width: 100%;
    /* background: #333; */
}

.sub-header .bg::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.2);
}

.breadcrumb {
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    margin: 12px 0 0;
}

.breadcrumb>li+li:before {
    content: '\e5e1';
    font-family: 'Material Symbols Outlined';
    font-size: 12px;
    margin: 0 6px;
}

.breadcrumb li {
    font-size: 14px;
    color: #fff !important;
    opacity: 0.85;
}

.breadcrumb li span {
    --fill: 1;
    font-size: 14px;
    color: #FFF;
}

.breadcrumb li a {
    display: flex;
    align-items: center;
}

.sub-tit {
    position: relative;
    text-align: center;
    font-size: 44px;
    margin: 12px 0 0;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.015em;
}

.sub-link {
    /* padding: 30px 0; */
    /* background: #485157; */
    /* border-bottom: 1px solid #dde0e1; */
    /* max-width: 1720px; */
    margin: 0 auto;
    background: #fff;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    box-shadow: 0 4px 10px rgb(0 0 0 / 2%);
    position: relative;
    display: none;
}

[id^="professor_"] .sub-link {
    /* display: none; */
}

[id^="professor_honor"] .sub-link {
    /* display: block; */
}

.sub-link ul {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    line-height: 1;
}

.sub-link ul li {}

.sub-link ul li a {
    padding: 20px 0px 20px;
    display: block;
    color: #9ea3a9;
    transition: 0.2s ease;
    position: relative;
    font-size: 16px;
    font-weight: 500;
}

.sub-link ul li.active a {
    color: #333;
    font-weight: 600;
}

.sub-link ul li a:hover {
    color: #333;
}

.sub-link ul li a::after {
    content: "";
    bottom: 0px;
    left: 50%;
    width: 0;
    height: 2px;
    position: absolute;
    background: transparent;
    transform: translateX(-50%);
    transition: all 0.3s ease;
}

.sub-link ul li:hover a::after,
.sub-link ul li.active a::after {
    width: 100%;
    background: var(--page-point-color);
}


.sub-wrap {
    padding-top: 100px;
}

#professor_honor01 .sub-wrap {
    padding-top: 100px;
}

#professor_honor01 .tit-h4 {
    border-bottom: none;
    text-align: center;
    padding: 0;
    font-size: 40px;
    letter-spacing: 0;
}

#professor_honor01 .tit-h5 {
    text-align: center;
    margin-bottom: 60px;
    font-size: 20px;
    border: none;
    padding-left: 0;
}

#professor_honor01 .tit-h5::before {
    content: none;
}

.sub-wrap .con {
    padding-bottom: 150px;
}

.sub-wrap .sub-h3 {
    font-size: 40px;
    font-weight: 700;
    text-align: center;
    margin: 0 0 85px;
    line-height: 1;
    /* display: none; */
}

.sub-wrap .sub-h3::after {
    content: '';
    width: 50px;
    height: 3px;
    background: #333;
    display: block;
    margin: 20px auto 0;
}

.sub-wrap .con .tit-h4 {
    font-size: 28px;
    color: #333;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1;
    margin-bottom: 24px;
}

.sub-wrap .con .tit-h4 span {
    color: var(--page-point-color);
}

.sub-wrap .con .inner+.inner {
    margin-top: 80px;
}

.text-box {}

.text-box+.text-box {
    padding-top: 50px;
}

.text-box p {
    font-size: 18px;
    line-height: 1.68;
    margin: 0;
    letter-spacing: -0.015em;
}

.text-box p+p {
    margin-top: 20px;
}

[id^="professor"] .inner .text-box li {
    font-size: 17px;
    margin-bottom: 8px;
}


.tit-h5 {
    font-size: 22px;
    position: relative;
    color: var(--page-point-color);
    line-height: 1;
    margin-bottom: 25px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.tit-h5 .material-symbols-outlined {
    /* background: #edf2f5; */
    border-radius: 100px;
    color: #9bacb3;
    --wght: 300;
    font-size: 40px;
    padding: 8px;
    vertical-align: sub;
    margin-right: 10px;
    display: none;
}

.tit-h5::before {
    position: absolute;
    content: "";
}

.dot-list {}

.dot-list li {
    position: relative;
    padding-left: 14px;
    font-size: 17px;
    margin-bottom: 5px;
    display: flex;
    line-height: 1.5;
}

.dot-list li::before {
    position: absolute;
    content: "";
    left: 0;
    top: 10px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--page-point-color);
}


/* 학과 소개 */
.sub-wrap .con .intro {
    display: flex;
    flex-direction: column;
    gap: 80px;
}

#about01 .tit-h4 {
    text-align: center;
    font-size: 32px;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin-bottom: 80px;
}

#about01 .tit-h4 span {
    color: var(--page-point-color);
    font-weight: 700;
}

#about01 .inner.text {
    display: grid;
    gap: 70px;
    grid-template-columns: 0.4fr 1fr;
    margin-top: 100px;
    padding: 0 50px;
}

#about01 .inner.text .tit-h5 {
    /* text-align: center; */
    padding: 0;
    margin: 0 0 40px;
    color: #333;
    line-height: 1.5;
    border-top: 2px solid;
    padding-top: 35px;
    font-size: 24px;
    font-weight: 600;
}

#about01 .inner.text .tit-h5 span {
    display: block;
    font-size: 44px;
    letter-spacing: 0;
    color: var(--page-point-color);
    font-weight: 700;
}

#about01 .text-box p {
    text-align: justify;
    margin-bottom: 30px;
}

#about01 .inner.text .text-box {
    padding-top: 5px;
}

.graph-box {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 40px;
    padding: 0 50px;
}

.graph-box .circle-wrap {
    position: relative;
}

.circle-wrap:nth-child(1) .circle {
    background: #485157;
}

.circle-wrap:nth-child(2) .circle {
    background: #898f97;
}

.circle-wrap:nth-child(3) .circle {
    background: #b9a771;
}

.circle-wrap:nth-child(4) .circle {
    background: #1b69af;
}

.circle-wrap:nth-child(5) .circle {
    background: #18a2dd;
}

.circle {
    position: relative;
    aspect-ratio: 1;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    padding: 0 15px;
    color: #fff;
    font-weight: 700;
    box-shadow: 5px 8px 5px rgba(0, 0, 0, 0.1);
    line-height: 1.5;
}

.circle::before {
    position: absolute;
    content: "\e315";
    font-family: "material symbols outlined";
    right: -46px;
    top: 50%;
    transform: translate(0, -50%);
    font-size: 50px;
    color: #696969;
    font-weight: 200;
}

.circle-wrap:last-child .circle::before {
    display: none;
}

.circle-wrap span {
    display: block;
    text-align: center;
    font-size: 15px;
    line-height: 1;
    border-radius: 100px;
    width: 85px;
    padding: 12px 0;
    margin: 0 auto 20px;
    font-weight: 600;
    /* box-shadow: 5px 10px 20px rgba(0,0,0,0.08); */
    border: 2px solid #eee;
}

.circle-wrap span::before {
    /* position: absolute; */
    content: "";
    width: 1px;
    background: #000;
    height: 20px;
    left: 50%;
    bottom: 5px;
    transform: translate(-50%, 0);
}

/* 발전계획 */


/* 학과연혁 */
#about03 .sub-wrap .inner {
    /* display: grid; */
    grid-template-columns: 0.3fr 1fr;
    /* gap: 50px; */
}

.title-wrap {
    margin-bottom: 60px;
    text-align: center;
}

#about02 .inner.title-wrap h4 {
    text-align: center;
    font-size: 32px;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin-bottom: 40px;
}

#about02 .inner.strategy .text-box p {
    /* padding-left: 65px; */
}

#about02 .inner.strategy .text-box .tit-h5 {
    margin-bottom: 20px;
}

#about02 .inner.strategy .text-box {
    border: 2px solid #e5e9eb;
    border-radius: 6px;
    padding: 35px;
}

#about02 .inner.strategy .text-box+.text-box {
    margin-top: 15px;
}

#about02 .inner.title-wrap .text-box {
    border: 3px solid #e7ebed;
    background: #f4f6f7;
    border-radius: 6px;
    padding: 50px 100px;
    position: relative;
}

#about02 .inner.title-wrap .text-box p {
    font-weight: 500;
    line-height: 1.6;
}

#about02 .inner.title-wrap .text-box::before,
#about02 .inner.title-wrap .text-box::after {
    content: '';
    width: 60px;
    aspect-ratio: 1;
    border-radius: 6px 0 0 0;
    border-left: 3px solid var(--page-point-color);
    border-top: 3px solid var(--page-point-color);
    position: absolute;
    left: -3px;
    top: -3px;
}

#about02 .inner.title-wrap .text-box::after {
    border-radius: 0 0 6px 0;
    border-left: none;
    border-top: none;
    border-right: 3px solid var(--page-point-color);
    border-bottom: 3px solid var(--page-point-color);
    position: absolute;
    left: auto;
    top: auto;
    right: -3px;
    bottom: -3px;

}

#about03 .title-wrap .tit-h4 {
    text-align: center;
    font-size: 32px;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin-bottom: 70px;
}

.title-wrap::after {
    /* content: '\e5d3'; */
    display: block;
    font-family: 'Material Symbols Outlined';
    font-size: 40px;
    margin-top: 20px;
    color: #bbb;
}

.title-wrap .tit-h4 {}

.title-wrap .tit-desc {
    font-size: 18px;
    font-weight: 500;
    color: var(--page-point-color);
}

.history-wrap {
    width: max-content;
    position: relative;
    margin: 50px auto 0;
}

#about03 .con img {
    border-radius: 6px;
    height: 300px;
    width: 100%;
    object-fit: cover;
}

.history-wrap::before {
    content: '';
    width: 4px;
    height: 100%;
    position: absolute;
    left: 180px;
    top: 0;
    background: #eee;
    border-top: 30px solid #fff;
    border-bottom: 35px solid #fff;
}

.history-wrap .history {
    display: grid;
    grid-template-columns: 180px 1fr;
    padding: 18px 0;
}

.history-wrap .history .year {
    position: relative;
    font-size: 28px;
    color: var(--page-point-color);
    font-weight: 700;
    padding-left: 20px;
}

.history-wrap .history .year::before {
    position: absolute;
    content: "";
    right: -7px;
    top: 13px;
    width: 10px;
    height: 10px;
    background: #044279;
    border-radius: 50%;
}

.history .dot-list {
    padding-left: 60px;
    padding-top: 6px;
}

.history .dot-list li::before {
    content: none;
}

.history .dot-list li {
    display: grid;
    grid-template-columns: 85px 1fr;
    letter-spacing: -0.015em;
    padding-left: 0;
    gap: 10px;
}

.history .dot-list li+li {
    margin-top: 5px;
}

.history .dot-list li>span {
    display: block;
    font-weight: 600;
    color: #333;
}

.history-wrap .history:nth-child(even) {}

/*  학과안내 */
#about04 .table-responsive {
    overflow-y: hidden;
}

#about04 thead tr {
    background: #f8f8f8;
}

#about04 thead th {
    text-align: center;
    border-top: 2px solid #333 !important;
}

#about04 tbody tr {}

#about04 tbody td {}

#about04 tbody td:nth-child(1),
#about04 tbody td:nth-child(2) {
    text-align: center;
}

#about04 table th {}

#about04 table th,
#about04 table td {
    padding: 15px 20px;
    border-left: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    border-top: 1px solid #ddd;
    font-size: 16px;
    line-height: 1.4;
}

.table-default tbody>tr>td:first-child,
.table-default thead>tr>th:first-child {
    border-left: none !important;
}

#about04 ul {}

#about04 ul li {
    line-height: 1.4;
    font-size: 16px;
}

#about04 ul li+li {
    margin-top: 4px;
}

#about04 table tbody tr {}

#about04 table tbody tr:hover {
    background: rgba(0, 0, 0, 0.02);
}

.map-info {
    margin-top: 20px;
    background: #f4f6f7;
    display: grid;
    grid-template-columns: 0.3fr 1fr;
    border-radius: 6px;
    padding: 35px 40px;
}

.map-info p {
    font-size: 24px;
    font-weight: 700;
}

.map-info ul {}

.map-info ul li {
    font-size: 16px;
    line-height: 1.6;
    position: relative;
    padding-left: 15px;
}

.map-info ul li::before {
    content: '';
    width: 4px;
    height: 4px;
    background: var(--page-point-color);
    position: absolute;
    left: 0;
    top: 11px;
    border-radius: 5px;
}

.map-info ul li+li {
    margin-top: 3px;
}

.map-info ul li span {
    display: inline-block;
    margin-right: 10px;
    font-weight: 600;
}

/*  교수 소개 */
[id^="pro0"] .sub-wrap {
    background: #f4f6f7;
}

.pro-type {
    display: flex;
    justify-content: center;
    background: #e2e8eb;
    padding: 15px 40px;
    border-radius: 6px;
    gap: 15px;
}

.pro-type a.active {
    background: var(--page-point-color);
    color: #fff;
    border-radius: 6px;
}

.pro-type a.active:hover {
    color: #fff;
}

.pro-type a:hover {
    color: var(--page-point-color);
}

.pro-type a {
    /* flex: 0 1 10%; */
    text-align: center;
    padding: 8px 12px;
    font-size: 16px;
    letter-spacing: 0;
    color: #394349;
    border-radius: 100px;
    font-weight: 500;
}

.pro-wrap {
    margin-top: 55px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px 30px;
}

.pro-wrap .pro-box {
    box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.02);
    transition: all 0.35s ease;
    border-radius: 6px;
    padding: 28px 28px 35px;
    background: #fff;
    border: 3px solid #fff;
}

.pro-wrap .pro-box img:hover {
    transform: scale(1.08);
}

.pro-wrap .pro-box:hover a img {}

.pro-wrap .pro-box:hover {
    border-color: var(--page-point-color);
}

.pro-wrap .pro-box>a {}

.pro-wrap .pro-box img {
    width: 100%;
    aspect-ratio: 3/2.6;
    object-fit: cover;
    object-position: top;
    background: #eee;
    transition: all 0.4s ease;
}

.pro-wrap .pro-box h5 {
    margin-top: 30px;
    font-size: 16px;
    text-align: center;
    font-weight: 500;
    color: #7e8b91;
}

.pro-wrap .pro-box h5 span {
    display: inline-block;
    font-size: 22px;
    font-weight: 700;
    color: #222;
    margin-right: 8px;
    letter-spacing: 1px;
}

.pro-wrap .type-wrap {
    margin-top: 30px;
    display: flex;
    justify-content: center;
    flex-flow: wrap;
    gap: 5px 6px;
}

.pro-wrap .pro-box .type-wrap a {
    display: block;
    padding: 6px 6px;
    color: #fff;
    border-radius: 3px;
    font-weight: 400;
    font-size: 13px;
    line-height: 1;
}

.pro-wrap .pro-box .type-wrap a:hover {
    filter: brightness(0.85);
}

.pro-wrap .pro-box a.type03 {}

.pro-wrap .pro-box a.type04 {
    background: #334555;
}

.pro-wrap .pro-box a.type05 {
    background: #e98e00;
}

.pro-wrap .pro-box a.type06 {
    background: #f76900;
}

.pro-wrap .pro-box a.type07 {
    background: #e84393;
}

.pro-wrap .pro-box a.type08 {
    background: #0092cf;
}

.pro-wrap .pro-box a.type09 {
    background: #42bd2f;
}

.pro-wrap .pro-box a.type10 {
    background: #e74231;
}

.pro-wrap .pro-box a.type11 {
    background: #ab793a;
}

.pro-wrap .pro-box a.type12 {
    background: #6f68e9;
}

.pro-wrap .pro-box a.type13 {
    background: #228175;
}

[id^=professor_] .sub-wrap {
    background: #f4f6f7;
    padding-top: 0;
}

[id^=professor_] .breadcrumb,
[id^=professor_] .sub-header {
    /* display: none; */
}

[id^=professor_] .sub-header {
    display: none;
}

[id^=professor_] .breadcrumb {
    margin-top: 30px;
    display: none;
}

[id^=professor_] .professor-wrap.dot-list li>span {
    display: block;
    margin-right: 15px;
    letter-spacing: 0;
    font-weight: 600;
    opacity: 0.65;
}

[id^=professor_] .dot-list li>span {
    display: block;
    font-weight: 700;
    margin-right: 10px;
}

[id^=professor_] .inner {
    /* display: grid; */
    /* grid-template-columns: 0.2fr 0.8fr; */
}

[id^=professor_] .inner .text-box {
    margin-top: 2px;
}

[id^="professor_"] .sub-wrap .con .tit-h4 {
    border-bottom: 1px solid #d8dcdf;
    padding-bottom: 15px;
}

.professor-link {
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    border-bottom: 1px solid #eee;
    background: #fff;
}

.professor-link a {
    font-size: 15px;
    display: block;
    padding: 18px 10px;
    color: #6d7377;
    letter-spacing: -0.01em;
    border-radius: 3px;
    font-weight: 400;
}

.professor-link span {
    font-size: 15px;
    display: block;
    padding: 18px 20px;
    font-weight: 700;
    position: relative;
    margin-right: 20px;
}

.professor-link span::after {
    content: '';
    width: 1px;
    height: 14px;
    background: #cdcdcd;
    position: absolute;
    right: 0;
    top: 18px;
}

.professor-link a:hover {
    color: var(--page-point-color);
    font-weight: 600;
}

.professor-link a.active {
    color: #333;
    font-weight: 700;
    color: #008fcb;
}

.professor-wrap {
    display: grid;
    grid-template-columns: 0.65fr 0.35fr;
    margin-bottom: 100px;
    background: #fcfcfc;
}

.professor-wrap+.container {
    background: #fff;
    padding: 80px;
    border-radius: 6px;
    box-shadow: 20px 20px 60px rgba(0, 0, 0, 0.02);
}

#professor_ic01 .professor-wrap img {
    width: 100%;
}

#professor_oc04 .professor-wrap {
    background: #fff;
}

.professor-wrap img {
    width: 80%;
    height: 860px;
    object-fit: cover;
    object-position: 50% 9%;
    margin: 0 auto;
}

#professor_pc03 .professor-wrap img {
    margin: 0 auto;
}

#professor_pc03 .professor-wrap {
    background: #f8e4d9;
}

.professor-wrap .professor-info {
    background: #2d3337;
    background: linear-gradient(135deg, #4d5459, #22282d);
    color: #fff;
    display: flex;
    flex-flow: column;
    justify-content: center;
    padding-left: 90px;
    padding-top: 0px;
}

.professor-info .name {
    margin-bottom: 35px;
}

.name span {
    font-size: 22px;
    color: #54c4f3;
    letter-spacing: 0;
    font-weight: 500;
    display: block;
}

.name h5 {
    font-size: 54px;
    margin-top: 10px;
    font-weight: 700;
    letter-spacing: 3px;
    line-height: 1;
    width: fit-content;
    display: inline-block;
}

.name .en-name {
    font-size: 18px;
    letter-spacing: 1px;
    font-weight: 600;
    opacity: 0.6;
    display: inline-block;
    margin-left: 13px;
}

.lab {
    margin-bottom: 60px;
}

.lab span {
    font-size: 20px;
    margin-bottom: 15px;
    display: block;
    font-weight: 500;
    letter-spacing: -0.01em;
}

.lab a {
    display: block;
    padding: 6px 15px;
    width: fit-content;
    border: 1px solid rgb(255 255 255 / 50%);
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0;
    border-radius: 3px;
}

.lab a::before {
    content: '\e88a';
    font-family: 'Material Symbols Outlined';
    font-variation-settings: 'FILL' 1;
    margin-right: 8px;
    font-size: 16px;
    line-height: 1;
}

.lab a:hover {
    background: #fff;
    color: #333;
}

.contact {}

.contact li {
    display: grid;
    align-items: center;
    grid-template-columns: 80px 1fr;
    margin-bottom: 7px;
    color: #fff;
    padding-left: 0;
    letter-spacing: 0;
    font-size: 15px;
}

.contact li::before {
    content: none;
}

.professor-wrap .professor-info .contact li span {
    display: block;
    color: #c4d0d9;
}

.contact li::before {
    background: #fff;
}

/* 명예교수 */
.img-wrap {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
    padding-top: 20px;
}

.img-wrap .img-box {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.02);
    padding: 45px 45px 30px;
    text-align: center;
}

.img-wrap .img-box img {
    object-fit: cover;
    margin: 0 auto;
    border-radius: 6px;
    width: 100%;
    aspect-ratio: 1/1.2;
    overflow: hidden;
}

.img-wrap .img-box p {
    font-size: 20px;
    font-weight: 700;
    text-align: center;
    padding: 22px 0 0px;
}

.img-wrap .img-box p span {
    font-size: 15px;
    font-weight: 500;
    display: block;
    margin-top: 12px;
    color: #7e8b91;
    letter-spacing: 0;
}

/* 게시판 */
tr.notice {
    background: #fafcfe;
}

td.subject .badge {
    background: var(--page-point-color);
}

.table.table_default tbody .num {
    font-weight: normal;
}

.table.table_default tr th,
.table.table_default tr td {
    border-bottom: 1px solid #ddd;
    padding: 16px 15px;
}

.table.table_default tr td {
    color: #777;
    font-size: 14px;
}

.table.table_default thead th {
    font-size: 16px;
    background: #f8f8f8;
    padding: 16px;
}

.table.table_default tbody .subject a {
    font-size: 16px;
    letter-spacing: -0.015em;
    font-weight: 400;
    color: #222;
}

.table.table_default tbody .subject a:hover {
    text-decoration: underline !important;
    text-underline-position: under;
}

.table.table_default colgroup .writer_col,
.table.table_default colgroup .regdate_col {
    width: 120px !important;
}

.table_blog .left span.thumb {
    border-radius: 6px;
    height: 170px;
    width: 250px;
    object-fit: cover;
    transition: all 0.4s ease;
}

.table_blog .right .title a {
    font-weight: 700;
    letter-spacing: -0.01em;
    font-size: 20px;
}

.table_blog .right .title {
    padding: 0;
    margin-top: 10px;
    margin-bottom: 15px;
}

.table_blog .right .info span {
    padding: 0 10px 0 0;
    font-size: 13px;
}

.table_blog .right {
    padding-left: 40px;
    padding-right: 50px;
}

.table_blog .right .info {
    margin-bottom: 20px;
}

.table_blog .right .text p {
    font-size: 15px;
    color: #6f6f6f;
    padding: 0;
    word-break: break-all;
    text-align: justify;
    line-height: 1.6;
    max-height: 85px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    white-space: normal;
    letter-spacing: -0.015em;
}

.research .table_blog dd {
    padding: 30px 0;
    display: flex;
    align-items: center;
    border-color: #dae0e7;
}

.research .table_blog dd:first-child {
    padding-top: 20px;
}

.table_blog dd {
    padding: 30px 30px;
    border-bottom: 1px solid #e3e3e3;
    display: flex;
    align-items: center;
}

.table_blog dd:hover {
    background: transparent;
}

.board_data_view .header_wrap .title {
    font-weight: 700;
    font-size: 28px;
}

.bbs-area .contents_inner p {
    font-size: 16px;
    line-height: 1.65;
}

.board_data_view .header_wrap {
    padding: 45px 0 40px;
    border-bottom: 1px solid #eee;
}

.board_data_view .header_wrap .info {
    margin-top: 25px;
}

.board_write_table #captcha+br {
    display: none;
}

.board_write_table #captcha {
    height: var(--input-height);
    vertical-align: bottom;
    margin-top: 0 !important;
}

.board_write_table #wr_captcha {
    margin-top: 0 !important;
}

.form-control {
    height: var(--input-height);
    border-radius: 3px;
}

.btn {
    min-height: var(--input-height);
}

/* 푸터 */
footer {
    margin-top: 0;
    background-color: #485157;
    color: #999;
}


footer .footer-wrap {
    /* display: grid; */
    padding: 50px 0;
    /* grid-template-columns: 0.2fr 1fr; */
}

footer .footer-logo {
    display: none;
}

.footer-logo img {
    height: 70px;
    filter: brightness(0) invert(1);
    opacity: 0.6;
}

.footer-info {
    display: flex;
    flex-flow: wrap;
    position: relative;
}

.footer-info li {
    font-size: 13px;
    margin-right: 20px;
    color: #fff;
    opacity: 0.8;
}

.footer-info li:first-child {
    font-weight: 500;
    font-size: 17px;
    margin-bottom: 18px;
    opacity: 0.95;
}

.footer-info li.copy {
    margin-top: 10px;
    font-size: 12px;
    color: #ffffff;
    letter-spacing: 0.1px;
    opacity: 0.4;
}

.footer-info li.login {
    position: absolute;
    right: 15px;
    bottom: 20px;
}

.footer-info li.login a {
    display: block;
    padding: 5px 15px;
    border: 1px solid rgb(255 255 255 / 20%);
    color: rgb(255 255 255 / 50%);
    border-radius: 3px;
    transition: all 0.2s ease;
}

.footer-info li.login a:hover {
    background: #fff;
    color: #333;
}

.footer-info li.clear-fix {
    width: 100%;
}

/* 반응형 */

@media (max-width: 767px) {
    .carousel-control {
        font-size: 14px;
    }

    .carousel-indicators li,
    .carousel-indicators li.active {
        width: 6px;
        height: 6px;
    }

    #mainCarousel .carousel-inner .item {
        height: 250px;
    }

    #mainCarousel .carousel-caption h1 {
        font-size: 24px;
    }

    #mainCarousel .carousel-caption p {
        font-size: 12px;
    }

    .navbar-inverse .navbar-toggle {
        border: 0;
        padding: 9px 0;
    }

    .navbar-inverse .navbar-toggle .icon-bar {
        background-color: #666;
        transition: ease 0.15s all;
        opacity: 1;
        position: relative;
    }

    .navbar-inverse .navbar-toggle:focus,
    .navbar-inverse .navbar-toggle:hover {
        background: none;
        border-color: #222;
    }

    .navbar-inverse .navbar-toggle:focus .icon-bar,
    .navbar-inverse .navbar-toggle:hover .icon-bar {
        background-color: #222;
    }

    .navbar-inverse .navbar-collapse,
    .navbar-inverse .navbar-form {
        border-color: transparent;
    }

    .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>.container .navbar-brand,
    .navbar>.container-fluid .navbar-brand {
        margin-left: 0;
    }

    .navbar-inverse .navbar-nav .dropdown-menu {
        min-width: 100%;
        background: #f4f6f7;
        left: 50%;
        right: auto;
        transform: translate(-50%, 0);
        border-radius: 0 0 6px 6px;
        border: 0;
        padding: 0;
        -webkit-box-shadow: 0 4px 8px rgba(0, 0, 0, .125);
        box-shadow: 5px 8px 5px rgba(0, 0, 0, .08);
        animation-fill-mode: both;
        animation-duration: 0.4s;
        animation-name: fadeIn;
        min-width: 150px;
        overflow: hidden;
    }

    .navbar-inverse .navbar-nav .dropdown-menu>li>a {
        padding: 13px 10px;
        color: #4d575d;
        text-align: center;
        font-size: 15px;
        transition: all 0.2s ease;
        font-weight: 500;
    }

    .navbar-inverse .navbar-nav .dropdown-menu>li+li>a {}

    .navbar-inverse .navbar-nav .dropdown-menu>li>a:focus,
    .navbar-inverse .navbar-nav .dropdown-menu>li>a:hover {
        background: var(--page-point-color);
        color: #fff;
    }
}