@charset "utf-8";

/**************************
파일 만든이 : 이은숙
파일 제작일 : 2022.07.04
파일 최종수정일 : 2025.07.10
***************************/

@import url(style.css);
@import url(fonts.css);

body, input, textarea, select, button, table{ margin: 0; font-size: 13px; font-family: 'PretendardGOV', '맑은 고딕', '돋움', Dotum, '새굴림', sans-serif; font-weight: 300; color: #333; }
body, h1, h2, h3, h4, h5, dl, dt, dd, ul, li, ol, th, td, p, form, fieldset, legend, button { margin: 0; padding: 0; }

img, fieldset{ border: 0 none; }
dl, ul, ol, li { list-style: none outside none; }
button{ border: 0 none; cursor: pointer; display: block; }
table, th, td, div{ border-collapse: collapse; }

li img { vertical-align: top; }
td img { vertical-align: middle; }
label { cursor: pointer; }

a { text-decoration: none; color: #333; }
a:hover, a:active, a:focus { color: #333; text-decoration: none; }
table a:link, table a:visited { color: #333; }
table a:hover, table a:active { color: #333; text-decoration: underline; }
address, caption, cite, code, dfn, em, var { font-style: normal; }

strong, .strong , b { font-weight: bold; }
.blind, legend, caption { display: none !important; }
.cursor { cursor: pointer; }
.clear { clear: both; }

/**********************************************************************
    바로가기
***********************************************************************/
#accessibility { position:absolute; z-index:2000; left:0; top:0; width:100% }
#accessibility a { display:block; width:1px; height:1px; margin-bottom:-1px; overflow:hidden; text-align:center; color:#222; font-size:16px; }
#accessibility a:focus, #accessibility a:active { width:100%; height:auto; padding:9px 0; background:#fff; }


/**********************************************************************
    공통
***********************************************************************/
/* html { scroll-behavior: smooth; } */
body { background-color: #f7f7f7; overflow-x: hidden;}
body.hide { overflow: hidden; }
div img { max-width: 100%; }

[class^="ico-"] {
    display: inline-block;
}
[class^="ico-"]:before {
    display: inline-block;
    color: inherit;
    font-family: "icomoon";
}
button {
    display: inline-block;
    background-color: transparent;
}
::-webkit-scrollbar {
    width: 5px;
}
/* Track */
::-webkit-scrollbar-track {
    box-shadow: inset 0 0 5px #7777771a;
    border-radius: 5px;
}
  /* Handle */
::-webkit-scrollbar-thumb {
    background: #c5c5c6;
    border-radius: 5px;
}
::-webkit-scrollbar-thumb:hover {
	background: #a5a5a5; 
}
.mo {
    display: none;
}

  
/**********************************************************************
    탑메뉴
***********************************************************************/
#header {
    position: relative;
	font-size: 14px;
	background:#fff;
    transition:all 0.5s;
}
#header .util-menu {
    position: absolute;
    right: 40px;
    top: calc(50% - 7px);
    display: none;
}
#header .util-menu li {
    display: inline-block;
    position: relative;
    padding: 0 9px 0 13px;
	color: #fff;
	font-size: 13px;
    line-height: 15px;
}
#header .util-menu li a { 
    color: #fff;
}
#header .util-menu li + li:before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    top: 1px;
    height: 15px;
    border-left: 1px solid #fff;
    opacity: 0.3;
}

#header > .inner {
	position: relative;
	padding: 0 120px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 75px;
    border-bottom: 1px solid #e2e2e2;
}

#header.sub > .inner {
    height: 62px;
    border-bottom: 1px solid #e2e2e2;
    box-shadow: 0 5px 18px rgba(0,0,0,.06);
}
#header .header-left {
    display: flex;
    align-items: center;
}
#header .header-right {
    display: flex;
}
#header .logo { 
	width: 114px;
    height: 50px;
    font-size: 0;
    background: url(../images/logo.svg) center no-repeat;
    background-size: 100% auto;
}
#header .logo a {
    display: block;
    width: 100%;
    height: 100%;
}

#header.sub .logo { 
	width: 105px;
    height: 45px;
}

#header #gnb {
	z-index: 110; 
}

#header #gnb .menu > li {
	position: relative;
	float: left;
	margin-left: 50px;
	color: #222;
	font-size: 17px;
	cursor: pointer;
}
#header.sub #gnb .menu > li {
	font-size: 16px;
}

#header #gnb .menu > li a {
    color: #222;
    font-weight: 600;
}
#header #gnb .menu > li.on a:after {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    bottom: 0;
    height: 11px;
    width: 100%;
    background-color: #ee592d;
}

#header #gnb .sub-menu {
	display: none;
	position: absolute;
	top: 47px;
	left: calc(50% - 115px);
	width: 230px;
    padding: 5px 0 15px 0;
	box-sizing: border-box;
	background-color: #3f3f7c;
    border-bottom-left-radius: 24px;
    border-bottom-right-radius: 24px;
}
#header #gnb .sub-menu .imp {
	background: rgba(0, 0, 0, .5);
    padding: 8px 10px;
    margin: 10px 0;
    border-radius: 8px;
    text-align: center;
    font-size: 14px;
}
#header.sub #gnb .sub-menu {
	top: 40px;
}

#header #gnb li.active .sub-menu {
    display: block;
}
#header #gnb .sub-menu > li {
    margin: 0 20px;
    border-bottom: 1px solid rgba(255,255,255,.2);
}
#header #gnb .sub-menu > li a {
	position: relative;
	display:block;
	padding: 18px 5px;
	font-size: 16px;
    font-weight: 300;
	color: #fff;
}
#header #gnb .sub-menu ul > li a {
	padding: 0 5px 15px 20px;
	font-size: 15px;
    position: relative;
}
#header #gnb .sub-menu ul > li a:before {
	content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 2px;
    width: 12px;
    height: 12px;
    background: url(../images/ico_sub.svg) center no-repeat;
    filter: invert(100%);
    opacity: .5;
    background-size: 100% auto;
}
#header #gnb .sub-menu > li:last-child {
    border-bottom: 0;
}
#header #gnb .sub-menu ul > li > a:hover,
#header #gnb .sub-menu > li > a:hover {
    color: rgba(255,255,255,.6);
}
#header #gnb .sub-menu a {
	color: #fff;
}

#header .search-area {
	margin-left: 27px;
	z-index: 100;
}
#header .search-area .input-area {
    display: flex;
    justify-content: space-between;
    align-items: center;
	position: relative;
    width: 374px;
	height: 50px;
	padding: 0 20px;
	border: 2px solid #d0d0d0;
    border-radius: 25px;
    box-sizing: border-box;
}
#header.sub .search-area .input-area {
	height: 44px;
}
#header .search-area .input-area .text {
	width: calc(100% - 40px);
	font-size: 16px;
	color: #161616;
	border: 0;
    background-color: transparent;
    outline: 0;
}
#header .search-area .input-area .text::-webkit-input-placeholder { 
  color: #646464;
}
#header .search-area .input-area .ico-search {
    color: #161616;
    font-size: 18px;
}

#header .btn-m {
	display: none;
}


/**********************************************************************
    STIKY
***********************************************************************/
#header.stiky {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 900;
    width: 100%;
    background: #333366;
}
#header.stiky > .inner {
    height: 59px;
    border-bottom: none;
    box-shadow: 0 5px 18px rgba(0,0,0,.2);
}
#header.stiky .logo {
    width: 97px;
    height: 40px;
    background: url(../images/logo_w.svg) center no-repeat;
    background-size: 100% auto;
}
#header.stiky .logo img {
    width: 97px; height: 39px;
}
#header.stiky #gnb {
}
#header.stiky #gnb .menu > li {
	font-size:16px;
}
#header.stiky #gnb .menu > li a {
    color: #fff;
    font-weight: 500;
}
#header.stiky #gnb .sub-menu {
    top: 38px;
}
#header.stiky #gnb .sub-menu > li {
	font-size: 16px;
}
#header.stiky .search-area {
}
#header.stiky .search-area .input-area {
	height: 43px;
    border: 2px solid #b0b0c4;
}
#header.stiky .search-area .input-area .text {
	font-size: 15px;
	color: #fff;
}
#header.stiky .search-area .input-area .ico-search {
    color: #fff;
    font-size: 17px;
}
#header.stiky .util-menu {
    top: 18px;
    display: none;
}


/**********************************************************************
    COLOR
***********************************************************************/
.blue {
    background-color: #00b3eb;
}
.green {
    background-color: #00b1b1;
}
.yellow {
    background-color: #f9a61a;
}
.purple {
    background-color: #8585cf;
}
.orange {
    background-color: #f0592c;
}
.khaki {
    background-color: #a5af3a;
}
.c-orange {
    color: #7a65ab !important;
}
.c-brown {
    color: #b2492a !important;
}
.c-blue {
    color: #c540a4 !important;
}
.d-blue {
	background-color: #504764 !important;
}
.g-yellow {
    background-color: #cf9a3f !important;
}
.d-khaki {
    background-color: #526258 !important;
}
.l-beige {
    background-color: #b6a792 !important;
}
.dd-beige {
    background-color: #958773 !important;
}


.fLine {color:#ccc; font-weight:100; font-size:1.7em;}

.democratization .section .section-title.bar-blue:before{
	border-color:#bbb3c6 !important;
    border-bottom: 8px solid transparent !important;
}
.democratization .section .section-title.bar-yellow:before{
	border-color:#c6c3b3 !important;
    border-bottom: 8px solid transparent !important;
}
.democratization .section .section-title.bar-khaki:before{
	border-color:#b3c6ba !important;
    border-bottom: 8px solid transparent !important;
}
.democratization .section .section-title.bar-beige:before{
	border-color:#c6bbb3 !important;
    border-bottom: 8px solid transparent !important;
}

.btn-basic {
    display: inline-block;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
	padding: 5px 12px;
    background-color: #504764;	
    box-shadow: 3px 3px 3px rgba(0,0,0,0.2);
	border-radius:6px;
}
.btn-top {
	display: inline-block;
	position: fixed;
	right: 10px;
	bottom: 10px;
	z-index: 10;
	width: 50px;
	height: 50px;
	background: rgba(255,255,255,.8) url('../images/icon_arrowtop.svg') no-repeat center center;
	background-size: 16px auto;
    border: 1px solid rgba(0,0,0,.15);
	border-radius: 50%;
}

/**********************************************************************
    SELECT
***********************************************************************/
.select-wrap { 
	display:block; 
	position:relative;
	width:145px; 
	padding:6px 14px; 
	color:#333237; 
	line-height:26px; 
	font-size:13px;
	background-color:#fbfbfb; 
	border:1px solid #e9e9e9; 
	box-sizing:border-box;
	cursor:pointer;
}
.select-wrap:after { 
	content:""; 
	display:inline-block; 
	position:absolute; 
	right:14px; 
	top:17px; 
	width:13px; 
	height:7px; 
	background:url('../images/icon/arrow_down.png') no-repeat center center; 
    opacity: 0.6;
}
.select-wrap.on:after { 
	background:url('../images/icon/arrow_up.png') no-repeat center center; 
    opacity: 0.6;
}
.select-wrap ul { 
	display:none;	
	position:absolute; 
	left:-1px; 
	top:50px; 
	z-index:10; 
	width:100%; 
	background-color:#fbfbfb; 
	border:1px solid #e9e9e9; 
}
.select-wrap ul li { 
	padding:10px 7px; 
	border-bottom:1px solid #e9e9e9; 
}
.select-wrap ul li:last-child {
	border-bottom:0;
}
.select-wrap a {
	display:block;
}

/**********************************************************************
    LAYER - 공지사항
***********************************************************************/
.layer_notice {
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 500;
    width: 1024px;
    color: #fff;
    padding: 27px 45px 20px;
    background-color: #008ce9;
}
.layer_notice a {
    color: #fff;
}
.layer_notice .control {
    position: absolute;
    right: 55px;
}
.layer_notice .control input {
    margin: -1px 5px 0 0;
    vertical-align: middle;
    border: 1px solid #ccc;
}
.layer_notice .control label {
    text-decoration: underline;
}
.layer_notice .control .btn-close {
    display: inline-block;
    width: 24px;
    height: 24px;
    margin-left: 25px;
    background: url('../images/ico_close.png') no-repeat center center;
    vertical-align: middle;
    cursor: pointer;
}
.layer_notice .title {
    margin-bottom: 12px;
    font-size: 20px;
    font-family: 'NanumSquare';
	font-weight:700;
}
.layer_notice .txt {
    font-size: 16px;
    line-height: 22px;
	font-weight:200;
}


/**********************************************************************
    SUB CSS
***********************************************************************/
#container.sub {
    max-width: 1440px;
    margin: 50px auto 80px;
}
#container .content {
    padding: 0 10px;
}
#container .location {
    display: flex;
    margin-bottom: 30px;
	flex-wrap: wrap;
}
#container .location li {
	font-size: 30px;
	color: #333;
}
#container .location li:last-child {
    font-weight: 500;
}
#container .location li + li:before {
    content: '\e917';
    display: inline-block;
    font-family: 'icomoon';
    margin: -5px 12px 0 12px;
    font-size: 18px;
    vertical-align: middle;
}
#container .location_wrap {
    display: flex;
    justify-content: space-between;
}
#container .location_wrap .btn_area {
    text-align: right;
}
.btn_shadow {
    padding: 10px 16px;
    font-size: 16px;
    font-weight: 600;
    color: #333;
    border: 1px solid #d5d5d5;
    background: #fff;
    box-shadow: 5px 5px 10px rgba(0,0,0,.1);
    border-radius: 8px;
    display: flex;
    align-items: center;
    margin-right: 10px;
}
.btn_shadow.btn_simple:before {
    content: '';
    display: inline-block;
    width: 39px;
    height: 21px;
    border-right: 2px solid #d1d1d1;
    background: url(../images/ico_simple.svg) left no-repeat;
    margin-right: 10px;
}
.btn_shadow.btn_detail:before {
    content: '';
    display: inline-block;
    width: 32px;
    height: 21px;
    border-right: 2px solid #d1d1d1;
    background: url(../images/ico_detail.svg) left no-repeat;
    margin-right: 10px;
}

#container.sub .democratization .section .list {
    margin-top: 10px;
}

.gallery_wrap {
    display: flex;
}
.gallery_m_list {
    width: 310px;
    border-right: 1px solid #d7d7d7;
    padding-right: 25px;
    margin-right: 25px;
}
.gallery_m_list li a {
    width: 100%;
    border:1px solid #cdcdcd;
    background: #fff;
    padding: 8px;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    box-sizing: border-box;
}
.gallery_m_list li a:hover {
    background: #f0f0f0;
    transition: all .3s;
}
.gallery_m_list li a .img {
    width: 65px; 
    height: 65px;
    border: 1px solid #eee;
    box-sizing: border-box;
    overflow: hidden;
}
.gallery_m_list li a .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.gallery_m_list li a:hover .img img {
    transform: scale(1.5);
    transition: all .3s;
}
.gallery_m_list li a .title {
    padding-left: 15px;
    font-size: 20px;
    font-weight: 700;
}
.gallery_wrap .multimedia-list {
    width: calc(100% - 361px);
}

.gallery_wrap select {
    display: none;
    width: 100%;
    height: 48px;
    margin-bottom: 15px;
    border-radius: 8px;
    padding: 0 10px;
    font-size: 15px;
}


/**********************************************************************
    FORM
***********************************************************************/
.control-wrap {
    display: flex;
    justify-content: space-between;
    line-height: 33px;
}
.control-wrap.top {
    align-items: flex-end;
    margin-bottom: 20px;
}
.control-wrap .left,
.control-wrap .right {
    min-width: 80px;
    z-index: 2;
}
.control-wrap .board-search {
    background-color: #fff;
    border: 1px solid #e7e8e9;
}
.control-wrap .board-search > * {
    color: #000;
    font-weight: 400;
    border: 0;
}
.control-wrap .board-search input {
    width: 260px;
}
.control-wrap .board-search .ico-search {
    margin: 0 10px;
    font-size: 14px;
}
.control-wrap .paging {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    font-weight: 400;
    z-index: 2;
}
.control-wrap .paging input {
    width: 50px;
    margin: 0 15px 0 30px;
    text-align: right;
}
.control-wrap .paging .total {
    display: inline-block;
    margin-left: 15px;
	font-family: 'NanumSquare';
}
.control-wrap .paging button {
    padding-left: 30px;
}
.select { 
	display: inline-block; 
    height: 33px;
    min-width: 65px;
	padding: 0 7px;
    margin-right: 2px;
	color: #333; 
	line-height: 31px; 
	font-size: 14px;
	background-color: #fff; 
	border: 1px solid #e7e8e9; 
	box-sizing: border-box;
    outline: 0;
}
.select.big {
    min-width: 100px;
}
input[type="text"] { 
	display: inline-block; 
    height: 32px;
    min-width: 65px;
	padding: 0 7px;
	color: #333; 
	line-height: 31px; 
	font-size: 14px;
	background-color: #fff; 
	border: 1px solid #e7e8e9; 
	box-sizing: border-box;
    outline: 0;
}

/**********************************************************************
    메인
***********************************************************************/
.democratization {
    padding: 0 0 140px 55px;
}
.democratization .section .section-title {
    position: relative;
    width: 200px;
    padding: 3px 26px 8px 26px;
    margin-left: auto;
    display: none;
}
.democratization .section .section-title:before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0;
    height: 72px;
    border-right: 11px solid #bbb3c6;
    border-bottom: 8px solid transparent;
}
.democratization .section .section-title .year {
    font-size: 20px;
    color: #666;
	font-family:NanumSquare;
	line-height:2;
}
.democratization .section .section-title .tit {
    font-size: 27px;
    font-weight: 500;
	line-height:1;
}
.democratization .section .list {
    display: flex;
    flex-wrap: wrap;
    position: relative;
    padding-left: 320px;
    margin: 70px -20px -8px 0;
    background: url('../images/bg_shelf.png') repeat-y 280px 0;
    background-size: 100% 256px;
}
.democratization .section .list.noYear { 
	margin-top:78px;
}
.democratization .section .list li.title {
    position: absolute;
    left: 0;
    top: -12px;
    width: auto;
    height: auto;
    padding: 0;
    background-image: none;
	margin:0 auto;
	text-align:center;
}
.democratization .section .list li.title .sub-info {
	padding:6px 20px 6px 42px;
	font-size:15px;
	border-bottom:2px solid #774e6b;
	color:#774e6b;
	border-radius:2px;
	display:inline-block;
	margin-top:8px;
	position:relative;
}
.democratization .section .list li.title .sub-info:before {
	content:'';
	background:url(../images/book-basic.svg) no-repeat center / cover;
	width:15px; 
	height:15px; 
	left:20px; 
	top:9px;
	filter:invert(35%) sepia(14%) saturate(1160%) hue-rotate(265deg) brightness(90%) contrast(86%);
	display:block;
	position:absolute;
}
.democratization .section .list li.title a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 260px;
    height: 260px;
    padding: 43px 0;
    text-align: center;
    color: #fff;
    border-radius: 50%;
    box-sizing: border-box;
}
.democratization .section .list li.title .category {
    position: relative;
    font-size: 16px;
}
.democratization .section .list li.title .category:before {
    content: '';
    display: block;
    width: 38px;
    height: 2px;
    margin: 0 auto 7px;
    background-color: rgba(255,255,255,.5);
}
.democratization .section .list li.title .name {
    margin: 15px 0 20px 0;
    font-size: 36px;
    font-family: 'NanumSquare';
    line-height: 40px;
    letter-spacing: -1.5px; 
    word-break: keep-all;
}
.democratization .section .list li.title .name.small {
    font-size: 30px;
    line-height: 34px;
}
.democratization .section .list li.title .name.big {
    font-size: 46px;
    line-height: 50px;
}
.democratization .section .list li.title .name.medium {
    font-size: 40px;
    line-height: 46px;
}
.democratization .section .list li.title .more {
    width: 39px;
    min-height: 39px;
    margin: 0 auto 5px;
    background: url('../images/ico_plus.png') no-repeat center center;
    background-size: 100% auto;
    -webkit-transition: -webkit-transform 0.1s;
    transition: transform 0.1s;
}
.democratization .section .list li.title a:hover .more {
    transform: scale(1.5);
}
.democratization .section .list li {
    width: 160px;
    height: 200px;
    padding: 10px 43px 8px 1px;
    margin: 37px 20px 19px 0;
    background: url('../images/bg_book.png') no-repeat center center;
    box-sizing: border-box;
    transition: transform 0.5s;
	position:relative;
}
.democratization .section .list li.pub:after {
    content:'출판예정';
	position:absolute;
	left:96px;
	top:-1px;
	width:30px;
	height:30px;
	padding:5px 6px 5px 4px;
	background:#774e6b;
	border-radius:50% 50% 50% 1px;
	color:#fff;
	font-size:12px;
	line-height:1.1;
	display:flex;
    align-items:center;
    text-align:center;
}
.democratization .section .list li.noupper {
    width: 7px;
    height: 131px;
    padding: 0;
    margin: 106px 112px 19px 63px;
    background-image:none;
	background:#e4e2e4;
    box-sizing: border-box;
    transition: none;
}
.democratization .section .list li.event {
    background-image: url('../images/bg_book_b.png');
}
.democratization .section .list li.back {
    background-image: url('../images/bg_book_p.png');
}
.democratization .section .list li.group {
    background-image: url('../images/bg_book_y.png');
}
.democratization .section .list li.upper {
    background-image: url('../images/bg_book_db.png');
}
.democratization .section .list li.event-sum {
    background-image: url('../images/bg_book_bg.png');
}
.democratization .section .list li.related {
    background-image: url('../images/bg_book_v.png');
}
.democratization .section .list li:not(.title):hover {
    transform: translateY(-15px);
}
.democratization .section .list li .photo {
    width: 100px;
    height: 100px;
    margin: 7px 7px 2px 7px;
    font-size: 0;
    line-height: 0;
    border-radius: 50%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
	opacity:.7;
    overflow: hidden;
}
.democratization .section .list li:hover .photo {
	opacity:1;
}
.democratization .section .list li .title {
    display: flex;
    flex-direction: column;
    justify-content: top;
    height: 75px;
    font-size: 16px;/**/
    font-weight: 500;
    line-height: 20px;
    text-align: center;
	padding:5px;
}

.democratization .section .list li .title:after {
    content: '';
    display: block;
    width: 39px;
    margin: 3px auto 0;
    padding-top: 0;
    font-size: 13px;
    line-height: 1;
    color: #707070;
    font-weight: 300;
}
.democratization .section .list li .title.bg:after {
    content: '배경';
}
.democratization .section .list li .title.group:after {
    content: '단체';
}
.democratization .section .list li .title.related:after {
    content: '연관 사건';
	width:auto;
}


/**********************************************************************
    멀티미디어
***********************************************************************/
.multimedia-list {
    display: flex;
    flex-wrap: wrap;
    gap: 26.5px;
}
.multimedia-list > li {
    width: calc(20% - 25px);
    margin-bottom: 40px;
}
.multimedia-list li .photo {
    padding-bottom: 96%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
	position:relative;
    border: 1px solid #bbb; /* 250912 */
}
.multimedia-list li .title-wrap {
    padding: 10px 0;
}
.multimedia-list li .title-wrap .title {
    margin-bottom: 5px;
    font-size: 17px;
    font-weight: 400;
    line-height: 20px;
    overflow : hidden;    
    text-overflow: ellipsis;    
    display: -webkit-box;    
    -webkit-line-clamp: 2;    
    -webkit-box-orient: vertical;
}
.multimedia-list li .title-wrap .category {
    display: flex;
	flex-wrap: wrap;
}
.multimedia-list li .title-wrap .category li {
    color: #666;
    font-size: 12px;
}
.multimedia-list li .title-wrap .category li + li:before {
    content: '>';
    padding: 0 3px;
}
.btn_play {
	position:absolute; 
	top:50%; 
	margin-top:-30px; 
	left:0; 
	right:0; 
	text-align:center; 
	display:block;
}
.btn_play img {
	width:60px !important;
	height:auto !important;;
}
.btn_play_s {
	position:absolute; 
	top:50%; 
	margin-top:-30px;
	left:0; 
	right:0; 
	text-align:center; 
	display:block;
}
.btn_play_s img {
	width:40px !important;
	height:auto !important;;
}

/**********************************************************************
    기사 상세
***********************************************************************/
#container .detail-wrap .content {
    display: flex;
    justify-content: space-between;
    position: relative;
    max-width: 1390px;
    margin: 35px auto 80px;
    padding: 0 15px 0 200px;
}
.detail-wrap h2.title {
    margin-bottom: 13px;/*221031*/
    margin-top: 50px;
	padding-right:80px;
    /* by odop 2023..11.15 한자 출력되지 않는 문제 관계로 주석처리 *//**/
    /* font-family: 'NanumSquare'; *//**/
    font-size: 42px;
    font-weight: 400;
    text-align: center;
	word-break:keep-all;
}
.detail-wrap h2.title.multi {
	font-size:34px;
	margin-bottom: 25px;/*221031*/
}
.detail-wrap h2.title .btn-detail {
    margin-top: -10px;
    color: #504764;
    font-size: 22px;
    vertical-align: top;
}

.detail-wrap .control {
    display: flex;
    justify-content: center;
    margin-bottom: 10px;
	padding-right:80px;
}
.detail-wrap .control button {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    min-width: 65px;
    padding: 5px 17px;
    font-size: 12px;
    border-right: 1px solid #dedede;
}
.detail-wrap .control button:first-child {
    border-left: 1px solid #dedede;
}
.detail-wrap .control button span {
    line-height: 12px;
}

/* 테이블 */
.table-title {
	margin: 75px 0 15px;
	text-align: center;
	font-size: 1rem; 
    color: #669933;
}
.table-wrap {
	padding: 0 0 20px; margin: 0 0 55px;
	overflow-x: auto;
}
.table-wrap table {
	border-top: 1px solid #7d8188;
	text-align: center;
	font-size: 1rem;
	width:100%;
}
.table-wrap thead th {
	padding: 18px 5px;
	background-color: #fafafa;
	width: 100px;
	border-bottom: 1px solid #e6e6e6;
	font-weight: 400; color: #000;
}
.table-wrap tbody th, 
.table-wrap tbody td {
	padding: 18px 5px;
	width: 100px;
	border-bottom: 1px solid #e6e6e6;
	font-weight: 400; color: #444;
}
.table-wrap thead th:not(:last-child), 
.table-wrap tbody th, 
.table-wrap tbody td:not(:last-child) {
	border-right: 1px solid #e6e6e6;
}

/* 토글메뉴 */
.detail-wrap .btn-dropdown {
    position: relative;
}
.detail-wrap .dropdown-menu {
    display: none;
    position: absolute;
    left: 50%;
    top: 45px;
    z-index: 100;
    width: 160px;
    padding: 10px 20px;
    background-color: #fff;
    border: 1px solid #e6e6e6;
    transform: translateX(-50%);
}
.detail-wrap .dropdown-menu:before {
    content: '';
    display: inline-block;
    position: fixed;
    left: calc(50% - 9px);
    top: -14px;
    width: 18px;
    height: 14px;
    background: url('../images/icon/ico-tooltip.png') no-repeat center top;
}
.detail-wrap .dropdown-menu li + li {
    border-top: 1px solid #e6e6e6;
}

/* info */
.detail-wrap #history-info.dropdown-menu {
    position: fixed;
    z-index: 101;
    width: 405px;
    padding: 20px 40px;
    transform: none;
    box-sizing: border-box;
}
.detail-wrap #history-info.dropdown-menu .arrow {
    display: inline-block;
    position: fixed;
    left: calc(50% - 9px);
    top: -14px;
    width: 18px;
    height: 14px;
    background: url('../images/icon/ico-tooltip.png') no-repeat center top;
}
.detail-wrap #history-info.dropdown-menu li {
    padding: 15px 0;
}
.detail-wrap #history-info.dropdown-menu dl {
    position: relative;
    padding-left: 80px;
    color: #313131;
    text-align: left;
}
.detail-wrap #history-info.dropdown-menu dl dt {
    position: absolute;
    left: 0;
    top: 0;
    min-width: 80px;
    font-size: 14px;
    line-height: 28px;
} 
.detail-wrap #history-info.dropdown-menu dl dd {
    font-size: 17px;
    line-height: 30px;
    font-weight: 400;
} 
.detail-wrap #history-info.dropdown-menu dl dd.title {
    color: #74629c;
}

/* sns */
.detail-wrap .dropdown-menu.sns-list li {
    padding: 0 25px;
    font-size: 13px;
    line-height: 47px;
    text-align: left;
}
.detail-wrap .dropdown-menu.sns-list li a {
    display: flex;
    align-items: center;
}
.detail-wrap .dropdown-menu.sns-list li i {
    width: 30px;
    margin: 0 10px;
    font-size: 20px;
    text-align: center;
}
.detail-wrap .dropdown-menu.sns-list li i.ico-facebook {
    color: #3b5998;
}
.detail-wrap .dropdown-menu.sns-list li i.ico-twitter {
    color: #2aa9e0;
}
.detail-wrap .dropdown-menu.sns-list li i.ico-kakao {
    width: 30px;
    height: 30px;
    background: url('../images/icon/ico-kakao.png') no-repeat center center;
}
.detail-wrap .dropdown-menu.sns-list li i.ico-url {
    color: #3b5998;
    font-size: 14px;
}

.detail-wrap .control i {
    font-size: 18px;
}
.detail-wrap .control i.ico-menu:before {
    content: '';
    width: 20px;
    height: 22px;
    margin-right: 10px;
    background: url('../images/icon/icon_menu.png') no-repeat left top;
    background-size: 100% auto;
}
.detail-wrap .control i.ico-txt-big,
.detail-wrap .control i.ico-txt-small {
    font-size: 12px;
}

.detail-wrap .lnb {
    position: absolute;
    left: 15px;
    top: -15px;
    min-width: 145px;
}
.detail-wrap .lnb.stiky {
    position: fixed;
    top: 63px;
    left: 50%;
    margin-left: -680px;
}
.detail-wrap .lnb > li {
    font-family: 'NanumSquare';
    font-size: 15px;
    font-weight: 400;
    line-height: 40px;
    letter-spacing: -0.5px;
}
.detail-wrap .lnb > li a {
    color: #000;
}
.detail-wrap .lnb > li.on > a {
    color: #cc0099;
}
.detail-wrap .lnb > li.on > a:after {
    content: '';
    display: inline-block;
    width: 31px;
    height: 12px;
    margin-left: 15px;
    background: url('../images/icon/ico_link.png') no-repeat left top;
}
.detail-wrap .lnb > li .sub-menu li {
    padding: 4px 0 4px 12px;
    font-size: 13px;
    line-height: 16px;
}
.detail-wrap .lnb > li .sub-menu li a:before {
    content: '-';
    display: inline-block;
    margin: 0 5px 0 -10px;
    color: #bfbfbf;
}

.detail-wrap .info {
    display: flex;
    justify-content: space-between;
    padding-top: 25px;
    border-top: 1px solid #777;
}
.detail-wrap .info .photo {
    /* by odop 2024.11.6 *//**/
    /* width:470px; *//**/
    width:420px;/**/
	max-width: calc(50% - 20px);
    margin-right: 20px;
    cursor: pointer;
	max-height:450px;
	min-height:250px;
}
.detail-wrap .info .photo .img-wrap {
    display:flex;
	align-items:center;
	justify-content: center;
	height:calc(100% - 42px);
    cursor: pointer;
	background:#ddd;
	border:1px solid #eee;
	border-width:1px 1px 0 1px;
    box-sizing: border-box;
}
.detail-wrap .info .photo .img-wrap img {
	max-width:100%;
	max-height:100%;
}
.detail-wrap .info .text {
    flex: 1 0 0;
    width: calc(50% - 20px);
    margin-left: 20px;
}
.detail-wrap .info .text dl {
    display: flex;
    padding: 7px 0;
    font-weight: 400;
    word-break: keep-all;
}
.detail-wrap .info .text dt {
    min-width: 125px;
	width: 125px;
    color: #767676;
    font-size: 14px;
    line-height: 20px;
	word-break: break-all; 
}
.detail-wrap .info .text dd {
    color: #000;
    font-size: 15px;
}
.detail-wrap .photo img {
    display: block;
}
.detail-wrap .photo .photo-info {
    display: flex;
    justify-content: space-between;
    line-height: 1.5;
    background-color: #fff;
    border: 1px solid #eee;
}
.detail-wrap .photo .photo-info .subject {
    padding: 10px 10px;
    font-size: 14px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
	width:100%;
}
.detail-wrap .photo .photo-info button {
    padding: 0 15px;
    font-size: 16px;
    border-left: 1px solid #eee;
}

.detail-wrap .section {
    padding: 70px 0 0 0;
}
.detail-wrap .section .title {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #cdcdcd;
    margin-bottom: 30px;
}
.detail-wrap .section .title > span {
    display: inline-block;
    padding: 0 30px;
    line-height: 45px;
    color: #fff;
    font-size: 19px;
    font-weight: 500;
    background-color: #504764;
}
.detail-wrap .section .title .btn-toggle {
    display: flex;
    align-items: center;
}
.detail-wrap .section .title .btn-toggle:before {
    content: '';
    display: inline-block;
    width: 8px;
    height: 2px;
    margin-right: 5px;
    background-color: #000;
    vertical-align: middle;
}
.detail-wrap .section .title .btn-toggle.change:before {
    content: '+';
    display: inline-block;
    width: auto;
    height: auto;
    color: #000;
    font-size: 17px;
    font-weight: 600;
    background-color: transparent;
}
.detail-wrap .section .txt {
    margin-bottom: 30px;
    color: #333;
    font-size: 17px;
    line-height: 31px;
    text-align: justify;
    /*overflow: hidden; 250725*/
	font-weight:400;
}
.detail-wrap .section .txt span {
    cursor: pointer;
}
.detail-wrap .section .txt sup {
    font-size: 12px;
}
.detail-wrap .section .txt:last-child {
    margin-bottom: 0;
}
.detail-wrap .section .sub-title {
    margin-bottom: 35px;
    font-size: 24px;
    font-weight: 500;
    line-height: 31px;
}
.detail-wrap .section .sub-title2 {
    margin-bottom: 20px;
    font-size: 19px;
    font-weight: 400;
    line-height: 31px;
}
.detail-wrap .section .txt + .sub-title {
    margin-top: 50px;
}
.detail-wrap .section .txt .photo {
    float: left;
    padding: 0 40px 40px 0;
    margin-top: 6px;
    font-size: 13px;
    line-height: 17px;
    color: #555;
    word-break: keep-all;
    box-sizing: border-box;
    cursor: pointer;
}
.detail-wrap .section .txt .photo.right {
    float: right;
    padding: 0 0 40px 40px;
}

.detail-wrap .section .list li {
	position:relative;
	padding-left:24px;
	margin-bottom:10px;
    color: #333;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.4;
}
.detail-wrap .section .list li:before {
    content: '';
	position:absolute;
	left:3px;
	top:13px;
    display: inline-block;
    width: 11px;
    height: 2px;
    margin: -2px 12px 0 0;
    background-color: #333;
    vertical-align: middle;
}
.detail-wrap .section .list li .file-down {
    margin-left: 10px;
}
.detail-wrap .section .list li .file-down i {
    width: 24px;
    height: 24px;
    line-height: 24px;
    text-align: center;
    color: #fff;
    font-size: 13px;
    background-color: #504764;
    border-radius: 50%;
}

.detail-wrap .section .photo-list {
    display: flex;
    flex-wrap: wrap;
}
.detail-wrap .section .photo-list li {
    position: relative;
    padding-bottom: 30px;
    margin: 20px 20px 20px 0;
    cursor: pointer;
}
.detail-wrap .section .photo-list li img {
	height:140px; width:auto;
	position:relative;
}
.detail-wrap .section .photo-list li .tit {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    color: #333;
    font-size: 14px;
    font-weight: 400;
    line-height: 30px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.detail-wrap .annotation dl {
    display: flex;
    align-items: flex-start;
}
.detail-wrap .annotation dl + dl {
    margin-top: 15px;
}
.detail-wrap .annotation dt {
    display: inline-block;
    min-width: 59px;
    padding: 0 10px;
    margin-right: 10px;
    color: #c647a6;
    line-height: 21px;
    background-color: #f7f7f7;
    border: 1px solid #d4d4d4;
    box-sizing: border-box;
}
.detail-wrap .annotation dd {
    color: #555;
    font-size: 14px;
    line-height: 21px;
}
.detail-wrap .annotation .btn-annotation {
    color: #c647a6;
    font-size: 12px;
}

.detail-info .tit {
    display: inline-block;
    padding: 0 10px;
    color: #fff;
    font-size: 17px;
    font-weight: 400;
    line-height: 28px;
    background-color: #9f5f8c;
}
.detail-info dl {
    display: flex;
    padding: 10px 0;
    font-weight: 400;
}
.detail-info dt {
    min-width: 130px;
    color: #666;
    font-size: 16px;
}
.detail-info dd {
    padding-left: 12px;
    color: #333;
    font-size: 16px;
    line-height: 25px;
    border-left: 1px solid #d7d7d7;
}

.article-wrap {
    min-width: 240px;
    padding: 0 0 0 30px;
}
.article-wrap .article {
    padding-bottom: 40px;
}
.article-wrap .article dt {
    display: flex;
    justify-content: space-between;
    padding: 0 5px;
    margin-bottom: 10px;
    color: #c540a4;
    font-size: 16px;
	font-weight:400;
    line-height: 40px;
    border-top: 1px solid #777;
    border-bottom: 1px solid #e1e1e1;
}
.article-wrap .article dt a {
    font-size: 12px;
}
.article-wrap .article dd {
    font-size: 15px;
    line-height: 32px;
	font-weight:400;
}
.detail-wrap .article dd:nth-child(6) ~ dd {
    display: none;
}
.article-wrap .article dd:before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 3px;
    margin: -3px 5px 0 8px;
    background-color: #353535;
    vertical-align: middle;
}

.article-wrap .article.collapsed, .article-wrap .article.collapsed dt {
    padding-bottom: 0;
    margin-bottom: 0;
    background: #ededed;
}

/**********************************************************************
    detail_multimedia
***********************************************************************/
.detail {
	width:100%;
}
#multi.photo-wrap .photo img {
     width:100%;
	 background:none;
	 border:none;
}
#multi.photo-wrap .multi-info {
    position: relative;
    padding: 20px 0;
}
#multi.photo-wrap .multi-info .title {
    padding-right: 180px;
    margin-bottom: 30px;
    font-size: 20px;
	font-weight:400;
}
#multi.photo-wrap .multi-info .lisence {
    position: absolute;
    right: 0;
    top: 20px;
}
#multi.photo-wrap .multi-info .list li {
    font-size: 14px;
    line-height: 18px;
}
#multi.photo-wrap .multi-info .list li span {
    display: inline-block;
}
#multi.photo-wrap .multi-info .list li span:after {
    content: '';
    display: inline-block;
    height: 13px;
    margin: 8px 6px 0 8px;
    border-left: 1px solid #cfcfcf;
}
#multi.photo-wrap .multi-info .list li a {
    color:#cc0099;
}

.embed-youtube {position:relative; width:100%; height:0; padding-bottom:56.25%;}
.embed-youtube iframe { position:absolute; top:0; left:0; width:100%; height:100%;}

/**********************************************************************
    Layer Popup
***********************************************************************/
#layerPop {
	position: absolute;
    left: 0;
    top: 0;
	display: none;
	width: 540px;
	padding: 15px 20px 20px 20px;
	background-color: #fff;
    box-shadow: 3px 3px 3px rgba(0,0,0,0.2);
    box-sizing: border-box;
}
#layerPop.c-orange {
    border-top: 5px solid #504764;
}
#layerPop.c-blue {
    border-top: 5px solid #5677c3;
}
#layerPop .top {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}
#layerPop .title {
    font-size: 19px;
}
#layerPop .txt {
    color: #515151;
    font-size: 14px;
    line-height: 19px;
}

/**********************************************************************
    기사상세 - 의견보내기 레이어
***********************************************************************/
.layerSendComment {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1000;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.8);
}
.layerSendComment .sendWrap {
    position: fixed;
    left: 50%;
    top: 5%;
    bottom: 5%;
    z-index: 900;
    width: 720px;
    padding: 35px 50px 50px 50px;
    background-color: #fff;
    box-sizing: border-box;
    transform: translateX(-50%);
    overflow-y: auto;
}
.layerSendComment .top {
    position: relative;
    margin-bottom: 20px;
    text-align: center;
}
.layerSendComment .top .title {
    margin-bottom: 20px;
    padding: 0 40px;
    font-size: 20px;
    font-weight: 500;
}
.layerSendComment .top .btn-close {
    position: absolute;
    right: 0;
    top: -10px;
    color: #a64a8b;
    font-size: 30px;
}
.layerSendComment .top .txt {
    color: #545454;
    font-size: 14px;
}
.layerSendComment .top .txt .ico-help {
    color: #8b577c;
}
.layerSendComment .top .txt .ico-help:before {
    margin-right: 5px;
}
.layerSendComment .top .data {
    margin: 20px 0 30px 0;
    line-height: 45px;
    font-size: 15px;
    border-top: 1px solid #e0e0e0;
    border-bottom: 1px solid #e0e0e0;
}
.layerSendComment .top .data span {
    color: #000;
}
.layerSendComment .top .data span:before {
    content: '\e915';
    font-family: 'icomoon';
    color: #8b577c;
    
}
.layerSendComment .top .data span:after {
    content: '';
    display: inline-block;
    height: 14px;
    margin: -1px 5px 0 7px;
    border-right: 1px solid #d1d2d5;
    vertical-align: middle;
}
.layerSendComment .top .certi p {
    margin-bottom: 10px;
    font-size: 14px;
}
.layerSendComment .top .certi .btn-certi {
    display: block;
    width: 306px;
    height: 41px;
    margin: 0 auto;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    line-height: 41px;
    background-color: #504764;
}
.layerSendComment .input-area dt {
    padding-top: 10px;
    line-height: 30px;
    font-size: 14px;
}
.layerSendComment .input-area input {
    width: 100%;
    height: 40px;
    color: #000;
    font-size: 13px;
}
.layerSendComment .input-area input::placeholder {
    color: #757575;
}
.layerSendComment .input-area input + input {
    border-top: 0;
}
.layerSendComment .input-area .select-wrap {
    width: 100%;
    text-align: left;
    background-color: #fff;
}
.layerSendComment .input-area .select-wrap ul {
    top: 38px;
    background-color: #fff;
}
.layerSendComment .input-area textarea {
    width: 100%;
    height: 135px;
    padding: 10px;
    font-size: 13px;
    background-color: #fff;
    border: 1px solid #e7e8e9;
    box-sizing: border-box;
    outline: 0;
}
.layerSendComment .input-area .input-file-wrap input[type="file"] {
	display: none;
}
.layerSendComment .input-area .input-file-wrap {
	position: relative;
	display: block;
	width: 100%;
	border: 1px solid #ddd;
	border-radius: 3px;
	box-sizing: border-box;
	cursor: pointer;
}
.layerSendComment .input-area .input-file-wrap input[type="text"] {
	position: relative; 
    z-index: -1;
	height: 44px;
	padding: 0 55px 0 15px;
	border: 0;
	background: transparent;
}
.layerSendComment .input-area .input-file-wrap:after {
	content: '\e90b';
	position: absolute; 
    top: 11px; 
    right: 12px;
    color: #c540a4;
    font-family: 'icomoon';
    font-weight: bold;
    font-size: 20px;
}
.layerSendComment .input-area .file-list {
    display: flex;
    gap: 0 15px;
    margin-top: 3px;
    color: #304b86;
    font-size: 13px;
}
.layerSendComment .input-area .file-list button {
    vertical-align: middle;
}
.layerSendComment .btn-send {
    display: block;
    width: 100%;
    height: 47px;
    margin: 40px auto 0;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    line-height: 47px;
    background-color: #504764;
}

/* 보내기 완료 */
.layerSendComment .sendComplete {
    display: none;
    position: fixed;
    left: 50%;
    top: 50%;
    z-index: 900;
    width: 720px;
    padding: 50px;
    background-color: #fff;
    box-sizing: border-box;
    transform: translate(-50%, -50%);
}
.layerSendComment .sendComplete .btn-close {
    position: absolute;
    right: 45px;
    top: 35px;
    color: #ee592d;
    font-size: 30px;
}
.layerSendComment .sendComplete .con {
    width: 480px;
    margin: 70px auto 90px;
}
.layerSendComment .sendComplete .title {
    margin-bottom: 20px;
    font-size: 24px;
    font-weight: 500;
    line-height: 36px;
}
.layerSendComment .sendComplete .txt {
    color: #616161;
    font-size: 16px;
    line-height: 28px;
}

/**********************************************************************
    Viewer
***********************************************************************/
#viewer {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1000;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.8);
}
#viewer .photo-wrap {
	position: absolute;
    top: calc(50% + 30px);
    left: 50%;
    max-width: 75%;
    transform: translate(-50%,-50%);
}
#viewer .photo-wrap.clip {
    width: 60%;
}
#viewer .photo-wrap .close {
    position: absolute;
    right: -70px;
    top: -70px;
    z-index: 1000;
    color: #fff;
    font-size: 30px;
}
#viewer .photo-wrap .btn-left {
    position: absolute;
    left: -100px;
    top: 50%;
    z-index: 1000;
    margin-top: -100px;
    color: #696b6d;
    font-size: 80px;
}
#viewer .photo-wrap .btn-right {
    position: absolute;
    right: -100px;
    top: 50%;
    z-index: 1000;
    margin-top: -100px;
    color: #696b6d;
    font-size: 80px;
}
#viewer .photo-wrap .photo {
    max-height: calc(85vh - 161px);
    overflow-y: hidden;
	background:#000;
	min-height: 300px;
    display: flex;
    flex-wrap: wrap;
    align-content: center;
}
#viewer .photo-wrap .photo img {
    display: block;
	margin:0 auto;
	max-height:100%;
	max-width:100%;
}
#viewer .photo-wrap .info {
    position: relative;
    padding: 20px;
    color: #fff;
    background-color: #1c1d1f;
}
#viewer .photo-wrap .info .title {
    padding-right: 180px;
    margin-bottom: 30px;
    font-size: 15px;
}
#viewer .photo-wrap .info .lisence {
    position: absolute;
    right: 20px;
    top: 20px;
}
#viewer .photo-wrap .info .list li {
    color: #bbb;
    font-size: 13px;
    line-height: 22px;
}
#viewer .photo-wrap .info .list li span {
    display: inline-block;
}
#viewer .photo-wrap .info .list li span:after {
    content: '';
    display: inline-block;
    height: 11px;
    margin: 0 6px 0 8px;
    border-left: 1px solid #575759;
}
#viewer .photo-wrap .info .list li a {
    color: #dd79c4;
}


/**********************************************************************
    의견보내기
***********************************************************************/
.tbl-wrap {
    margin-bottom: 20px;
}
.tbl-wrap table {
    width: 100%;
    border-top: 1px solid #aeaeae;
}
.tbl-wrap table th,
.tbl-wrap table td {
    padding: 14px 20px;
    color: #383838;
    font-size: 15px;
    text-align: center;
    border-bottom: 1px solid #e1e1e1;
}
.tbl-wrap table th {
    font-size: 14px;
    font-weight: 400;
}
.tbl-wrap table td.subject {
    width: 50%;
    text-align: left;
	font-weight:400;
	color:#000;
}
.tbl-wrap table .no {
    width: 7%;
    min-width: 40px;
}
.tbl-wrap table .type {
    width: 12%;
    min-width: 50px;
}
.tbl-wrap table .name,
.tbl-wrap table .date {
    width: 10%;
    min-width: 50px;
}
.tbl-wrap table .answer {
    width: 11%;
    min-width: 57px;
}


/**********************************************************************
    시기별보기
***********************************************************************/
.generation {
    margin-bottom: 0;
}
.generation .list {
    display: flex;
    flex-wrap: wrap;
    margin-right: -35px;
}
.generation .list > li {
    width: 25%;
    height: 276px;
    margin-bottom: 20px;
    box-sizing: border-box;
	transition: transform 0.5s;
}
.generation .list > li:not(.title):hover {
    transform: translateY(-15px);
}
.generation .list > li a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5.png') no-repeat left top;
}

.generation .list > li.upper a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5_db.png') no-repeat left top;
}
.generation .list > li.event a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5_b.png') no-repeat left top;
}
.generation .list > li.back a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5_p.png') no-repeat left top;
}
.generation .list > li.group a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5_y.png') no-repeat left top;
}

.generation .list > li.event-sum a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5_bg.png') no-repeat left top;
}

.generation .list > li.related a {
    display: flex;
    position: relative;
    height: 100%;
    margin: -21px 0 0 0;
    padding: 0 46px 0px 0;
    background: url('../images/bg_book5_v.png') no-repeat left top;
}

.generation .list > li a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2.png') no-repeat calc(100% + 19px) top;
}

.generation .list > li.upper a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2_db.png') no-repeat calc(100% + 19px) top;
}
.generation .list > li.event a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2_b.png') no-repeat calc(100% + 19px) top;
}
.generation .list > li.back a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2_p.png') no-repeat calc(100% + 19px) top;
}
.generation .list > li.group a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2_y.png') no-repeat calc(100% + 19px) top;
}

.generation .list > li.event-sum a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2_bg.png') no-repeat calc(100% + 19px) top;
}

.generation .list > li.related a:after {
    content: '';
    display: block;
    position: absolute;
    right: -10px;
    top: 0;
    bottom: 0;
    width: 57px;
    background: url('../images/bg_book2_v.png') no-repeat calc(100% + 19px) top;
}

.generation .list > li .left {
    width: 126px;
    padding-top: 46px;
    text-align: center;
}
.generation .list > li .photo {
    width: 101px;
    height: 101px;
	margin: 7px auto 2px;
    font-size: 0;
    line-height: 0;
    border-radius: 50%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
	opacity:.7;
    overflow: hidden;
}
.generation .list > li:hover .photo {
	opacity:1;	
}
.generation .list > li .title {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 15px 5px 0 5px;
    font-size: 19px;
    font-weight: 500;
    line-height: 20px;
    text-align: center;
}
.generation .list > li .title:after {
    content: '';
    display: block;
    width: 41px;
    margin: 10px auto 0;
    padding-top: 5px;
    font-size: 13px;
    line-height: 15px;
    color: #707070;
    font-weight: 300;
}
.generation .list > li .title.bg:after {
    content: '배경';
    border-top-color: #ff6666;
}
.generation .list > li .title.group:after {
    content: '단체';
    border-top-color: #f9a61a;
}
.generation .list > li .title.related:after {
    content: '연관사건';
    border-top-color: #f9a61a;
	width:auto;
}

.generation .list > li .right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: calc(100% - 142px);
    height: 100%;
    padding: 30px 0 25px;
    margin-left: 16px;
    box-sizing: border-box;
    background: url('../images/bg_book3_n.png') no-repeat 0 0;
    background-size: 100% 279px;
}
.generation .list > li .right .title {
    display: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.generation .list > li .txt {
    flex: 1 0 0;
    max-height: 111px;
    margin: 20px 0;
    color: #222;
    font-size: 15px;
    font-weight: 400;
    line-height: 22px;
    word-break: keep-all;
    overflow : hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
}
.generation .list > li .category {
    display: flex;
    overflow: hidden;
}
.generation .list > li .category li {
    color: #666;
    font-size: 12px;
    white-space: nowrap;
}
.generation .list > li .category li + li:before {
    content: '>';
    padding: 0 3px;
}
.generation .list > li .category li:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
}
.generation .list > li .info li {
    color: #666;
    font-size: 12px;
    line-height: 18px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.generation .list > li .info span {
    display: inline-block;
    margin-top: -0.5px;
    vertical-align: top;
}
.generation .list > li .info span:after {
    content: '';
    display: inline-block;
    height: 11px;
    margin: 0 4px;
    border-left: 1px solid #c8c9ca;
    vertical-align: middle;
}


/**********************************************************************
    SEARCH RESULT
***********************************************************************/
.search-result {
    padding: 0 10px;
    margin-bottom: 50px;
    font-family: 'NanumSquare';
    font-size: 30px;
    font-weight: 400;
	letter-spacing:-0.06em;
}
.search-result span {
    display: inline-block;
    margin-left: 25px;
    font-size: 24px;
}
.search-wrap {
    display: flex;
    justify-content: space-between;
}
.search-wrap .lnb {
    min-width: 274px;
    margin: 7px 47px 0 10px;
}
.search-wrap .lnb .top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 17px;
}
.search-wrap .lnb .top .btn-filter {
    color: #000;
    font-size: 18px;
    font-weight: 500;
}
.search-wrap .lnb .top .btn-filter i {
    display: inline-block;
    width: 32px;
    height: 32px;
    margin-right: 5px;
    line-height: 32px;
    color: #6e6e6e;
    font-size: 16px;
    background-color: #e1e1e1;
    border-radius: 3px;
}
.search-wrap .lnb .top .btn-reset {
    color: #cc0099;
    font-size: 14px;
    font-weight: 500;
}
.search-wrap .lnb dl.check-list {
    padding: 15px 0;
    border-top: 1px solid #c6c6c6;
}
.search-wrap .lnb dl.check-list dt {
    margin-bottom: 7px;
    font-size: 18px;
    font-weight: 600;
}
.search-wrap .lnb dl.check-list dd {
    color: #444;
    font-size: 15px;
    font-weight: 400;
    line-height: 25px;
}
.search-wrap .lnb dl.check-list dt input,
.search-wrap .lnb dl.check-list dd input {
    margin-right: 10px;
}
.search-wrap .lnb dl.check-list dt span,
.search-wrap .lnb dl.check-list dd span {
    display: inline-block;
    margin-left: 5px;
	font-family: 'NanumSquare';
}
.search-wrap .lnb dl.check-list:last-child {
    border: 0;
}
.search-wrap .lnb .btn-apply {
    display: block;
    width: 100%;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    line-height: 52px;
    text-align: center;
    background-color: #504764;
}
.search-wrap .lnb .btn-apply i {
    margin: -3px 15px 0 0;
    font-size: 11px;
    vertical-align: middle;
}

.search-wrap .content .search-list {
    margin-bottom: 20px;
    border-top: 1px solid #777;
}
.search-wrap .content .search-list li a {
    display: flex;
    padding: 20px 0;
    border-bottom: 1px solid #d2d2d2;
}
.search-wrap .content .search-list .photo {
    min-width: 160px;
    height: 110px;
    margin-right: 30px;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.search-wrap .content .search-list .title {
    color: #333;
    font-size: 21px;
    font-weight: 500;
}
.search-wrap .content .search-list .category {
    font-size: 14px;
}
.search-wrap .content .search-list .txt {
    margin-top: 12px;
    font-size: 15px;
    font-weight: 400;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

/**********************************************************************
    의견보내기 - 읽기
***********************************************************************/
.board-view {
    display: flex;
    justify-content: space-between;
}
.board-view .control-wrap.top .title {
    font-size: 28px;
    font-weight: 500;
}
.board-view .control-wrap.top .right {
    min-width: 0;
}
.board-view .board-content {
    margin-bottom: 20px;
    border-top: 1px solid #aeaeae;
}
.board-view .board-content li {
    display: flex;
    flex-wrap: wrap;
    padding: 13px 0 20px;
    font-weight: 400;
    border-bottom: 1px solid #dcdcdc;
}
.board-view .board-content li .tit {
    display: flex;
    align-items: center;
    color: #767676;
    font-size: 14px;
}
.board-view .board-content li .tit .con {
    margin-right: 50px;
}
.board-view .board-content li .con {
    color: #333;
    font-size: 15px;
}
.board-view .board-content li .con:before {
    content: '';
    display: inline-block;
    height: 12px;
    margin: -3px 10px 0 10px;
    border-left: 1px solid #d2d2d2;
    vertical-align: middle;
}
.board-view .board-content li.long-text {
    display: block;
    padding-bottom: 35px;
}
.board-view .board-content li.long-text .tit {
    margin-bottom: 20px;
}
.board-view .board-content li.long-text .tit:after {
    display: none;
}
.board-view .board-content li.long-text .con {
    font-size: 16px;
    line-height: 30px;
}
.board-view .board-content li.long-text .con:before {
    display: none;
}
.board-view .board-content li.file {
    display: block;
    padding: 13px 0;
    color: #74629c;
    font-size: 15px;
}
.board-view .board-content li.file i {
    padding: 0 15px;
    color: #74629c;
    font-size: 14px;
}

.board-view .rnb {
    min-width: 392px;
    margin: 130px 10px 0 47px;
    border-top: 1px solid #aeaeae;
}
.board-view .rnb li {
    padding: 21px 0;
    font-weight: 400;
    border-bottom: 1px solid #dcdcdc;
}
.board-view .rnb li .tit {
    color: #767676;
    font-size: 14px;
}
.board-view .rnb li .con {
    margin-top: 10px;
    color: #333;
    font-size: 16px;
}


/**********************************************************************
    BTN
***********************************************************************/
.btn-text {
	display: inline-block;
    padding: 0 24px;
	line-height: 31px;
	text-align: center;
	color: #000;
	font-size: 15px;
    font-weight: 400;
	background-color: #fff;
	cursor: pointer;
	vertical-align: middle;
	border: 1px solid #d5d6d9;
    border-radius: 2px;
}

/* paging */
#paging { 
	text-align: center; 
	padding: 10px 0 20px 0; 
	font-size: 14px;
	color: #888;
}
#paging select {
	height: 33px;
	margin: 0 10px;
	line-height: 33px;
	border: 1px solid #d3d4d7;
	border-radius: 3px;
}
#paging a {
	display: inline-block; 
	width: 35px; 
	height: 33px;
	padding: 0 5px; 
	color: #8f8f8f; 
	line-height: 33px;
	font-size: 13px; 
	text-align: center;
	border: 1px solid #dbdcdf;
	box-sizing: border-box;
	vertical-align: middle;
}
#paging a.now {
	color: #606060;
	border-color: #9fa0a2;
}
#paging a.first {
	background: url('../images/icon/arrow_first.gif') no-repeat center top;
}
#paging a.prev {
	margin-right: 3px;
	background: url('../images/icon/arrow_prev.gif') no-repeat center top;
}
#paging a.next {
	margin-left: 3px;
	background: url('../images/icon/arrow_next.gif') no-repeat center top;
}
#paging a.last {
	background: url('../images/icon/arrow_last.gif') no-repeat center top;
}

.mt50 { margin-top: 50px !important; }

.stLock {color:#993366 !important; font-size:.8em; position:relative; display:inline-block; padding-left:17px;}
.stLock:after {content:''; position:absolute; top:-2px; left:0; width:13px; height:17px; background:url(../images/icon/ico_lock.svg) no-repeat; background-size:13px auto;}
.stAnswer {color:#993366 !important; font-size:.8em; position:relative; display:inline-block; padding-left:23px;}
.stAnswer:after {content:''; position:absolute; top:3px; left:0; width:18px; height:14px; background:url(../images/icon/ico_Answer.svg) no-repeat; background-size:18px auto;}
.c-danger {color:#cc6600;}
.c-dblue {color:#003399;}
.c-location {margin:0 auto; text-align:center; padding-right:80px; margin-bottom:27px;}
.c-location span {font-size:.9rem; font-weight:200; display:inline-block; padding-right:12px; margin-right:7px; position:relative;}
.c-location span:after {content:''; position:absolute; right:0; top:7px; width:4px; height:8px; background:url(../images/icon/ico_loc.svg); background-size:4px auto;}
.c-location span:last-child:after {display:none;}

.btn-copyright {color:#fff; background:#3399ff; padding:12px 10px 12px 40px; border-radius:4px; font-weight:500; font-size:14px; display:block; position:relative;}
.btn-copyright:before {content:''; position:absolute; display:block; left:10px; top:10px; width:25px; height:25px; background:url(../images/icon/ico_copyright.svg) center / cover;}
.btn-copyright:hover {background:#0660bb; color:#fff; transition:all 0.3s;}

.btn-bbs {background:#774e6b; color:#fff; padding:12px 20px; border-radius:4px; margin:0 0 0 15px; font-size:14px; line-height:1; font-weight:500;}
.btn-bbs:hover {color:#deb9d3; transition:all 0.3s;}

.f-mid {font-size:15px; line-height:1.6;}
.f-link {color:#8066b8; font-size:17px; font-weight:500;}
.f-link:hover {color:#711c5c; transition:all 0.3s;}

.entry-section { margin-bottom:100px;}

@media only screen and (max-width : 1240px){
	.c-location {padding-right:0;}
}

@media only screen and (max-width : 767px){
	.c-location {padding-left:17px; margin-bottom:17px;}
	.c-location span {font-size:.7rem;}
	.c-location span:after {top:5px;}
	
	
	.control-wrap .paging { display:block;}
	.btn-copyright {padding:10px 10px 10px 45px; font-size:13px; margin-bottom:15px;}
	.btn-copyright:before {top:10px; width:22px; height:22px;}
	
	.btn-bbs {padding:14px 20px; margin:15px 0 0 0; font-size:14px; display:block; text-align:center;}

	.f-mid {font-size:12px; line-height:1.6;}
	.f-link {font-size:14px;}
	.img-copyright {height:50px;}
	
}

.copyright-spe {margin-top:50px; display:block; color:#333; border:3px solid #e1e1e1; padding:30px 40px;  border-radius:25px; background:#fff; font-size:16px; line-height:1.8; letter-spacing:0; word-break:keep-all; display:block;}
.copyright-spe .copy-title {font-weight:600; color:#8066b8; font-size:20px; margin-bottom:14px;}

@media only screen and (max-width : 1024px){
	.copyright-spe {padding:30px 20px; font-size:14px;}
	.copyright-spe .copy-title {font-size:18px; margin-bottom:14px;}
}

@media only screen and (max-width : 767px){
	.copyright-spe {margin-top:30px; padding:20px 10px; font-size:12px;}
	.copyright-spe .copy-title {font-size:15px; margin-bottom:10px;}
}

/*imagepopup*/
.imagepopup {position:fixed; top:80px; left:15px; max-width:550px; z-index:5001; background:#ddd;}/**/
.imagepopup .popup-body a {display:block;}
.imagepopup .popup-body a img {display:block; max-width:calc(100% - 18px); margin:9px 9px 0;} 
.imagepopup .popup-foot {display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; background:#ddd; padding:20px;}
.imagepopup .popup-foot > div {display:flex; flex-wrap:wrap; align-items:center;}	
.imagepopup .popup-foot > div .check-box {margin-right:20px;}
.imagepopup .popup-foot > div .check-box:last-of-type {margin:0;}                 
.imagepopup .popup-foot > div label {color:#666; font-size:14px;}
.imagepopup .popup-foot > div label input {position:relative; top:1px; appearance:auto; -webkit-appearance:auto; margin-right:3px;}
.imagepopup .popup-foot > a {display:block; font-size:0; width:15px; height:15px; background:url('../images/icon_close.svg') no-repeat center / cover; opacity:0.6;}

@media (max-width:580px){
    .imagepopup {left:10px; top:70px; max-width:calc(100% - 20px);}
    .imagepopup .popup-foot {padding:10px;}
    .imagepopup .popup-foot > div label {font-size:11px;}
    .imagepopup .popup-foot > a {width:13px; height:13px;}
    .imagepopup .popup-foot > div label input {top:-2px;}
}
/*imagepopup*/

/*popup 250912*/
.popup-wrap {display: flex; flex-wrap: wrap; flex-direction: row-reverse; gap: 10px 10px; position:fixed; top:48px; left:10px; z-index:5001;}
.popup-new {box-shadow:12px 12px 27px rgba(0,0,0,0.38); background-color: #fff;}
.popup-new .box {position:relative; display:flex;}
.popup-new .box .popup-body {display:flex; flex-wrap: wrap; max-width: 460px; border: 8px solid #fff;}
.popup-new .box .popup-body .imgWrap {display:flex; position:relative; width:100%; margin-bottom: 8px;} 
.popup-new .box .popup-body .imgWrap .img {display:flex; position:relative; width:100%; height:463px; overflow: hidden; } 
.popup-new .box .popup-body .imgWrap .img::after {content: ''; position: absolute; inset: 0; background-color: rgba(37,37,73,.6);}
.popup-new .box .popup-body .imgWrap .img img {object-fit:cover; width:100%; position: relative;}
.popup-new .box .popup-body .imgWrap .imgCon {position:absolute; width: 100%; margin: 0 auto; text-align: center; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.popup-new .box .popup-body .imgWrap .imgCon .title {font-size:30px; line-height:1.3; padding:0 10% 30px; color: #fff; text-align:center; font-weight:700; word-break: keep-all;}
.popup-new .box .popup-body .imgWrap .imgCon .sub-title {font-size: 18px; color: #fff; padding:0 10% 40px;}
.popup-new .box .popup-body .imgWrap .imgCon .btn-wrap {display: flex; justify-content: center;}
.popup-new .box .popup-body .imgWrap .imgCon .btn-wrap a.view-more {font-size:14px; padding: 10px 10px; border-radius:20px; background: #ffdd18; display: flex; font-weight: 800;}
.popup-new .box .popup-body .imgWrap .imgCon .btn-wrap a.view-more:hover {background: #ff9900; transition: .5s;}
.popup-new .box .popup-body .conWrap {width:100%; background-color: #f9eadc; padding:30px 27px;}
.popup-new .box .popup-body .conWrap .con p {font-size:16px; font-weight: 500; line-height:1.7; color:#111; word-break: keep-all;}
.popup-new .box .popup-body .conWrap .con .logo {width: 100%; text-align: center; margin: 15px 0 0;}
.popup-new .box .popup-body .conWrap .con .logo img {width: 100px;}

.popup-spe01 {box-shadow:12px 12px 27px rgba(0,0,0,0.38); background-color: #3f3f7c;}
.popup-spe01 .box {position:relative; display:flex;}
.popup-spe01 .box .popup-body {display:flex; flex-wrap: wrap; max-width: 511px; }
.popup-spe01 .box .popup-body .conWrap {width:100%; padding:23px 23px; position: relative;}
.popup-spe01 .box .popup-body .conWrap dl {display: flex; flex-wrap: wrap; align-items: center; gap: 4px 10px;}
.popup-spe01 .box .popup-body .conWrap dl dt {display: flex; align-items: center; justify-content: center; width: 85px; height: 31px; background-color: #232338; color: #fff; font-size: 12px; font-weight: 400; border-radius: 15px;}
.popup-spe01 .box .popup-body .conWrap dl dd {display: flex; width: calc(100% - 95px); font-size: 15px; color: #fff; line-height: 1.2; font-weight: 400;}
.popup-spe01 .box .popup-body .conWrap dl dd a {font-size: inherit; line-height: inherit; color: #fff; text-decoration: underline;}
.popup-spe01 .box .popup-body .conWrap .gift {position: absolute; left: 395px; top: 130px;}
.popup-spe01 .box .popup-body .conWrap .qrWrap {display: flex; align-items: flex-end; gap: 0 10px; margin-top: 36px;}
.popup-spe01 .box .popup-body .conWrap .qrWrap .qr {display: flex; justify-content: center; width: 85px;}
.popup-spe01 .box .popup-body .conWrap .qrWrap .qr img {width: 65px;}
.popup-spe01 .box .popup-body .conWrap .qrWrap .con {display: flex; flex-wrap: wrap; width: calc(100% - 95px); font-size: 14px; color: #fff; line-height: 1.3; font-weight: 400; position: relative;}
.popup-spe01 .box .popup-body .conWrap .qrWrap .con::before {content: ''; width: 30px; height: 21px; margin-bottom: 7px; display: block; background: url(../images/ico_hand.svg) no-repeat left / cover; filter: invert(100%);}

.popup-foot {position:absolute; right:15px; top:15px; display:flex; flex-wrap:wrap;}
.popup-foot a.close_today {display:block; height:26px; line-height:26px; padding:0 12px; font-size:12px; margin-right:5px; font-weight:100; color:#fff; background:#3f3f7c; border-radius:14px; text-decoration:none; border: 1px solid rgba(255,255,255,.2);}
.popup-foot a.close {display:block; height:26px; width:26px; font-size:0; background:#3f3f7c url('../images/btn-notice-close.svg') no-repeat center; background-size:11px auto; border: 1px solid rgba(255,255,255,.2); border-radius:50%;}

@media (max-width:1024px){
    .popup-wrap {display: block;}
    .popup-new {position: fixed; top: 40px; left: 120px;}
    .popup-spe01 {position: fixed; top: 20px; left: 20px;}
}

@media (max-width:620px){
    .popup-new {position: fixed; top: 10px; left: 10px; max-width: 380px;}
    .popup-spe01 {position: fixed; top: 50px; left: 10px; max-width: 380px;}
}

@media (max-width:530px){
    .popup-spe01 {position: fixed; top: 50px; left: 10px; right: 10px;}    
    .popup-spe01 .box .popup-body .conWrap {padding:23px 10px;}
    .popup-spe01 .box .popup-body .conWrap dl {gap: 1px 7px;}
    .popup-spe01 .box .popup-body .conWrap dl dt {width: 70px; height: 31px; font-size: 11px;}
    .popup-spe01 .box .popup-body .conWrap dl dd {width: calc(100% - 77px); font-size: 13px;}
    .popup-spe01 .box .popup-body .conWrap .gift {display: none;}
    .popup-spe01 .box .popup-body .conWrap .qrWrap {gap: 0 7px; margin-top: 20px;}
    .popup-spe01 .box .popup-body .conWrap .qrWrap .qr {width: 70px;}
    .popup-spe01 .box .popup-body .conWrap .qrWrap .qr img {width: 70px;}
    .popup-spe01 .box .popup-body .conWrap .qrWrap .con {width: calc(100% - 77px); font-size: 12px;}
    .popup-spe01 .box .popup-body .conWrap .qrWrap .con::before {height: 21px; margin-bottom: 5px;}
}

@media (max-width:530px){
    .popup-new {position: fixed; top: 10px; left: 10px; right: 10px;} 
    .popup-new .box .popup-body {border: 4px solid #fff;}
    .popup-new .box .popup-body .imgWrap {margin-bottom: 4px;} 
    .popup-new .box .popup-body .imgWrap .img {height:320px;}
    .popup-new .box .popup-body .imgWrap .imgCon .title {font-size:20px; padding:0 5% 20px;}
    .popup-new .box .popup-body .imgWrap .imgCon .sub-title {font-size: 14px; padding:0 5% 20px;}
    .popup-new .box .popup-body .imgWrap .imgCon .btn-wrap a.view-more {font-size:12px; padding: 8px 10px; }
    .popup-new .box .popup-body .conWrap {padding:20px 10px;}
    .popup-new .box .popup-body .conWrap .con p {font-size:14px;}
    .popup-new .box .popup-body .conWrap .con .logo {margin: 10px 0 0;}
    .popup-new .box .popup-body .conWrap .con .logo img {width: 70px;}
}

/*popup 250912*/

/**********************************************************************
    반응형 CSS
***********************************************************************/

@media only screen and (max-width : 1600px){

    #header > .inner {
        padding:0 20px;
    }
    #header.stiky .util-menu {
        display: none;
    }

}

/* only 시기별보기 화면 */
@media only screen and (max-width : 1400px){
    .detail-wrap .lnb.stiky {
        left: 15px;
        margin-left: 0;
    }
}

/* only 시기별보기 화면 */
@media only screen and (max-width : 1345px){
    .generation .list > li {
        width: 33.333%;
    }
    .generation .list > li a {
        padding: 0 50px 0px 0;
    }
    .generation .list > li a:after {
        width: 60px;
    }
}

@media only screen and (max-width : 1240px){
    .mo {
        display: block;
    }
        
    #header {
        z-index: 900;
        background: #3f3f7c;
    }
    #header > .inner {
        padding: 0;
        display: block;
    }
    #header .logo {
        width: 90px;
        height: 75px;
        margin-left: 20px;
        background: url(../images/logo_w.svg) center no-repeat;
        background-size: 90px auto;
    }
    #header.sub .logo {
        width: 90px;
        height: 62px;
        margin-left: 20px;
    }
    #header.stiky .logo {
        padding: 0;
        height: 59px;
        width: 80px;
        background-size: 80px auto;
    }
    #header.stiky .logo img {
        height:33px;
        padding: 8px 0 9px 0;
    }
    #header.stiky #gnb .menu > li a {
        color: #161616;
        font-weight: 400;
        font-size: 15px;
    }
    #header.stiky .search-area .input-area .ico-search {
        color: #161616;
        font-size: 16px;
    }
    #header #gnb {
        display: none;
    }
    #header .util-menu {
        display: none;
    }
    #header .search-area {
        display: none
    }

    #header .btn-m {
        display: inline-block;
        position: absolute;
        right: 22px;
        top: calc(50% - 12px);
        border: 0;
        background-color: transparent;
    }
    #header .btn-m li {
        display: inline-block;
    }
    #header .btn-m li + li {
        margin-left: 40px;
    }
    #header .btn-m li button {
        width: 24px;
        height: 24px;
        color: #fff;
        font-size: 15px;
        border: 0;
        background-color: transparent;
    }
    #header .btn-m li button.btn-menu:before {
        content: '\e916';
        font-family: 'icomoon';
    }
    #header .btn-m li button.btn-search:before {
        content: '\e919';
        font-family: 'icomoon';
    }
    #header .btn-m li button.btn-util:before  {
        content: '\e923';
        font-family: 'icomoon';
    }
    #header .btn-m li button.close:before {
        content: '\e904';
        font-family: 'icomoon';
    }

    #header #gnb {
        top: 100% !important;
        left: 0 !important;
        bottom: initial;
        z-index: 900;
        width: 100%;
        background-color: #fff;
    }
    #header #gnb .sub-menu .imp {
        background: rgba(0, 0, 0, .1);
        padding: 2px 10px;
        margin: 5px 0;
        border-radius: 8px;
        text-align: left;
        font-size: 14px;
    }
    #header #gnb .menu {
        background-color: #fff;
    }
    #header #gnb .menu > li, #header.sub #gnb .menu > li {
        float: none;
        margin: 0 20px;
        padding: 0 12px;
        font-size: 15px;
        line-height: 42px;
        font-weight: 300;
        color: #333;
        border-bottom: 1px solid #eaeaea;
    }
    #header #gnb .menu > li:after {
        content: '';
        display: inline-block;
        position: absolute;
        right: 10px;
        top: 11px;
        width: 24px;
        height: 24px;
        background: url('../images/icon/arrow_down.png') no-repeat center center;
    }
    #header #gnb .menu > li.no-sub:after {
        display: none;
    }
    #header #gnb .menu > li.active:after {
        background: url('../images/icon/arrow_up.png') no-repeat center center;
    }
    #header #gnb .menu > li a {
        color: #333;
    }
    #header #gnb .sub-menu {
        display: none;
        position: static;
        width: 100%;
        padding: 0;
        background-color: #fff;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        border-top: 1px solid #eaeaea;
    }
    #header #gnb .sub-menu > li {
        margin: 0;
        padding: 0 25px;
        line-height: 32px;
        border-bottom: 1px solid #eaeaea;
    }
    #header #gnb .sub-menu > li a {
        color: #000;
        font-size: 15px;
        font-weight: 400;
        padding: 5px 0;
    }
    #header.stiky #gnb .sub-menu ul > li a,
    #header #gnb .sub-menu ul > li a {
        padding: 0 0 15px 20px;
        line-height: 1.2;
        font-size: 13px;
    }
    #header #gnb .sub-menu ul > li a:before {
        filter: none;
    }
    #header #gnb .sub-menu ul > li > a:hover,
    #header #gnb .sub-menu > li > a:hover {
        color: #ee582c;
    }

    #header .util-menu {
        right: 0 !important;
        top: 100% !important;
        z-index: 900;
        width: 100%;
        background-color: #fff;
    }
    #header .util-menu li {
        display: block;
        margin: 0 20px;
        padding: 0 40px 0 12px;
        font-size: 15px;
        line-height: 42px;
        font-weight: 500;
        color: #333;
        border-bottom: 1px solid #eaeaea;
        position: relative;
    }
    #header .util-menu li:after {
        content: '';
        display: block;
        position: absolute;
        right: 0;
        top: 11px;
        width: 16px;
        height: 16px;
        background: url(../images/ico_outlink.svg) center no-repeat;
        background-size: auto 100%;
        opacity: .7;
    }
    #header .util-menu li a { 
        color: #333;
    }
    #header .util-menu li + li:before {
        display: none;
    }

    #shadow_m {
        display: none;
        position: fixed;
        left: 0;
        top: 0;
        z-index: 800;
        width: 100%;
        height: 100%;
        background-color: rgba(54, 58, 64, 0.5);
        backdrop-filter: blur(3px);
    }

    #header .header-left {
        display: block;
    }
    #header .search-area {
        z-index: 900;
        width: 100%;
        height: 100px;
        background-color: #fff;
        margin-left: 0;
    }
    #header .search-area .input-area {
        width: 80%;
        height: 46px;
        padding: 0 15px;
        margin: 0;
        border-color: #c0c7d6;
        left: 10%;
        top: 27px;
    }
    #header .search-area .input-area .text {
        color: #333;
    }

    .btn-top {
        width: 40px;
        height: 40px;
        background-size: 14px auto;
    }

    .layer_notice {
        width: 100%;
        padding: 22px 15px;
        box-sizing: border-box;
    }
    .layer_notice .control {
        right: 15px;
        font-size: 10px;
    }
    .layer_notice .control input {
        margin: -1px 5px 0 0;
        vertical-align: middle;
        border: 1px solid #ccc;
    }
    .layer_notice .control .btn-close {
        width: 18px;
        height: 18px;
        margin-left: 15px;
        background-size: 100% auto;
    }
    .layer_notice .title {
        margin-bottom: 7px;
        font-size: 17px;
    }
    .layer_notice .txt {
        font-size: 12px;
        line-height: 16px;
    }

    .democratization {
        padding: 0 0 50px 22px;
    }

    .democratization .section .section-title {
        width: 140px;
        padding: 3px 16px 4px 16px;
    }
    .democratization .section .section-title:before {
        height: 55px;
        border-right: 8px solid #f16339;
        border-bottom: 5px solid transparent;
    }
    .democratization .section .section-title .year {
        font-size: 15px;
    }
    .democratization .section .section-title .tit {
        font-size: 21px;
    }

    .democratization .section .list {
        padding: 0 0 2px 100px;
        margin: 60px -20px -8px 0;
        background: url('../images/bg_shelf.png') repeat-y 80px 0;
        background-size: 100% 190px;
    }
    .democratization .section .list + .list.noYear { 
        margin-top:58px;
    }
    .democratization .section .list + .list {
        margin-top: 10px;
    }
    .democratization .section .list li.title {
        width: auto;
        height: auto;
        padding: 0;
        background-image: none;
    }
    .democratization .section .list li.title.pub-t {
        top:-35px;
    }
    .democratization .section .list li.title .sub-info {
        margin-top:0;
        border:none;
        font-size:13px;
    }
    .democratization .section .list li.title .sub-info:before {
        width:13px; 
        height:13px;
    }
    .democratization .section .list li.title a {
        width: 178px;
        height: 178px;
        padding: 23px 0;
    }
    /* by odop 2024.6.27
    .democratization .section .list li:nth-child(2) {
        margin-left: 100px;
    }*/
    .democratization .section .list li.title + li:nth-child(2) {
        margin-left: 100px;
    }

    .democratization .section .list li.title .category {
        font-size: 11px;
    }
    .democratization .section .list li.title .category:before {
        width: 26px;
        height: 1px;
    }
    .democratization .section .list li.title .name {
        margin: 15px 0 10px 0;
        font-size: 24px;
        line-height: 30px;
    }
    .democratization .section .list li.title .name.small {
        font-size: 21px;
        line-height: 24px;
    }
    .democratization .section .list li.title .name.big {
        font-size: 31px;
        line-height: 36px;
    }
    .democratization .section .list li.title .name.medium {
        font-size: 24px;
        line-height: 30px;
    }
    .democratization .section .list li.title .more {
        width: 26px;
        min-height: 26px;
        margin: 0 auto 3px;
    }
    .democratization .section .list li.title a:hover .more {
        transform: scale(0);
    }

    .democratization .section .list li {
        width: 120px;
        height: 150px;
        padding: 10px 34px 8px 3px;
        margin: 27px 10px 13px 0;
        background-size: 100% auto;
        box-sizing: border-box;
        transition: transform 0.5s;
    }
    .democratization .section .list li.pub:after {
        left:76px;
        top:-1px;
        width:24px;
        height:24px;
        padding:5px 6px 5px 4px;
        font-size:11px;
    }
    .democratization .section .list li.noupper {
        width: 6px;
        height: 100px;
        margin: 76px 79px 19px 45px;
    }
    .democratization .section .list li .title {
        height: 54px;
        font-size: 13px;
        line-height: 15px;
    }
    .democratization .section .list li:not(.title):hover {
        transform: translateY(0);
    }
    .democratization .section .list li .photo {
        width: 77px;
        height: 77px;
        margin: 3px 3px 0 3px;
    }
    .democratization .section .list li .title:after {
        width: 31px;
        margin: 5px auto 0;
        padding-top: 2px;
        font-size: 10px;
        line-height: 12px;
        border-top: none;
    }

    .multimedia-list > li {
        width: calc(25% - 20px);
        margin-bottom: 30px;
    }
    .multimedia-list li .title-wrap {
        padding: 5px 0;
    }
    .multimedia-list li .title-wrap .title {
        margin-bottom: 5px;
        font-size: 16px;
        line-height: 18px;
    }
    .multimedia-list li .title-wrap .category li {
        font-size: 10px;
    }

    #container.sub {
        margin: 25px auto 60px;
    }
    #container .location {
        margin-bottom: 40px;
    }
    #container .location li {
        font-size: 27px;
    }

    #container .detail-wrap .content {
        display: block;
        padding: 0 15px;
    }
    .detail-wrap .lnb {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        gap: 4px;
        position: static;
        margin-bottom: 35px;
    }
    .detail-wrap .lnb.stiky {
        position: static;
    }
    .detail-wrap .lnb > li {
        font-size: 14px;
        background-color: #fff;
        border: 1px solid #e8e8e8;
    }
    .detail-wrap .lnb > li a {
        display: block;
        position: relative;
        padding: 0 10px;
        color: #000;
    }
    .detail-wrap .lnb > li.on a:after,
    .detail-wrap .lnb > li a:after {
        content: '';
        display: inline-block;
        position: absolute;
        right: 10px;
        top: 7px;
        width: 24px;
        height: 24px;
        margin: 0;
        background: url('../images/icon/ico-arrow-down.png') no-repeat center center;
    }
    .detail-wrap .lnb > li .sub-menu {
        display: none;
    }
    .detail-wrap .section {
        padding: 50px 0 0 0;
    }
    .detail-wrap .section .title {
        margin-bottom: 25px;
    }
    .detail-wrap .section .txt {
        margin-bottom: 30px;
        font-size: 16px;
        line-height: 29px;
    }

    .detail-wrap .section .list li {
        font-size: 16px;
    }

    .detail-info dt {
        font-size: 16px;
    }
    .detail-info dd {
        font-size: 16px;
    }

    .detail-wrap .annotation dt {
        min-width: 50px;
        padding: 0 5px;
        line-height: 17px;
        font-size:12px;
    }

    .detail-wrap .annotation dd {
        font-size: 12px;
        line-height: 17px;
    }

    .article-wrap {
        padding: 40px 10px 0 10px;
    }
    .article-wrap .article {
        padding-bottom: 40px;
    }
    .article-wrap .article:last-child {
        padding-bottom: 0;
    }


    #viewer .photo-wrap {
        width: 65%;
    }
    #viewer .photo-wrap .photo img {
        max-width: 100%;	
    }
    #viewer .photo-wrap .info .lisence img {
        width: 120px;
    }
    #viewer .photo-wrap .info .title {
        font-size: 14px;
    }

    .tbl-wrap table th,
    .tbl-wrap table td {
        padding: 13px 15px;
        font-size: 14px;
    }
    .tbl-wrap table th {
        font-size: 11px;
    }

    .search-result {
        margin-bottom: 35px;
        font-size: 25px;
    }
    .search-result span {
        margin-left: 25px;
        font-size: 20px;
    }
    .search-wrap {
        display: block;
    }
    .search-wrap .lnb {
        display: none;
    }
    .search-wrap .content .search-list li {
        padding: 15px 0;
    }
    .search-wrap .content .search-list .photo {
        min-width: 136px;
        height: 93px;
        margin-right: 20px;
    }
    .search-wrap .content .search-list .title {
        font-size: 17px;
    }
    .search-wrap .content .search-list .category {
        font-size: 12px;
    }
    .search-wrap .content .search-list .txt {
        margin-top: 8px;
        font-size: 12px;
    }

    .board-view .control-wrap.top .title {
        font-size: 30px;
    }
    .board-view .board-content li {
        padding: 10px 0 15px;
    }
    .board-view .board-content li .tit {
        font-size: 11px;
    }
    .board-view .board-content li .tit .con {
        margin-right: 40px;
    }
    .board-view .board-content li .con {
        font-size: 13px;
    }
    .board-view .board-content li .con:before {
        height: 10px;
        margin: -1px 7px 0 7px;
    }
    .board-view .board-content li.long-text {
        padding-bottom: 25px;
    }
    .board-view .board-content li.long-text .tit {
        margin-bottom: 10px;
    }
    .board-view .board-content li.long-text .con {
        font-size: 14px;
        line-height: 25px;
    }
    .board-view .board-content li.file {
        padding: 10px 0;
        font-size: 12px;
    }
    .board-view .rnb {
        display: none;
    }

    .generation {
        margin-bottom: 40px;
    }

    .btn-text {
        padding: 0 20px;
        line-height: 26px;
        font-size: 13px;
    }

    .control-wrap .paging {
        font-size: 11px;
    }

    .detail-wrap h2.title, .detail-wrap h2.title.multi, .detail-wrap .control {
        padding-right:0;
    }

} /* 1240 end */


/* only 시기별보기 화면 */
@media only screen and (max-width : 1024px){

    .generation {
        margin-bottom: 20px;
    }
    .generation .list {
        margin-right: -10px;
    }
    .generation .list > li {
        width: 50%;
        margin-bottom: 0;
    }
    .generation .list > li a {
        padding: 0 30px 0px 0;
    }
    .generation .list > li a:after {
        right: -30px;
    }

    .gallery_m_list {
        width: 210px;
        padding-right: 20px;
        margin-right: 20px;
    }
    .gallery_m_list li a {
        padding: 7px;
        margin-bottom: 8px;
    }
    .gallery_m_list li a .img {
        width: 60px; 
        height: 60px;
    }
    .gallery_m_list li a .title {
        padding-left: 10px;
        font-size: 16px;
    }
    .gallery_wrap .multimedia-list {
        width: calc(100% - 261px);
    }

    .multimedia-list > li {
        width: calc(33.33% - 20px);
        margin-bottom: 1.25rem;
    }

} /* 1024 end */

@media only screen and (max-width : 768px){

    #header .logo, #header.sub .logo {
        width: 80px;
        margin-left: 10px;
        height: 60px;
        background-size: 80px auto;
    }

    #header > .inner {
        padding: 0;
        height: 60px;
    }

    #header.stiky > .inner {
        height: 50px;
    }
    #header.stiky .logo {
        width: 80px;
        height: 50px;
        background-size: 100% auto;
    }

    #header .btn-m {
        right: 10px;
    }
    #header .btn-m li + li {
        margin-left: 1rem;
    }
    #header .btn-m li button {
        font-size: 14px;
    }
    #header #gnb .menu > li, #header.sub #gnb .menu > li {
        margin: 0 0.625rem;
        padding: 0 0.625rem;
        font-size: 13px;
        line-height: 36px;
    }
    #header #gnb .sub-menu .imp {
        font-size: 13px;
    }
    #header #gnb .menu > li:after {
        top: 8px
    }
    #header.stiky #gnb .menu > li a{    
        font-size: 13px;
    }
    #header.stiky #gnb .sub-menu > li a,
    #header #gnb .sub-menu > li a {
        font-size: 13px;
        line-height: 36px;
    }

    #header .search-area .input-area {
        width: 94%;
        left: 3%;
    }
    #header .search-area .input-area .text {
        font-size: 13px;
    }
    #header .search-area .input-area .ico-search {
        font-size: 15px;
    }

    #header .util-menu li {
        margin: 0 0.625rem;
        font-size: 13px;
        line-height: 36px;
    }

    .btn-top {
        right: 3px;
        bottom: 3px;
        width: 38px;
        height: 38px;
        background-size: 12px auto;
    }

    .layer_notice .control {
        right: 15px;
        font-size: 10px;
    }
    .layer_notice .control input {
        margin: -1px 5px 0 0;
        vertical-align: middle;
        border: 1px solid #ccc;
    }
    .layer_notice .control .btn-close {
        width: 12px;
        height: 12px;
        margin-left: 0.625rem;
    }
    .layer_notice .title {
        width: calc(100% - 130px);
        margin-bottom: 5px;
        font-size: 13px;
        word-break: keep-all;
    }
    .layer_notice .txt {
        font-size: 10px;
        line-height: 13px;
    }

    #container.sub {
        margin: 1.25rem auto 2.5rem;
    }
    #container .location {
        margin-bottom: 25px;
    }
    #container .location li {
        font-size: 1.563rem;
    }
    #container .location li + li:before {
        margin: -5px 8px 0 8px;
        font-size: 12px;
    }

    .control-wrap.top {
        display: none;
    }
    .control-wrap {
        justify-content: center;
    }
    .control-wrap .left {
        display: none;
    }
    .control-wrap .paging button {
        font-size: 10px;
    }

    .democratization {
        padding: 0 12px 1.875rem 12px;
    }

    .democratization .section .section-title {
        width: 70px;
        padding: 0 8px 2px 12px;
        line-height: 18px;
    }
    .democratization .section .section-title:before {
        height: 35px;
        border-right: 5px solid #f16339;
        border-bottom: 3px solid transparent;
    }
    .democratization .section .section-title .year {
        font-size: 10px;
    }
    .democratization .section .section-title .tit {
        font-size: 13px;
    }

    .democratization .section .list {
        padding: 0 0 0 0.938rem;
        margin: 30px -20px -8px 0;
        background: url('../images/bg_shelf.png') repeat-y 0 0;
        background-size: 100% 150px;
    }
    .democratization .section .list + .list.noYear { 
        margin-top:36px;
    }
    .democratization .section .list + .list {
        margin-top: 0.625rem;
    }
    .democratization .section .list li.title {
        position: static;
        padding-top: 0.625rem;
        margin-left: -0.938rem;
        margin-right: 0.625rem;
    }
    .democratization .section .list li.title .sub-info {
        font-size:11px;
        padding:2px 0 2px 15px;
    }
    .democratization .section .list li.title .sub-info:before {
        width:11px; 
        height:11px;
        top:5px;
        left:0;
    }
    .democratization .section .list li.title a {
        width: 107px;
        height: 107px;
        padding: 13px 0;
    }
    .democratization .section .list li:nth-child(2) {
        margin-left: 0;
    }
    .democratization .section .list li.title .category {
        font-size: 10px;
    }
    .democratization .section .list li.title .category:before {
        width: 16px;
        margin-bottom: 4px;
    }
    .democratization .section .list li.title .name {
        margin: 5px 0 3px 0;
        font-size: 15px;
        line-height: 17px;
    }
    .democratization .section .list li.title .name.small {
        font-size: 13px;
        line-height: 0.938rem;
    }
    .democratization .section .list li.title .name.big {
        font-size: 19px;
        line-height: 1.25rem;
    }
    .democratization .section .list li.title .name.medium {
        font-size: 18px;
        line-height: 21px;
    }
    .democratization .section .list li.title .more {
        width: 16px;
        min-height: 16px;
        margin: 0 auto 2px;
    }

    .democratization .section .list li {
        width: 100px;
        height: 125px;
        padding: 8px 25px 5px 3px;
        margin: 0.938rem 0 9px 0;
        background-size: auto 100%;
        background-position: left top;
    }
    .democratization .section .list li.pub:after {
        left:58px;
        top:-1px;
        width:22px;
        height:22px;
        padding:5px 6px 5px 4px;
        font-size:10px;
    }

    .democratization .section .list li.noupper {
        width: 4px;
        height: 80px;
        margin: 60px 57px 9px 39px;
    }
    .democratization .section .list li .title {
        height: 50px;
        font-size: 10.5px;
        line-height: 13px;
    }
    .democratization .section .list li:not(.title):hover {
        transform: translateY(0);
    }
    .democratization .section .list li .photo {
        width: 63px;
        height: 63px;
        margin: 3px 3px 0 3px;
    }
    .democratization .section .list li .title:after {
        width: 26px;
        margin: 3px auto 0;
        padding-top: 2px;
        font-size: 10px;
        line-height: 12px;
        border-top: none;
    }

    .multimedia-list {
        gap: 12px;
    }
    .multimedia-list > li {
        width: calc(33.33% - 8px);
        margin-bottom: 1.25rem;
    }
    .multimedia-list li .title-wrap {
        padding: 5px 0;
    }
    .multimedia-list li .title-wrap .title {
        margin: 2px 0 0 0;
        font-size: 12px;
        line-height: 14px;
    }
    .multimedia-list li .title-wrap .category li {
        display: none;
    }

    .detail-wrap {
        margin: 0 0 40px 0;
    }
    .detail-wrap h2.title, .detail-wrap h2.title.multi {
        margin-bottom: 0.5rem;
        font-size: 24px;
    }
    .detail-wrap h2.title.multi {
        margin-bottom: 0.95rem;
    }
    .detail-wrap h2.title .btn-detail i {
        font-size: 17px;
    }
    .detail-wrap .lnb {
        grid-template-columns: 1fr 1fr 1fr;
        gap: 3px;
        margin-bottom: 1.25rem;
    }
    .detail-wrap .lnb > li {
        font-size: 11px;
        line-height: 30px;
    }
    .detail-wrap .lnb > li a {
        padding: 0 5px;
    }
    .detail-wrap .lnb > li.on a:after,
    .detail-wrap .lnb > li a:after {
        right: 0;
        top: 3px;
    }

    .detail-wrap .control {
        margin-bottom: 17px;
    }
    .detail-wrap .control button {
        min-width: 50px;
        padding: 3px 17px;
        font-size: 10px;
    }
    .detail-wrap .control .btn-print,
    .detail-wrap .control .btn-down,
    .detail-wrap .control .btn-result {
        display: none;
    }

    .detail-wrap .control i {
        font-size: 14px;
    }
    .detail-wrap .control i.ico-menu:before {
        content: '';
        width: 1.25rem;
        height: 22px;
        margin-right: 0.625rem;
        background: url('../images/icon/icon_menu.png') no-repeat left top;
        background-size: 100% auto;
    }
    .detail-wrap .control i.ico-txt-big,
    .detail-wrap .control i.ico-txt-small {
        font-size: 10px;
    }

    .detail-wrap .info {
        padding-top: 1.25rem;
    }
    .detail-wrap .info .text {
        min-width: 50%;
        margin-left: 1.25rem;
    }
    .detail-wrap .info .text dl {
        padding: 2px 0;
    }
    .detail-wrap .info .text dt {
        min-width: 115px;
        width: 115px;
        font-size: 12px;
    }
    .detail-wrap .info .text dd {
        font-size: 12px;
    }
    .detail-wrap .photo .photo-info {
        line-height: 35px;
    }
    .detail-wrap .photo .photo-info .subject {
        padding: 11px 7px;
        font-size: 12px;
        line-height: 13px;
    }

    .detail-wrap .section {
        padding: 1.25rem 0 0 0;
    }
    .detail-wrap .section .title {
        margin-bottom: 1.25rem;
    }
    .detail-wrap .section .title > span {
        padding: 0 1.25rem;
        line-height: 35px;
        font-size: 15px;
    }
    .detail-wrap .section .txt {
        font-size: 13px;
        line-height: 22px;
    }

    /* by odop 2024.11.6*/
    .detail-wrap .section table * {
        font-size: 13px;
        line-height: 22px;
    }

    .detail-wrap .section .txt .photo {
        max-width: 55%;
        padding: 0 1.25rem 0.625rem 0;
        margin-top: 6px;
        font-size: 12px;
        line-height: 17px;
    }
    .detail-wrap .section .txt .photo.right {
        padding: 0 0 0.625rem 1.25rem;
    }

    .detail-wrap .section .sub-title {
        margin-bottom: 1.25rem;
        font-size: 16px;
        line-height: 31px;
    }
    .detail-wrap .section .sub-title2 {
        margin-bottom: 0.625rem;
        font-size: 15px;
        line-height: 21px;
    }
    .detail-wrap .section .txt + .sub-title {
        margin-top: 30px;
    }

    .detail-wrap .section .list li {
        font-size: 13px;
        padding-left: 18px;
    }
    .detail-wrap .section .list li:before {
        width: 8px;
        margin-right: 5px;
        top:10px;
    }
    .detail-wrap .section .list li .file-down i {
        width: 18px;
        height: 18px;
        line-height: 18px;
        font-size: 11px;
    }

    .detail-wrap .section .photo-list li {
        padding-bottom: 26px;
        margin: 0.625rem 0.625rem 0.625rem 0;
    }
    .detail-wrap .section .photo-list li .tit {
        font-size: 12px;
        line-height: 26px;
    }

    .detail-info .tit {
        padding: 0 5px;
        font-size: 13px;
        line-height: 23px;
    }
    .detail-info dl {
        padding: 5px 0;
    }
    .detail-info dt {
        min-width: 100px;
        font-size: 13px;
    }
    .detail-info dd {
        font-size: 13px;
        line-height: 1.25rem;
    }

    #viewer .photo-wrap, #viewer .photo-wrap.clip {
        width: 100%;
        max-width: none;
        padding: 0 40px;
        box-sizing: border-box;
    }
    #viewer .photo-wrap .info {
        padding: 13px;
    }
    #viewer .photo-wrap .info .lisence {
        top: 13px;
        right: 13px;
    }
    #viewer .photo-wrap .info .lisence img {
        width: 100px;
    }
    #viewer .photo-wrap .info .title {
        margin-bottom: 1.25rem;
        padding-right: 6.875;
        font-size: 13px;
    }
    #viewer .photo-wrap .info .list li {
        font-size: 12px;
        line-height: 18px;
    }
    #viewer .photo-wrap .btn-left {
        left: 10px;
        margin-top: -30px;
        font-size: 40px;
    }
    #viewer .photo-wrap .btn-right {
        right: 10px;
        margin-top: -30px;
        font-size: 40px;
    }
    #viewer .photo-wrap .close {
        right: 20px;
        top: -40px;
        font-size: 20px;
    }

    /* sns */
    .detail-wrap .dropdown-menu.sns-list {
        width: 137px;
        padding: 5px 0.625rem;
        box-sizing: border-box;
    }
    .detail-wrap .dropdown-menu.sns-list li {
        padding: 0 0.938rem;
        font-size: 10px;
        line-height: 32px;
    }
    .detail-wrap .dropdown-menu.sns-list li i {
        width: 30px;
        margin: 0 5px;
        font-size: 14px;
    }
    .detail-wrap .dropdown-menu.sns-list li i.ico-kakao {
        width: 30px;
        height: 14px;
        background: url('../images/icon/ico-kakao.png') no-repeat center center;
        background-size: auto 100%;
    }
    .detail-wrap .dropdown-menu.sns-list li i.ico-url {
        font-size: 10px;
    }

    /* info */
    .detail-wrap #history-info.dropdown-menu {
        max-width: 85%;
        width: 295px;
        padding: 0.625rem 30px;
    }
    .detail-wrap #history-info.dropdown-menu li {
        padding: 0.625rem 0;
    }
    .detail-wrap #history-info.dropdown-menu dl {
        padding-left: 60px;
    }
    .detail-wrap #history-info.dropdown-menu dl dt {
        min-width: 60px;
        font-size: 10px;
        line-height: 18px;
    } 
    .detail-wrap #history-info.dropdown-menu dl dd {
        font-size: 12px;
        line-height: 21px;
    } 

    .article-wrap .article {
        padding-bottom: 1.25rem;
    }
    .article-wrap .article:last-child {
        padding-bottom: 0;
    }
    .article-wrap .article dt {
        padding: 0 5px;
        margin-bottom: 5px;
        font-size: 13px;
        line-height: 30px;
    }
    .article-wrap .article dd {
        font-size: 12px;
        line-height: 23px;
    }
    .article-wrap .article dd:before {
        width: 2px;
        height: 2px;
        margin: -3px 3px 0 4px;
    }

    .mt50 { margin-top: 30px !important;
    }

    .tbl-wrap table th,
    .tbl-wrap table td {
        min-width: auto !important;
        padding: 13px 5px;
        font-size: 12px;
    }
    .tbl-wrap table th {
        font-size: 10px;
    }
    .tbl-wrap table .no,
    .tbl-wrap table .type,
    .tbl-wrap table .date {
        display: none;
    }
    .tbl-wrap table td.subject {
        width: 40%;
    }

    .generation {
        margin-bottom: 0.625rem;
    }
    .generation .list > li {
        height: 195px;
    }
    .generation .list > li a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    .generation .list > li.upper a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2_db.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    .generation .list > li.event a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2_b.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    .generation .list > li.back a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2_p.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    .generation .list > li.group a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2_y.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    
    .generation .list > li.event-sum a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2_bg.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    
    .generation .list > li.related a {
        margin: -21px 0 0 0;
        padding: 0 25px 0px 0;
        background: url('../images/bg_book2_v.png') no-repeat -5px top;
        background-size: auto 195px;
    }
    
    .generation .list > li .title {
        padding-top: 5px;
        font-size: 14px;
        line-height: 18px;
    }
    .generation .list > li .title:after {
        margin: 5px auto 0;
        padding-top: 2px;
        font-size: 10px;
        line-height: 12px;
    }
    .generation .list > li a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }

    .generation .list > li.upper a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2_db.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }
    .generation .list > li.event a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2_b.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }
    .generation .list > li.back a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2_p.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }
    .generation .list > li.group a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2_y.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }
    .generation .list > li.event-sum a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2_bg.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }
    .generation .list > li.related a:after {
        right: -10px;
        width: 37px;
        background: url('../images/bg_book2_v.png') no-repeat calc(100% + 19px) top;
        background-size: auto 195px;
    }
    .generation .list > li .left {
        width: 96px;
        padding-top: 30px;
        margin-left: 2px;
    }
    .generation .list > li .photo {
        width: 82px;
        height: 82px;
        margin: 0 auto;
    }
    .generation .list > li .right {
        width: calc(100% - 110px);
        padding: 1.875 0 0.938rem;
        margin-left: 12px;
        background: url('../images/bg_book3_n.png') no-repeat 0 0;
        background-size: 100% 195px;
    }

    .generation .list > li .txt {
        max-height: 60px;
        margin: 0.625rem 0;
        font-size: 13px;
        line-height: 19px;
        -webkit-line-clamp: 3;
    }

    .search-result {
        margin-bottom: 1.25rem;
        font-size: 19px;
    }
    .search-result span {
        margin-left: 0.938rem;
        font-size: 15px;
    }
    .search-wrap .content .search-list li {
        padding: 12px 0;
    }
    .search-wrap .content .search-list .photo {
        min-width: 109px;
        height: 75px;
        margin-right: 13px;
    }
    .search-wrap .content .search-list .title {
        font-size: 14px;
    }
    .search-wrap .content .search-list .category {
        font-size: 10px;
    }
    .search-wrap .content .search-list .txt {
        margin-top: 5px;
        font-size: 11px;
    }

    .board-view .control-wrap {
        display: flex !important;
        justify-content: space-between;
    }
    .board-view .control-wrap .left {
        display: block !important;
    }
    .board-view .control-wrap.top .title {
        font-size: 1.25rem;
    }
    .board-view .board-content li {
        padding: 0.625rem 0 0.938rem;
    }
    .board-view .board-content li .tit {
        font-size: 10px;
    }
    .board-view .board-content li .tit .con {
        margin-right: 1.875;
    }
    .board-view .board-content li .con {
        font-size: 12px;
    }
    .board-view .board-content li .con:before {
        height: 8px;
        margin: -2px 5px 0 5px;
    }
    .board-view .board-content li.long-text {
        padding-bottom: 0.938rem;
    }
    .board-view .board-content li.long-text .tit {
        margin-bottom: 5px;
    }
    .board-view .board-content li.long-text .con {
        font-size: 12px;
        line-height: 22px;
    }
    .board-view .board-content li.file {
        padding: 0.625rem 0;
        font-size: 11px;
    }

    .btn-text {
        font-size: 12px;
    }

    #container .location_wrap {
        display: inline-block;
        margin-bottom: 25px;
    }
    .btn_shadow {
        padding: 8px 15px;
        font-size: 14px;
        box-shadow: 3px 3px 5px rgba(0,0,0,.1);
        margin-right: 0;
    }
    .btn_shadow.btn_simple:before {
        width: 35px;
        height: 17px;
        margin-right: 10px;
    }
    .btn_shadow.btn_detail:before {
        width: 35px;
        height: 17px;
        margin-right: 10px;
    }

    .gallery_m_list {
        display: none;
    }

    .gallery_wrap{
        display: block;
    }

    .gallery_wrap .multimedia-list {
        width: 100%;
    }

    .gallery_wrap select {
        display: block;
    }



    /**********************************************************************
        Layer Popup
    ***********************************************************************/
    #layerPop {
        max-width: 340px;
        width: 100%;
        padding: 0.625rem 0.938rem 0.938rem 0.938rem;
        margin-left: 5px;
    }
    #layerPop.c-orange {
        border-top: 3px solid #504764;
    }
    #layerPop.c-blue {
        border-top: 3px solid #504764;
    }
    #layerPop .title {
        font-size: 14px;
    }
    #layerPop .txt {
        font-size: 11px;
        line-height: 14px;
    }


    /**********************************************************************
        기사상세 - 의견보내기 레이어
    ***********************************************************************/
    .layerSendComment .sendWrap {
        left: 10px;
        top: 10px;
        right: 10px;
        bottom: 10px;
        width: auto;
        padding: 1.25rem 0.625rem;
        transform: none;
        box-sizing: border-box;
    }
    .layerSendComment .top {
        margin-bottom: 0.625rem;
    }
    .layerSendComment .top .title {
        margin-bottom: 0.625rem;
        padding: 0 30px;
        font-size: 15px;
    }
    .layerSendComment .top .btn-close {
        top: -3px;
        font-size: 20px;
    }
    .layerSendComment .top .txt {
        font-size: 10px;
    }
    .layerSendComment .top .txt .ico-help:before {
        margin-right: 3px;
    }
    .layerSendComment .top .data {
        margin: 0.625rem 0 0.938rem 0;
        line-height: 37px;
        font-size: 11px;
    }
    .layerSendComment .top .data span:after {
        height: 11px;
        margin: -1px 4px 0 6px;
    }
    .layerSendComment .top .certi p {
        font-size: 11px;
    }
    .layerSendComment .top .certi .btn-certi {
        width: 240px;
        height: 32px;
        font-size: 12px;
        line-height: 32px;
    }
    .layerSendComment .input-area dt {
        line-height: 24px;
        font-size: 11px;
    }
    .layerSendComment .input-area input {
        height: 32px;
        font-size: 10px;
    }
    .layerSendComment .input-area .select-wrap {
        font-size: 10px;
        line-height: 18px;
    }
    .layerSendComment .input-area .select-wrap:after {
        top: 11px;
        right: 11px;
    }
    .layerSendComment .input-area .select-wrap ul {
        top: 30px;
    }
    .layerSendComment .input-area .select-wrap li {
        padding: 6px 7px;
    }
    .layerSendComment .input-area textarea {
        height: 105px;
        padding: 7px;
        font-size: 11px;
    }
    .layerSendComment .input-area .input-file-wrap input[type="text"] {
        height: 32px;
        padding: 0 35px 0 0.625rem;
    }
    .layerSendComment .input-area .input-file-wrap:after {
        top: 8px; 
        right: 8px;
        font-size: 16px;
    }
    .layerSendComment .input-area .file-list {
        gap: 0 10px;
        font-size: 10px;
    }
    .layerSendComment .input-area .file-list button {
        font-size: 12px;
    }
    .layerSendComment .btn-send {
        height: 37px;
        margin: 1.25rem auto 0;
        font-size: 11px;
        line-height: 37px;
    }

    /* 보내기 완료 */
    .layerSendComment .sendComplete {
        left: 10px;
        right: 10px;
        top: 50%;
        width: auto;
        padding: 0.938rem 0.625rem;
        transform: translateY(-50%);
    }
    .layerSendComment .sendComplete .btn-close {
        right: 10px;
        top: 15px;
        font-size: 20px;
    }
    .layerSendComment .sendComplete .con {
        width: auto;
        margin: 40px 0.625rem 60px;
    }
    .layerSendComment .sendComplete .title {
        font-size: 18px;
        line-height: 28px;
    }
    .layerSendComment .sendComplete .txt {
        font-size: 12px;
        line-height: 21px;
    }

} /* 768 end */

@media only screen and (max-width : 767px){
	
    #container .location li { 
        font-size:1.3rem;
    }

    input[type="text"] { 
        font-size: 11px;
    }

    #header.stiky .logo {
        height: 38px;
        padding: 2px 0 10px;
    }
    
    #multi.photo-wrap .multi-info .title {
        padding-right: 120px;
        margin-bottom: 20px;
        font-size: 15px;
    }
    #multi.photo-wrap .multi-info .lisence img {
        width:100px;
    }
    #multi.photo-wrap .multi-info .list li {
        font-size: 12px;
        line-height: 15px;
    }
    #multi.photo-wrap .multi-info .list li span:after {
        content: '';
        display: inline-block;
        height: 13px;
        margin: 8px 6px 0 8px;
        border-left: 1px solid #cfcfcf;
    }

    .table-title {
        margin: 40px 0 15px;
        font-size: .8rem;
    }
    .table-wrap {
        margin: 0 0 20px;
    }
    .table-wrap table {
        font-size: .8rem;
    }
    .table-wrap thead th {
        padding: 16px 5px;
    }
    .table-wrap tbody th, 
    .table-wrap tbody td {
        padding: 16px 5px;
    }

    .detail-wrap .section .photo-list li img {
        height:90px;
    }
        
}

/* only 시기별보기 화면 */
@media only screen and (max-width : 600px){

    .generation .list > li {
        width: 100%;
    }
    .generation .list > li .title:after {
        padding-top: 5px;
    }
    .generation .list > li .left .title span {
        display: none;
    }
    .generation .list > li .right {
        display: block;
    }
    .generation .list > li .right .title {
        display: block;
        padding: 0 0 2px 0;
        text-align: left;
    }
    .generation .list > li .right .title:after {
        display: none;
    }

    .generation .list > li {
        height: 151px;
    }
    .generation .list > li .right {
        background-size: 100% 151px;
    }
    .generation .list > li a, .generation .list > li.upper a, .generation .list > li.back a, .generation .list > li.group a, .generation .list > li.event a, .generation .list > li.event-sum a, .generation .list > li.related a {
        background-position: -5px top;
        background-size: 287px 151px;
    }
    .generation .list > li a:after, .generation .list > li.upper a:after, .generation .list > li.back a:after, .generation .list > li.group a:after, .generation .list > li.event a:after, .generation .list > li.event-sum a:after, .generation .list > li.related a:after {
        background-size: auto 151px;
    }
    .generation .list > li .info {
        display: none;
    }

}


/* 메인 페이지 및 서브메인 페이지를 위한 사이즈 */
@media only screen and (max-width : 480px){

    .multimedia-list {
        gap: 16px;
    }
    .multimedia-list > li {
        width: calc(50% - 8px);
        margin-bottom: 0.938rem;
    }

    .detail-wrap .info {
        display: block;
    }
    .detail-wrap .info .photo {
        width:100%;
        max-width:initial;
        max-height:initial;
        min-height:initial;
    }
    .detail-wrap .info .text {
        margin: 0.938rem 0 0 0;
        width:100%;
    }
    .detail-wrap .info .text dt {
        min-width: 90px;
        width: 90px;
    }

    .detail-wrap .section .txt .photo {
        float: none;
        max-width: 100%;
        padding: 0 0 0.625rem 0;
        margin-top: 0;
        font-size: 12px;
        line-height: 17px;
    }
    .detail-wrap .section .txt .photo.right {
        float: none;
        padding: 0 0 0.625rem 0;
    }

    .detail-wrap .section .list li {
        padding-left: 0.938rem;
    }
    .detail-wrap .section .list li:before {
        width: 8px;
        height: 2px;
    }

    #viewer .photo-wrap {
        top: calc(50% + 15px);
        padding: 0 25px;
    }
    #viewer .photo-wrap .info {
        padding: 0.625rem;
    }
    #viewer .photo-wrap .info .lisence {
        position: static;
        margin-bottom: 3px;
    }
    #viewer .photo-wrap .info .lisence img {
        width: 100px;
    }
    #viewer .photo-wrap .info .title {
        margin-bottom: 0.625rem;
        padding-right: 0;
        font-size: 13px;
    }
    #viewer .photo-wrap .info .list li {
        font-size: 11px;
        line-height: 0.938rem;
    }
    #viewer .photo-wrap .btn-left {
        left: 5px;
        margin-top: -1.25rem;
        font-size: 30px;
    }
    #viewer .photo-wrap .btn-right {
        right: 5px;
        margin-top: -1.25rem;
        font-size: 30px;
    }
    #viewer .photo-wrap .close {
        right: 20px;
        top: -40px;
        font-size: 16px;
    }
    .democratization .section .list + .list.noYear { 
        margin-top:26px;
    }

} /* 480 end */

/* only 메인 화면 */
@media only screen and (max-width : 480px){	
    .democratization {
        padding: 0 43px 1.875rem 43px;
    }
}

@media only screen and (max-width : 413px){        
        .democratization {
            padding: 0 36px 1.875rem 36px;
    }
}

@media only screen and (max-width : 399px){        
    .democratization {
        padding: 0 26px 1.875rem 26px;
    }
}

@media only screen and (max-width : 379px){        
    .democratization {
        padding: 0 19px 1.875rem 19px;
    }
}

@media only screen and (max-width : 365px){        
    .democratization {
        padding: 0 14px 1.875rem 14px;
    }
}

@media only screen and (max-width : 355px){        
    .democratization {
        padding: 0 9px 1.875rem 9px;
    }
}

@media only screen and (max-width : 344px){        
    .democratization {
        padding: 0 0 1.875rem 0;
    }
}


/* 250725 본문 지도 링크 레이어 */
.popup-word {color:#0066ee; position:relative; cursor:pointer;}
.popup-word-cont {position: absolute; bottom: calc(100% + 10px); left: 50%; z-index: 10; border: 1px solid #c2c2c2; box-shadow: 5px 5px 8px rgba(0,0,0,.08); box-sizing: border-box;background-color: #fff; width: 330px; display: none; padding: 30px; transform: translateX(-50%); font-size: 15px; line-height: 1.4; font-weight: 300; color: #1e1e1e; letter-spacing:0; cursor:auto;}
.popup-word-cont h5 {font-weight:700; font-size:20px; color: #5858ad; line-height: 1.2; margin-bottom: 12px;}
.popup-word-cont .sm {font-weight:400; font-size:12px; color: #555; line-height: 1.2; margin-bottom: 12px;}
.popup-word-cont .ext {font-weight:300; font-size:14px; color: #222; line-height: 1.2;}
.popup-word-cont a.go-map {padding: 14px 0; margin-top: 20px; display: flex; justify-content: center; border: 1px solid #dedede; border-radius: 4px; background-color: #fff; transition: all .3s;}
.popup-word-cont a.go-map:hover {background: #d1d1da; border: 1px solid #d1d1da;}
.popup-word-cont a.go-map span {font-weight:800; font-size:14px; color: #3838cd; display: flex; align-items: center;}
.popup-word-cont a.go-map span::after {content: ''; display: block; width: 14px; height: 14px; background: url(../images/ico_arrow.svg) no-repeat center; margin-left: 19px;}
.popup-word-cont figure {display: flex; justify-content: center;}
.popup-word-cont figure img {max-width: 260px; max-height: 180px; box-sizing: border-box; border: 1px solid #f5f5f5;}
.popup-word-cont .close {position:absolute; right:9px; top:9px; width:20px; height:20px; background: #fdfdfd url(../images/ico_close_sm.svg) center no-repeat; background-size:10px auto; border:1px solid #c5c5c5; border-radius:2px;}
.popup-word-cont.active {display: block;}
.popup-word-cont:before {content: ''; position: absolute; bottom: -9px; left: 50%; border-top: 9px solid #d3d3d3; border-left: 7px solid transparent; border-right: 7px solid transparent; margin-left: -7px;}
.popup-word-cont:after {content: '';position: absolute; bottom: -7px; left: 50%; border-top: 7px solid #fff; border-left: 5px solid transparent; border-right: 5px solid transparent; margin-left: -5px;}
.popup-word-cont.popup-align-left {left: 0;}
.popup-word-cont.popup-align-center {left: 50%; transform: translateX(-50%);}
.popup-word-cont.popup-align-right {right: 0;}

.map_ico {text-decoration: underline;}
.map_ico i {display: inline-block; height: 20px; width: 20px; margin-left: 2px; transform: rotate(-45deg); border-radius: 50% 50% 50% 0; position: relative;}
.map_ico i::after {content: ''; display: block; transform: rotate(45deg); background-position: center; background-repeat: no-repeat; background-size: 100% auto; position: absolute; width: 10px; height: 10px; left: calc(50% - 5px); top: calc(50% - 5px);}
.map_ico.space {color: #3838cd; font-weight: 700;}
.map_ico.space i {background-color: #5c5cf1;}
.map_ico.space i::after {background-image: url(../map/images/map_icon_01.svg);}
.map_ico.building {color: #339900; font-weight: 700;}
.map_ico.building i {background-color: #5da145;}
.map_ico.building i::after {background-image: url(../map/images/map_icon_03.svg);}
.map_ico.map_photo {color: #e44b00; font-weight: 700;}
.map_ico.map_photo i {background-color: #ff7200;}
.map_ico.map_photo i::after {background-image: url(../map/images/map_icon_02.svg);}

.header_logo_kdm {display: flex; align-items: center; width: 140px; height: 26px; background: url(../images/logo_kdm_w.svg) no-repeat center; background-size: 140px auto; font-size: 0;}

/* 슬라이드 팝업 */
.slide_popup {display: none; position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 9999; width: 1024px; max-height: 85vh;}
.slide_popup .slide_content {background-color: #fff; border-radius: 8px; padding: 60px 1px; width: 100%; height: 100%; position: relative;}
.detail_slide figure {text-align: center; margin: 0;}
.detail_slide figure img {max-width: 100%; max-height: 460px; border: 1px solid #ddd;}
.detail_slide h4 {font-size: 22px; line-height: 1.4; font-weight: 700; text-align: center; margin-top: 25px;}
.detail_slide .txt {margin-top: 25px; font-size: 15px; line-height: 22px;}
.detail_slide .info {margin-top: 10px; display: flex; align-items: center; justify-content: space-between;}
.detail_slide .info .ref {font-size: 14px; line-height: 22px; font-weight: 700;}
/*.detail_slide .info a {padding: 4px 16px; background-color: #3399ff; border-radius: 8px; color: #fff; font-size: 14px; line-height: 22px; font-weight: 700;}*/
.detail_slide .item {padding: 0 80px; max-height: calc(85vh - 150px); overflow-y: auto; width: calc(100% - 160px) !important;}
.detail_slide .arr_wrap button {position: absolute; top: calc(50% - 25px); width: 28px; height: 51px; background-repeat: no-repeat; background-size: 100% auto; cursor: pointer; z-index: 1;}
.detail_slide .arr_wrap button.arr_prev {background-image: url(../map/images/arr_prev_on.svg); left: 15px;}
.detail_slide .arr_wrap button.arr_prev.swiper-button-disabled {background-image: url(../map/images/arr_prev.svg); left: 15px;}
.detail_slide .arr_wrap button.arr_next {background-image: url(../map/images/arr_next_on.svg); right: 15px;}
.detail_slide .arr_wrap button.arr_next.swiper-button-disabled {background-image: url(../map/images/arr_next.svg); right: 15px;}
.detail_bullet {text-align: center; position: absolute; bottom: 30px !important;}
.detail_bullet span {width: 16px; height: 16px; margin: 0 6px !important; background-color: #d5d5d5; opacity: 1;}
.detail_bullet span.swiper-pagination-bullet-active {background-color:#3399ff;}
.slide_content .close {position: absolute; right: 20px; top: 20px; width: 26px; height: 26px; background: url(../map/images/icon_close.svg) no-repeat 0 0; background-size: 100% auto; cursor: pointer; z-index: 1;}

.detail_slide .multi-info {position: relative; padding: 20px 0 0;}
.detail_slide .multi-info .title-wrap {display: flex; align-items: flex-start;}
.detail_slide .multi-info .title {flex: 1; font-size: 18px; font-weight:400;}
.detail_slide .multi-info .lisence {display: flex; justify-content: flex-end; width: 180px;}
.detail_slide .multi-info .list li {font-size: 14px; line-height: 18px;}
.detail_slide .multi-info .list li span {display: inline-block;}
.detail_slide .multi-info .list li span:after {content: ''; display: inline-block; height: 13px; margin: 8px 6px 0 8px; border-left: 1px solid #cfcfcf;}
.detail_slide .multi-info .list li a {color:#0660bb;}

/* 버튼 */
.btn-copyright {color:#fff; background:#3399ff; padding:8px 10px 8px 35px; border-radius:8px; font-weight:500; font-size:14px; display:block; position:relative;}
.btn-copyright:before {content:''; position:absolute; display:block; left:10px; top:5px; width:20px; height:20px; background:url(../images/icon/ico_copyright.svg) center / cover;}
.btn-copyright:hover {background:#0660bb; color:#fff; transition:all 0.3s;}

@media screen and (max-width: 1100px) {
    .slide_popup {width: calc(100% - 40px); left: 15px; transform: translate(0, -50%);}
    .detail_slide .item {padding: 0 50px; max-height: calc(85vh - 100px); width: calc(100% - 100px) !important;}
}

@media screen and (max-width: 767px) {

	.slide_popup {width: calc(100% - 6px); left: 3px; top: 3px; transform: none; height: calc(100vh - 6px); max-height: none;}
	.slide_popup .slide_content {padding: 10px 3px; width: calc(100% - 6px); max-height: calc(100% - 20px);}
	.detail_slide {margin-top: 40px;}
	.detail_slide .item {padding: 0 20px; height: calc(100vh - 80px) !important; max-height: none; width: calc(100% - 40px) !important;}
	.detail_slide .arr_wrap button {width: 15px; height: 30px;}
	.detail_slide h4 {font-size: 18px; line-height: 21px;}
	.detail_slide .txt {font-size: 12px; line-height: 17px; margin-top: 20px;}
	.detail_slide .txt {font-size: 12px; line-height: 22px;}
	/*.detail_slide .info a {font-size: 11px; line-height: 18px; border-radius: 7px; padding: 4px 15px;}*/
	.detail_bullet span {width: 13px; height: 13px;}
	.slide_content .close {top: 10px; right: 50%; transform: translateX(50%);}
	.detail_bullet {bottom: 10px !important;}

	.detail_slide .arr_wrap button.arr_prev {left: 5px;}
	.detail_slide .arr_wrap button.arr_prev.swiper-button-disabled {left: 5px;}
	.detail_slide .arr_wrap button.arr_next {right: 5px;}
	.detail_slide .arr_wrap button.arr_next.swiper-button-disabled {right: 5px;}
    
    .detail_slide .multi-info .title-wrap {flex-wrap: wrap;}
    .detail_slide .multi-info .title {flex: auto; width: 100%; font-size: 15px;}
    .detail_slide .multi-info .lisence {justify-content: flex-start; width: 100%; margin-top: 10px;}
    .detail_slide .multi-info .list li {font-size: 12px; line-height: 15px;}

    .btn-copyright {padding:4px 10px 4px 35px; border-radius:4px; font-size:12px;}
    .btn-copyright:before {left:10px; top:3px; width:15px; height:15px; background:url(../images/icon/ico_copyright.svg) center / cover;}
}


body.dim {overflow: hidden;}
body.dim:before {background-color: rgba(0, 0, 0, .7); -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); content:""; position:fixed; left:0; top:0; height:100vh; width:100%; z-index:9998;}