/* Font */
@import url("../css/noto-sans-korean.css");
.tc01_01 .unit {
  padding-bottom: 0;
  border-bottom: none;
}
.tc01 .unit {
  margin-bottom: 0rem;
}
h3 {
  font-size: 1.5rem;
  margin: 20px 0;
  word-break: keep-all;
}

.tc01 .dataCategory .categoryA li a {
  overflow: hidden;
}
.field img {
  max-width: 96%;
}
.ib03 > dl > dd {
  height: 662px;
}

.fc01 .thumb img,
.fillwidth {
  border: 0;
  width: 100%;
  height: auto;
}
.copyright img {
  border: 0;
  width: auto;
  height: auto;
}

.tc01 .dataCategory .pdfA {
  padding-bottom: 30px;
  border-bottom: 1px solid #ddd;
}
.tc01 .field--name-field-content h3 {
  padding: 1rem 0;
}
.fc02.fc02_01 {
  background: #427ec4;
}

.tc01 .dataGraph .graphA {
  height: 660px;
  background-color: #fff;
}
.graphA iframe {
  border: none;
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
  box-shadow: 2px 2px 2px #ddd;
}
.select2 button.select2-selection__choice__remove {
  top: 50%;
  transform: translateY(-50%);
}
header ul.menu > li > .sub-menu {
  max-height: 0;
  position: fixed;
  left: 0;
  top: 6.25rem;
  width: 100%;
  background-color: #eaf3f8;
  box-sizing: border-box;
  z-index: 300;
  overflow: hidden;
  transition: max-height 0.4s;
}
.tc01 .summary {
  margin-bottom: 1rem;
}
.tc01 .dataGraph .tabMenu li.on a {
  border-color: #a1d1f0;
}
.contextual-region .tabs {
  position: relative;
  max-width: 73.75rem;
  margin: 0 auto;
}

.ng03 dl dd p a {
  margin-bottom: 1.5rem;
  font-size: 0.875rem;
  color: #434343;
  word-break: keep-all;
}
.cf02_01 fieldset.advanced a.toggle {
  text-align: center;
}

.popup-body {
  padding: 30px 20px;
}

/* photo popup */
#photo-target-eng {
  font-style: italic;
}
#photo-collection {
  color: #1173b3;
}
.ib04 .meta dl dd {
  display: table-cell;
  line-height: 1.1rem;
}
.ib02 .slider {
  background-color: #000;
}
/*제안하기 팝업*/
.cf07 .popupA {
  left: 0rem;
  top: 1rem;
  z-index: 100;
  position: relative;
}

/*table*/
.page_content table {
  width: 100%;
  border-collapse: collapse;
}
.page_content thead {
  background-color: #eee;
}
.page_content th {
  height: 50px;
}
.page_content td {
  line-height: 40px;
  text-align: center;
  padding: 8px 12px;
}
.page_content td p:last-child {
  margin-bottom: 0;
}
.page_content tr {
  border-bottom: 1px solid #eee;
}

/*views table*/
.views-table.views-view-table {
  width: 100%;
}
.views-table thead {
  background-color: #eee;
}
.views-table th {
  height: 50px;
}
.views-table td {
  height: 50px;
  text-align: center;
}
.views-table td.views-field-title {
  text-align: left;
}
.views-table tr {
  border-bottom: 1px solid #eee;
}

/*pdf*/
.pdf {
  width: 100%;
  height: 600px;
}

/*map*/
.leaflet-top,
.leaflet-bottom {
  position: absolute;
  z-index: 100 !important;
  pointer-events: none;
}

.cf02_02 h3 {
  color: #fff;
  font-size: 1.5rem;
  margin-bottom: 1rem;
  text-align: left;
  margin-top: 0;
}
.fc02 {
  background: #99bbe1;
}
#si-data .fc02 {
  background: #427ec4;
}

.field__label {
  padding: 10px 0;
  font-size: 18px;
  color: #000;
  margin-top: 20px;
}
.summary h2 {
  margin-bottom: 20px;
}
.dataType01 .titleA em b,
.dataType02 .titleA em b,
.dataType03 .titleA em b,
.dataType04 .titleA em b,
.dataType05 .titleA em b {
  color: #1056aa;
}
.photoType01 .titleA em b,
.photoType02 .titleA em b {
  color: #009c8f;
}
.cf02_01 fieldset.advanced a.toggle::after {
  content: "";
}
.map01 {
  position: relative;
  margin-bottom: 0.875rem;
  background-color: #eee;
  height: 38.25rem;
}

.fc01,
.select2-dropdown {
  animation: fadein 0.5s;
  -moz-animation: fadein 0.5s; /* Firefox */
  -webkit-animation: fadein 0.5s; /* Safari and Chrome */
  -o-animation: fadein 0.5s; /* Opera */
}
.gridItem,
.map01 .inner {
  animation: fadein 1s;
  -moz-animation: fadein 1s; /* Firefox */
  -webkit-animation: fadein 1s; /* Safari and Chrome */
  -o-animation: fadein 1s; /* Opera */
}
.fc03,
.lc01,
.lc02,
.lc03 {
  animation: fadein 2s;
  -moz-animation: fadein 2s; /* Firefox */
  -webkit-animation: fadein 2s; /* Safari and Chrome */
  -o-animation: fadein 2s; /* Opera */
}
.ib05,
.ib06,
.ib03,
.dataSeoul {
  animation: fadein 1s;
  -moz-animation: fadein 1s; /* Firefox */
  -webkit-animation: fadein 1s; /* Safari and Chrome */
  -o-animation: fadein 1s; /* Opera */
}
@keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-moz-keyframes fadein {
  /* Firefox */
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes fadein {
  /* Safari and Chrome */
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-o-keyframes fadein {
  /* Opera */
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/*조사데이터*/
.tbl01 tbody td {
  border-bottom: 1px solid #dfe6ee;
  font-size: 0.875rem;
  color: #313131;
  padding: 1rem 2rem;
  text-align: left;
  line-height: 24px;
}
.tbl02 th.t01 {
  width: 5%;
}
.tbl02 th.t01,
.tbl02 th.t02 {
  border-bottom: none;
  background-color: #eaf3f8;
  font-size: 0.875rem;
  color: #313131;
  padding: 0.6rem 1rem;
  text-align: left;
  height: 20px;
}
.tbl02 tbody td {
  border-bottom: none;
  font-size: 0.875rem;
  color: #313131;
  padding: 0.6rem 1rem;
  text-align: left;
  line-height: 24px;
}
.views-table tr.notice {
  background-color: #edf8ff;
}
.sisurvey .btn-down {
  border: 1px solid #ddd;
  padding: 10px 20px 10px 35px;
  background-image: url("../images/icon-download.png");
  background-size: 15px;
  background-repeat: no-repeat;
  background-position: 10px;
}

a.pdf {
  border: 1px solid #ddd;
  padding: 10px 20px 10px 35px;
  background-image: url("../images/icon-file.png");
  background-size: 15px;
  background-repeat: no-repeat;
  background-position: 10px;
}
a.zip {
  border: 1px solid #ddd;
  padding: 10px 20px 10px 35px;
  background-image: url("../images/icon-file.png");
  background-size: 15px;
  background-repeat: no-repeat;
  background-position: 10px;
}
a.xls {
  border: 1px solid #ddd;
  padding: 10px 20px 10px 35px;
  background-image: url("../images/icon-file.png");
  background-size: 15px;
  background-repeat: no-repeat;
  background-position: 10px;
}
.tc01 .bodyA p {
  margin-bottom: 1rem;
  word-break: keep-all;
  text-align: justify;
}
.tc01 .dataGraph .btnA {
  height: 40px;
}

.sisurvey .item {
  padding: 20px 0;
  float: left;
  width: 240px;
  margin-right: 10px;
}
.sisurvey .con01 {
  margin-top: 10px;
}
.con02 .fillheight {
  border: 1px solid #ccc;
}
.unit h4 {
  margin-top: 20px;
  font-size: 1.5rem;
}
form#views-exposed-form-seoul-survey-page-1 {
  margin-top: -130px;
  text-align: right;
}
.cf09 {
  margin-bottom: 3rem;
}

/*연관콘텐츠 */
.div-line {
  width: 100%;
  margin: 4rem 0;
  border-bottom: 1px solid #ddd;
}

/*제안하기 */
.suggest-form label.js-form-required.form-required {
  width: 100px;
  display: block;
  padding: 10px 0;
}
.suggest-form #edit-file--label {
  width: 100px;
  display: block;
  padding: 10px 0;
}
.suggest-form #edit-submit {
  padding: 10px 30px;
  background-color: #008dea;
  border: 1px solid #008dea;
  color: #fff;
}
.suggest-form #edit-actions {
  text-align: center;
}

/* 사진 상세 */
.fc04 .thumb img.fillheight {
  height: 100%;
  width: auto;
}
.fc04 .thumb {
  background: #000;
  height: 30rem;
}
.thumb-title {
  font-size: 12px;
  background: #fff;
  padding: 8px 5px;
  color: #000;
}
.viewPicture .slick-slide {
  border: 1px solid #ccc;
}

/* 미래유산 */

.archi .inner {
  display: flex;
}
.archi aside {
  width: 240px;
}
.archi .tc01 {
  width: 900px;
  margin-left: 40px;
}
:root {
  --primary: #008dea;
  --sub: #f3fbff;

  --gray50: #fafafa;
  --gray100: #f4f4f5;
  --gray200: #e4e4e7;
  --gray300: #d4d4d8;
  --gray400: #a1a1aa;
  --gray500: #71717a;
  --gray600: #52525b;
  --gray700: #3f3f46;
  --gray800: #27272a;
  --gray900: #18181b;

  --warning: #fd4545;
  --confirm: #0aeea2;
  --processing: #2e78f1;

  --regular: 400;
  --medium: 500;
  --bold: 700;
}
/*************************/
/*.lc01 {
width: 30%;
z-index: 2;
box-shadow: 4px 0px 20px rgba(0, 0, 0, 0.1);
}*/
.archi .side-bar {
  width: 100%;
}
.archi .tab-box {
  display: flex;
  width: 100%;
}
.archi .tab {
  width: 50%;
  text-align: center;
  padding: 12px 0;
  border-bottom: 1px solid #ddd;
  cursor: pointer;
}
.archi .tab.active {
  border-bottom: 4px solid var(--primary);
  color: var(--primary);
}
.archi .route {
  width: 100%;
  padding: 16px;
}
.archi .route-titles {
  border: 1px solid #ddd;
  border-radius: 10px;
}
.archi .route-title {
  padding: 10px;
  border-bottom: 1px solid #ddd;
  font-size: 15px;
  cursor: pointer;
}

.route-title.last {
  border: none;
}
.route-title.active {
  background-color: #eee;
}

.archi th {
  text-align: left;
}
.archi td {
  text-align: left;
}
.archi tr {
  border-bottom: 1px solid #9d9d9d;
}

/* 모니터링 메뉴 */
.archi ul.menu {
  margin-left: 0;
}
.archi ul.menu .menu .menu {
  margin-left: 8px;
}

.archi ul.menu a,
.archi ul.menu span {
  color: #595959;
  font-size: 13px;
}
.archi aside > .menu > li.menu-item > .menu > li.menu-item > a {
  display: block;
  color: #424242;
  font-size: 13px;
  border-bottom: 1px solid #ddd;
  padding: 8px 0;
  font-weight: 400;
}
.archi aside > .menu > li.menu-item > a,
.archi aside > .menu > li.menu-item > span {
  display: block;
  color: #424242;
  font-size: 13px;
  border-bottom: 1px solid #ddd;
  padding: 16px 0;
  font-weight: 600;
  cursor: pointer;
}
.archi .menu-item--expanded {
  list-style-type: none;
  list-style-image: none;
}
.archi .menu-item--expanded .menu-item {
  padding: 0;
}
.archi .menu-item--expanded .menu-item a {
  padding: 8px 0;
  display: block;
}

.archi aside > .menu > .menu-item--expanded > .menu {
  display: none;
}
.archi aside > .menu > .menu-item--expanded.menu-item--active-trail > .menu {
  display: block;
}
.archi .menu-item--active-trail .is-active,
.archi .menu-item--active-trail > span {
  color: #008dea !important;
  font-weight: 600;
  text-decoration: underline;
}

/* 필터영역 */
.filterHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 8px;
  border-bottom: 1px solid #e3e3e3;
}

.titleBar {
  color: var(--gray500);
  cursor: pointer;
}

.listItem {
  font-size: 16px;
  padding: 5px 12px;
}

.discovery label {
  display: flex;
  align-items: center;
}
.discovery a {
  color: #595959;
}
.discovery .active {
  font-weight: 600;
  text-decoration: underline;
}

.colorLabel {
  border-radius: 50%;
  display: block;
  width: 16px;
  height: 16px;
  margin: 0 4px;
}

#AColor {
  background-color: rgb(192, 0, 0);
}

#BColor {
  background-color: rgb(255, 192, 0);
}

#CColor {
  background-color: rgb(191, 144, 0);
}

#DColor {
  background-color: rgb(0, 112, 192);
}

#EColor {
  background-color: rgb(112, 48, 160);
}

/* checkbox
input[type="checkbox"] {
  display: none;
}

input[type="checkbox"] + label {
  cursor: pointer;
}
*/
.discovery input[type="checkbox"] + label:before {
  content: "";
  width: 13px;
  height: 13px;
  line-height: 13px;
  margin: 2.5px;
  margin-right: 6.5px;
  border: 2px solid var(--gray300);
  border-radius: 2px;
  vertical-align: middle;
}

.discovery input[type="checkbox"]:checked + label:before {
  content: "\f00c";
  font-family: "Font Awesome 5 free";
  font-weight: 700;
  color: #fff;
  background-color: var(--primary);
  border-color: var(--primary);
  font-size: 12px;
  text-align: center;
}

#layerItem {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-right: 8px;
}

.opacitySlider {
  -webkit-appearance: none;
  width: 90px;
  height: 6px;
  border-radius: 4px;
  border: 1px solid var(--gray300);
  background: var(--gray200);
  outline: none;
  -moz-transition:
    background-color 0.2s ease,
    border 0.2s ease;
  -webkit-transition:
    background-color 0.2s ease,
    border 0.2s ease;
  transition:
    background-color 0.2s ease,
    border 0.2s ease;
}

.opacitySlider:hover {
  background: var(--primary);
  border: 2px var(--primary) solid;
}

.opacitySlider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fafafa;
  border: 2px var(--gray200) solid;
  cursor: pointer;
  transition: border 0.2s ease;
  -webkit-transition: border 0.2s ease;
}

.opacitySlider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fafafa;
  border: 2px var(--gray200) solid;
  cursor: pointer;
  transition: border 0.2s ease;
  -moz-transition: border 0.2s ease;
}

.opacitySlider::-webkit-slider-thumb:hover {
  border: 2px solid var(--primary);
}

.opacitySlider::-moz-range-thumb:hover {
  border: 2px solid var(--primary);
}
#overlay {
  display: none;
  position: absolute;
  bottom: 0;
  margin-bottom: 16px;
  padding: 16px;

  width: 789px;
  height: 237px;
  overflow: hidden;
  background-color: #fff;
  border-radius: 8px;
  z-index: 3;

  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}

#closeBtn {
  position: absolute;
  cursor: pointer;
  right: 8px;
  top: 8px;
}

.pos-title {
  margin-bottom: 8px;
}

#overlayTitle {
  font-weight: var(--bold);
  font-size: 24px;
  line-height: 36px;
}

.architTypeTag {
  display: inline-block;
  font-size: 14px;
  margin-bottom: 8px;
  margin-right: 12px;
  padding: 6px 12px;
  border-radius: 8px;
}

#tagA {
  color: rgb(192, 0, 0);
  background-color: rgb(192, 0, 0, 0.18);
}

#tagB {
  color: rgb(255, 192, 0);
  background-color: rgb(255, 192, 0, 0.18);
}

#tagC {
  color: rgb(191, 144, 0);
  background-color: rgb(191, 144, 0, 0.18);
}

#tagD {
  color: rgb(0, 112, 192);
  background-color: rgb(0, 112, 192, 0.18);
}

#tagE {
  color: rgb(112, 48, 160);
  background-color: rgb(112, 48, 160, 0.18);
}

#overlayContent {
  white-space: pre-wrap;
  height: 124px;
  overflow: auto;
  line-height: 24px;
}

#titleRow {
  display: flex;
}

#overlayImg {
  display: block;
  object-fit: contain;
  margin-right: 16px;
  width: 300px;
  height: 205px;
}

#mask {
  position: absolute;
  z-index: 999;
  background-color: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  top: 0;
  opacity: 0.3;
}

#spinner {
  width: 240px;
  height: 240px;
  margin: 20px;
  display: inline-block;
}

.swal2-container.swal2-center > .swal2-popup {
  grid-row: 1 !important;
}

#lnb.fixed {
  position: fixed;
  width: 240px;
  top: 100px;
}

/* anniv */
.anniv {
  right: 0;
  position: absolute;
  top: 1.4rem;
}
header ul.menu {
  right: 29rem !important;
}
header .cf01 {
  right: 12rem !important;
}
.cf01 input {
  width: 11.25rem;
}

.photo-subinfo {
  width: 600px;
  padding: 20px;
  max-width: 600px;
  position: absolute;
  top: 120px;
  left: 50%;
  margin-left: -300px;
  z-index: 99;
  background-color: #fff;
  border: 1px solid #ddd;
  line-height: 1.1;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
  display: none;
}

.photo-subinfo td {
  text-align: left;
  line-height: 1.4;
  padding: 10px;
}
/*.photo-subinfo ol {
  list-style: disc;
}*/
.photo-subinfo h4 {
  line-height: 1.5;
}
.photo-subinfo table {
  margin-top: 20px;
  border: 1px solid #ddd;
}
.modal-header {
  height: 30px;
  text-align: right;
}
.group-info {
  position: absolute;
  padding: 10px;
}
.pager li > a,
.pager li > span {
  padding: 0;
}
@media screen and (min-width: 320px) and (max-width: 1023px) {
  .anniv {
    right: 70px;
    top: 10px;
    width: 90px;
  }
  .anniv img {
    height: auto;
  }

  header ul.menu > li > .sub-menu .ng03 dl dd ul.btns li a {
    width: 70px;
    height: 30px;
    line-height: 32px;
    border-radius: 15px;
    font-size: 12px;
    text-align: center;
    text-indent: 0;
  }
}
/* anniv */
.anniv img {
  height: 50px;
}
/*                         */
@media screen and (min-width: 320px) and (max-width: 768px) {
  .ib02 .leftA {
    z-index: 9;
  }
  .photo-subinfo {
    width: 80%;
    left: 50%;
    margin-left: -45%;
    display: none;
  }
  .group-info {
    top: -15px;
  }
  .th01.photoCollect {
    position: relative;
  }
  .pp02 .popupBox {
    position: fixed !important;
  }
  .anniv {
    right: 70px;
    top: 10px;
    width: 90px;
  }
  .anniv img {
    height: auto;
  }
  .tc01 .unit {
    margin-bottom: 0 !important;
  }
  .ib03 > dl > dd {
    height: auto;
  }
  footer .policy {
    float: none;
    clear: both;
    margin-bottom: 20px;
  }

  .lc06 li {
    width: 100% !important;
    margin-right: 4%;
    margin-bottom: 4%;
  }
  .lc06 li a {
    height: 200px !important;
  }
  header ul.menu > li > .sub-menu .ng03 dl dd ul.btns li a {
    width: 100px !important;
    font-size: 12px !important;
  }

  #lnb.fixed {
    position: fixed;
    width: 100%;
    top: 0px;
    background-color: #fff;
    margin-left: -16px;
  }
  .archi aside {
    width: 100%;
  }
  .archi .inner {
    display: block;
  }
  .archi .tc01 {
    width: 100%;
    margin: 0;
  }
  .filterHeader {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 5px 8px;
    border-bottom: 1px solid #e3e3e3;
  }
  #lnb.fixed .filterHeader {
    padding: 5px 24px;
    border-bottom: 1px solid #b5b5b5;
  }
  .listItem {
    font-size: 12px;
    padding: 5px 12px;
  }
  .tc01 .dataGraph .btnA {
    height: auto;
  }
}

.fc01 .bodyA ul {
  list-style: disc;
  margin-left: 20px;
}
.fc01 .bodyA ol {
  list-style: decimal;
  margin-left: 20px;
}

.dataCategory ul.categoryA {
  list-style: none;
  margin-left: 20px;
}
.fc01.sisurvey ul {
  list-style: none;
  margin-left: 20px;
}

.dataGraph ul.tabMenu {
  list-style: none;
  margin-left: 20px;
}

.bodyA h4 {
  font-size: 1.2rem;
  margin: 10px 0;
  word-break: keep-all;
}

.lc06 li a:hover {
  transform: scale(1.03);
}
.lc06 li a span:hover {
}
.lc06 li a span {
  position: absolute;
  bottom: 50px;
  left: 0;
  width: 100%;
  padding: 0 2rem 2rem 2rem;
  box-sizing: border-box;
  z-index: 1;
  color: #fff !important;
}
.lc06 li a span h5,
.lc06 li a span h4 {
  color: #fff !important;
  font-weight: 400;
}

.lc06 li a span h3 {
  color: #fff !important;
  font-size: 1.2rem;
}

.lc06 li strong {
  color: #fff;
  font-size: 1.2rem;
}
.lc06 li {
  float: left;
  width: 31%;
  margin-right: 3%;
  margin-bottom: 2%;
}
.lc02 li > a b span {
  width: 65%;
}

header .logo {
  top: 1rem;
}
header .logo a {
  height: 3.6rem;
}

.cf03_01 ul li .select2 {
  float: left;
  width: 28rem !important;
}
.popup_tb tr {
  border: none !important;
}

.popup_tb th {
  text-align: left !important;
  vertical-align: top;
  padding: 10px;
}
.popup_tb td {
  text-align: left !important;
  vertical-align: top;
  padding: 10px;
}

.ppBody .row {
  text-align: center !important;
  padding: 5px;
}
.pp02 .popupBox {
  width: 34rem;
}
/* 모달 팝업이 GNB(z-index:200) 위에 표시되도록 */
.pp01 .bgBlack {
  z-index: 300;
  transition: none !important;
  animation: none !important;
}
.pp01 .popupBox {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  max-width: 960px;
  width: calc(100% - 32px) !important;
  max-height: 90vh;
  overflow: hidden auto !important;
  z-index: 301;
  transition: none !important;
  animation: none !important;
  padding: 0 !important;
}
.pp01 .popupBox .ppBody {
  padding: 1.875rem;
  padding-top: 0;
}
.pp01 .popupBox h4 {
  padding: 1.875rem 1.875rem 0;
}
.pp01 .popupBox a.close {
  position: sticky;
  top: 0;
  float: right;
  z-index: 400;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 1.25rem;
  text-decoration: none;
  transition: background 0.2s;
  margin-top: -2.5rem;
}
.pp01 .popupBox a.close:hover {
  background: rgba(0, 0, 0, 0.85);
}
.pp02 .bgBlack {
  z-index: 300;
}
.pp02 .popupBox {
  z-index: 301;
}
/* iframe map */
.map04.leaflet-container.leaflet-fade-anim {
  height: 166px;
}

.con02 .fillheight {
  width: 157px;
  height: auto;
}
.tbl01 tbody td > .con01 {
  overflow: hidden;
  float: left;
  margin-right: 20px;
}
.tbl01 tbody td > .con02 {
  overflow: hidden;
  float: left;
  margin-right: 20px;
}
/****/

.table-1014 th {
  text-align: left;
  width: 120px;
}
.table-1014 td {
  text-align: left;
}
.box-1014 td {
  text-align: left;
  padding: 30px;
}
.box-1014 td p {
  margin: 0 !important;
}
.box-1014 {
  background-color: #efefef;
  border: 1px solid #ddd;
}

/* map */

.pull {
  position: absolute;
  bottom: -20px;
  width: 50px;
  height: 20px;
  left: 50%;
  margin-left: -25px;
  cursor: pointer;
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 5px;
  background: #009aff url(../images/arrow_white_b.png) no-repeat left 18px
    center;
  z-index: 99;
}

.pull.opened {
  background: #009aff url(../images/arrow_white_t.png) no-repeat left 18px
    center;
}

.ng03 dl dd ul.btns li a {
  width: 88%;
}
.pos-info {
  background: #64d1fb;
  width: 60px;
  height: 50px;
  text-align: center;
  border: 10px solid #b4dceb;
  border-radius: 40px;
  color: #fff;
  line-height: 1.3;
  font-size: 14px;
  /*opacity: .85;*/
  padding-top: 10px;
}

#slideonmap {
  z-index: 9;
  max-width: 100%;
  position: absolute;
  /*left: 50%;
    margin-left: -250px;
    height: 70px;*/
  bottom: -116px;
  background-color: #f6f6f6;
  display: none;
  overflow-x: auto;
  width: 100%;
}
#slideonmap {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#slideonmap::-webkit-scrollbar {
  display: none;
}
#slideonmap img {
  width: auto;
  border: 1px solid #888;
  height: 110px;
}
.slide-box {
  display: flex;
  min-width: 100px;
}
.photo-sm {
  margin: 0 2px;
}
.slick-prev {
  left: 5px;
  z-index: 9;
}
.slick-next {
  right: 5px;
  z-index: 9;
}

ul.btns {
  padding-left: 0;
}
header ul.menu > li > .sub-menu .ng03 dl dd ul.btns.mr li a {
  border-color: #b8cbd6;
  background-color: #fff;
  font-size: 0.6rem;
}

.map01.photo01 {
  margin-bottom: 6.875rem;
}
.map02.photo01 {
  margin-bottom: 7rem;
}
.fc01 {
  /*padding-top: 5rem;*/
  padding-bottom: 5rem;
}

.slide-related {
  margin-top: 15px;
}
.slide-related img {
  width: 100%;
  max-height: 104px;
}

.tc01 .dataCategory .pdfA a.pdf {
  background-image: none;
  padding: 0;
}
.fc04 {
  margin: 0.5rem auto 5.125rem;
}

em.date {
  float: right;
  font-size: 0.75rem;
  color: #7d7d7d;
  font-weight: normal;
}

.ib02 .leftA.fullWidth {
  float: left;
  width: 100%;
  height: 22.125rem;
  position: relative;
}

/* dxpr */
.dxpr {
  margin: 60px 0;
}

.btn-primary {
  background-color: #008dea;
  border: none;
}

.bg-primary {
  color: #fff;
  background-color: #008dea;
}
.progress-bar {
  background-color: #008dea;
}
.dxpr .az-image-content {
  max-width: 100% !important;
}

/*.dxpr h2 {
    margin: 20px 0;
}*/

/*
.grid figure {
  position: relative;
  float: left;
  overflow: hidden;
  margin: 10px 1%;
  min-width: 320px;
  max-width: 480px;
  max-height: 360px;
  width: 48%;
  background: #3085a3;
  text-align: center;
  cursor: pointer;
}
figure.effect-chico:hover img {
  opacity: 0.5;
  -webkit-transform: scale(1);
  transform: scale(1);
}
figure.effect-chico img {
  -webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
  transition: opacity 0.35s, transform 0.35s;
  -webkit-transform: scale(1.12);
  transform: scale(1.12);
}
.grid figure img {
  position: relative;
  display: block;
  min-height: 100%;
  max-width: 100%;
  opacity: 0.8;
}
figure.effect-chico figcaption {
  padding: 3em;
}
.grid figure figcaption, .grid figure figcaption > a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.grid figure figcaption {
  padding: 2em;
  color: #fff;
  text-transform: uppercase;
  font-size: 1.25em;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
figure {
  display: block;
}
figure.effect-chico h2 {
  padding: 20% 0 20px 0;
}
.grid figure h2, .grid figure p {
  margin: 0;
}
.grid figure h2 {
  word-spacing: -0.15em;
  font-weight: 300;
}
.grid figure h2 span {
  font-weight: 800;
}
figure.effect-chico:hover figcaption::before, figure.effect-chico:hover p {
  opacity: 1;
  -webkit-transform: scale(1);
  transform: scale(1);
}
figure.effect-chico p {
  margin: 0 auto;
  max-width: 200px;
  -webkit-transform: scale(1.5);
  transform: scale(1.5);
}
figure.effect-chico figcaption::before, figure.effect-chico p {
  opacity: 0;
  -webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
  transition: opacity 0.35s, transform 0.35s;
}
.grid figure p {
  letter-spacing: 1px;
  font-size: 68.5%;
}
.grid figure h2, .grid figure p {
  margin: 0;
}
.grid figure figcaption > a {
  z-index: 1000;
  text-indent: 200%;
  white-space: nowrap;
  font-size: 0;
  opacity: 0;
}
.grid figure figcaption, .grid figure figcaption > a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}*/

.tc01 .content-list .gridItemCard {
  width: 100%;
  padding: 0.3rem 2.125rem 3rem;
  box-sizing: border-box;
  word-break: keep-all;
  height: 350px;
}
.si-card.item {
  float: left;
  width: 25%;
  text-align: center;
}
.gridItemCard .card-img {
  height: 180px;
}
.gridItemCard img {
  width: 50%;
  height: auto;
  border: 1px solid #ddd;
  display: block;
  margin: 0 auto;
  box-shadow: 5px 5px 5px #ddd;
}
.gridItemCard a:hover b {
  color: #008dea;
}
.gridItemCard a b {
  display: block;
  font-size: 1rem;
  margin-bottom: 0.5rem;
  font-weight: 400;
}
.gridItemCard a em {
  display: block;
  font-size: 0.875rem;
  color: #434343;
  max-height: 6.6rem;
  margin-bottom: 0.5rem;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gridItemCard a i {
  display: block;
  font-style: normal;
  font-size: 0.75rem;
  color: #aaa;
}

.clear-both {
  clear: both;
  margin-bottom: 10px;
}
.si-card.item.invisible {
  display: none;
}
.category-li {
  margin: 10px;
  padding: 5px 20px;
  background: #f6f6f6;
  border-radius: 10px;
}
.category-ul {
  display: flex;
  width: 900px;
  margin: 0 auto;
  margin-bottom: 2.5rem;
}
.category-li a {
  color: #666;
}
.category-li.active a {
  color: #fff;
}
.category-li.active {
  background: #008dea;
}

#nid-65372 .header {
  display: none;
}
#nid-65387 .header {
  display: none;
}
.si-card.views-row {
  padding: 20px 15px;
  border-bottom: 1px solid #ddd;
}

.breadcrumb {
  margin-bottom: 0;
  display: flex;
  align-items: center;
}

footer .siteInfo address {
  margin-bottom: 0;
}
/*footer .inner div{
  display: flex;
}*/

.ng03 dl.d05 {
  float: left;
  width: 25%;
  margin-right: 1.7%;
  box-sizing: border-box;
  padding-right: 1rem;
}
.ng03 dl.d05 li {
  font-size: 0.875rem;
  color: #434343;
  word-break: keep-all;
}

@media screen and (min-width: 320px) and (max-width: 1023px) {
  .si-card.item {
    float: left;
    width: 50%;
    text-align: center;
  }
  .gridItemCard img {
    width: 115px;
    height: auto;
    border: 1px solid #ddd;
    display: block;
    margin: 0 auto;
    box-shadow: 5px 5px 5px #ddd;
  }
  .category-ul {
    display: block;
    width: 80%;
    margin: 0 auto;
    margin-bottom: 2.5rem;
  }
  .category-li {
    float: left;
    height: 21px;
  }
  /*    footer .inner div{
      display: block;
    }*/
}

@media screen and (min-width: 320px) and (max-width: 768px) {
  .si-card.item {
    float: left;
    width: 50%;
    text-align: center;
  }
  .gridItemCard img {
    width: 115px;
    height: auto;
    border: 1px solid #ddd;
    display: block;
    margin: 0 auto;
    box-shadow: 5px 5px 5px #ddd;
  }
  .category-ul {
    display: block;
    width: 80%;
    margin: 0 auto;
    margin-bottom: 2.5rem;
  }
  .category-li {
    float: left;
    height: 21px;
  }
  /*    footer .inner div{
      display: block;
    }*/
}

/* AI 분석 정보 섹션 - 사진 상세 */
li.ai-analysis {
  list-style: none;
  margin-top: 20px;
  padding: 0 !important;
  padding-left: 0 !important;
  background-image: none !important;
  display: block !important;
  border-bottom: none !important;
}
.ai-analysis--full {
  width: 100%;
  clear: both;
  margin-top: 20px;
  margin-bottom: 20px;
  border-radius: 6px;
  overflow: hidden;
}
.ai-analysis__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  background: #eef4fb;
  border-radius: 6px;
  cursor: pointer;
  user-select: none;
}
.ai-analysis__title {
  font-weight: 700;
  font-size: 15px;
  color: #3a7bd5;
}
.ai-analysis__title i {
  margin-right: 4px;
  font-size: 14px;
}
.ai-analysis__badge {
  font-size: 12px;
  color: #9ab0c8;
}
.ai-analysis__body {
  padding: 16px;
  background: #fff;
}
.ai-analysis__label {
  display: block !important;
  font-size: 13px;
  color: #888;
  margin-bottom: 10px;
}
.ai-analysis__desc {
  display: block;
}
.ai-analysis__desc p {
  font-size: 14px;
  line-height: 1.5;
  color: #333;
  margin: 0;
  word-break: keep-all;
}
.ai-analysis__keywords {
  margin-bottom: 18px;
}
.ai-keywords {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.ai-keyword-chip {
  display: inline-block;
  padding: 5px 14px;
  background: #e8f0fe;
  color: #3a7bd5;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition:
    background 0.2s,
    color 0.2s;
}
.ai-keyword-chip:hover {
  background: #3a7bd5;
  color: #fff;
}
/* AI 분석 정보 - 컬렉션 팝업 (topA 하단 full-width) */
.ai-analysis--popup {
  margin-top: 16px;
  margin-bottom: 20px;
  clear: both;
  width: 100%;
}
.ai-analysis__badge i {
  margin-left: 4px;
  font-size: 12px;
  transition: transform 0.2s;
}

/* 사진 유형 툴팁 */
.photo-type-tooltip-wrap {
  position: relative;
  cursor: pointer;
}
.photo-type-tooltip-wrap .xi-info {
  color: #888;
}
.photo-type-tooltip {
  display: none;
  position: absolute;
  bottom: calc(100% + 8px);
  left: 0;
  white-space: nowrap;
  background: #333;
  color: #fff;
  font-size: 0.85rem;
  padding: 6px 12px;
  border-radius: 4px;
  z-index: 10;
  font-weight: normal;
}
.photo-type-tooltip::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 16px;
  border: 6px solid transparent;
  border-top-color: #333;
}
.photo-type-tooltip-wrap:hover .photo-type-tooltip {
  display: block;
}

/* 좌우 네비게이션 버튼 */
#slideonmap .slide-track {
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none;
  scrollbar-width: none;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}
#slideonmap .slide-track::-webkit-scrollbar {
  display: none;
}
#slideonmap img:hover {
  opacity: 0.8;
}
.slide-nav {
  position: absolute;
  top: 0;
  z-index: 10;
  width: 32px;
  height: 100%;
  border: none;
  background: rgba(0, 0, 0, 0.35);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s;
  padding: 0;
}
.slide-nav:hover {
  background: rgba(0, 0, 0, 0.55);
}
.slide-nav.disabled {
  opacity: 0.3;
  cursor: default;
  pointer-events: none;
}
.slide-prev {
  left: 0;
  border-radius: 0 4px 4px 0;
}
.slide-next {
  right: 0;
  border-radius: 4px 0 0 4px;
}
/* 사진 건수 표시 */
.slide-count {
  position: absolute;
  top: 4px;
  right: 40px;
  z-index: 10;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 10px;
}

/* ============================================
   패싯 필터 패널
   ============================================ */

.facet-panel {
  margin-bottom: 20px;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  background: #fafafa;
}

.facet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  border-bottom: 1px solid #e0e0e0;
}

.facet-toggle-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: #333;
  padding: 0;
}

.facet-toggle-arrow {
  font-size: 10px;
  transition: transform 0.2s;
  color: #888;
}

.facet-toggle-arrow.rotated {
  transform: rotate(180deg);
}

.facet-active-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  border-radius: 10px;
  background: #2563eb;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 0 6px;
}

.facet-clear-btn {
  background: none;
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 4px 10px;
  font-size: 12px;
  color: #666;
  cursor: pointer;
  transition: all 0.2s;
}

.facet-clear-btn:hover {
  border-color: #999;
  color: #333;
  background: #f0f0f0;
}

.facet-body {
  display: none;
  padding: 12px 16px;
}

.facet-body-open {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.facet-group {
  flex: 1;
  min-width: 200px;
}

.facet-group-title {
  font-size: 13px;
  font-weight: 600;
  color: #555;
  margin: 0 0 8px 0;
  padding-bottom: 6px;
  border-bottom: 1px solid #e8e8e8;
}

.facet-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 200px;
  overflow-y: auto;
}

.facet-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  color: #444;
  transition: background 0.15s;
}

.facet-item:hover {
  background: #e8edf3;
}

.facet-item-active {
  background: #dbeafe;
  color: #1d4ed8;
  font-weight: 600;
}

.facet-item-active:hover {
  background: #bfdbfe;
}

.facet-label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-right: 8px;
}

.facet-count {
  flex-shrink: 0;
  font-size: 11px;
  color: #999;
  background: #eee;
  border-radius: 8px;
  padding: 1px 6px;
  min-width: 20px;
  text-align: center;
}

.facet-item-active .facet-count {
  background: #93c5fd;
  color: #1e40af;
}

/* count=0인 패싯 항목 비활성화 스타일 */
.facet-item-disabled {
  opacity: 0.45;
  cursor: default;
}

.facet-item-disabled:hover {
  background: transparent;
}

.facet-item-disabled .facet-count {
  background: #f5f5f5;
  color: #bbb;
}

/* 모바일: 패싯 접히기/열림 토글 */
@media (max-width: 768px) {
  .facet-body-open {
    flex-direction: column;
    gap: 12px;
  }

  .facet-group {
    min-width: auto;
  }

  .facet-list {
    max-height: 150px;
  }
}

/* 데스크톱: 패싯 기본 열림, 토글 버튼 숨김 */
@media (min-width: 769px) {
  .facet-body {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    padding: 12px 16px;
  }

  .facet-header {
    border-bottom: none;
    padding-bottom: 0;
  }

  .facet-toggle-btn {
    display: none;
  }
}

/* ── Error Pages (403 / 404) ── */
.error-page {
  text-align: center;
  padding: 80px 20px 120px;
  min-height: 50vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.error-page__code {
  font-size: 120px;
  font-weight: 800;
  color: #1a3a5c;
  line-height: 1;
  margin-bottom: 16px;
}
.error-page__title {
  font-size: 28px;
  font-weight: 700;
  color: #222;
  margin: 0 0 16px;
}
.error-page__message {
  font-size: 16px;
  color: #666;
  line-height: 1.7;
  margin: 0 0 40px;
  word-break: keep-all;
}
.error-page__actions {
  display: flex;
  gap: 12px;
  justify-content: center;
}
.error-page__btn {
  display: inline-block;
  padding: 12px 32px;
  border-radius: 4px;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  transition:
    background-color 0.2s,
    color 0.2s;
}
.error-page__btn--primary {
  background-color: #1a3a5c;
  color: #fff;
}
.error-page__btn--primary:hover {
  background-color: #0f2a45;
  color: #fff;
}
.error-page__btn--secondary {
  background-color: #e9ecef;
  color: #333;
}
.error-page__btn--secondary:hover {
  background-color: #dee2e6;
  color: #333;
}
@media (max-width: 768px) {
  .error-page {
    padding: 60px 16px 80px;
  }
  .error-page__code {
    font-size: 80px;
  }
  .error-page__title {
    font-size: 22px;
  }
  .error-page__actions {
    flex-direction: column;
  }
}

/* 팝업 btnA: 다운로드 가로 배치 */
.ib04 .btnA {
  display: flex;
}
/* 팝업 meta dl 디바이더 */
.ib04 .meta dl + dl {
  border-top: 1px solid #eee;
  padding-top: 6px;
  margin-top: 6px;
}

/* 사진 다운로드 이용목적 셀렉트 */
.photo-download-group {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.photo-purpose-select {
  height: 40px;
  padding: 0 12px;
  font-size: 14px;
  color: #333;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 5px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23666'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px;
  cursor: pointer;
  flex: 1;
  min-width: 0;
}
.photo-purpose-select:focus {
  border-color: #70bef1;
  outline: none;
  box-shadow: 0 0 0 2px rgba(112, 190, 241, 0.2);
}
.photo-download-group .btn01 {
  height: 40px;
  line-height: 40px;
  padding: 0 1rem;
  box-sizing: border-box;
  white-space: nowrap;
}
.photo-purpose-detail {
  flex-basis: 100%;
  height: 40px !important;
  padding: 0 12px;
  font-size: 14px;
  color: #333;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 5px;
  min-width: 0;
  box-sizing: border-box;
  text-indent: 0 !important;
}
.photo-purpose-detail:focus {
  border-color: #70bef1;
  outline: none;
  box-shadow: 0 0 0 2px rgba(112, 190, 241, 0.2);
}

/* 모바일: select + 버튼 50/50 */
@media (max-width: 768px) {
  .photo-download-group {
    gap: 6px;
  }
  .photo-purpose-select {
    flex: 1 1 calc(50% - 3px);
  }
  .photo-download-group .btn01 {
    flex: 1 1 calc(50% - 3px);
    text-align: center;
  }
}

/* 저작권 영역 하단 배치 */
.copyright--bottom {
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid #eee;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 8px;
}
.copyright--bottom > a {
  flex: 1 1 calc(50% - 4px);
  height: auto !important;
}
.copyright--bottom > a img {
  width: 100%;
  height: auto !important;
  display: block;
}
.copyright-guide {
  margin: 8px 0 0;
  font-size: 13px;
  text-align: right;
  flex-basis: 100%;
}

/* 사진 노드 페이지: control + copyright를 meta/map과 동일 비율로 배치 */
.fc04 .photo-sub-row {
  clear: both;
  overflow: hidden;
  margin-bottom: 12px;
}
.fc04 .photo-sub-left {
  float: left;
  width: 62%;
  box-sizing: border-box;
  padding-top: 8px;
}
.fc04 .photo-sub-right {
  float: right;
  width: 35%;
  box-sizing: border-box;
  padding-top: 8px;
}
.fc04 .photo-sub-right .copyright--bottom {
  border-top: none;
  margin-top: 0;
  padding-top: 0;
}

/* 모바일: photo-sub-row 세로 배치 */
@media (max-width: 1023px) {
  .fc04 .photo-sub-row {
    clear: both;
  }
  .fc04 .photo-sub-left {
    float: none;
    width: auto;
    padding-top: 0;
    margin-bottom: 12px;
  }
  .fc04 .photo-sub-right {
    float: none;
    width: auto;
    padding-top: 0;
  }
  .fc04 .photo-sub-right .copyright--bottom {
    border-top: 1px solid #eee;
    margin-top: 8px;
    padding-top: 8px;
  }
}
.copyright-guide a {
  color: #555;
  text-decoration: none;
}
.copyright-guide a:hover {
  color: #208ad0;
  text-decoration: underline;
}
.copyright-guide i {
  margin-right: 4px;
}

/* 파노라마 전체화면 팝업 */
.pp-panorama-fullscreen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pp-panorama-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
}
.pp-panorama-container {
  position: relative;
  width: 90%;
  max-height: 90vh;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.pp-panorama-close {
  position: absolute;
  top: -2.5rem;
  right: 0;
  color: #fff;
  font-size: 1.5rem;
  z-index: 2;
}
.pp-panorama-close:hover {
  color: #ccc;
}
.pp-panorama-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  max-height: 85vh;
  border-radius: 4px;
  background: #000;
  cursor: grab;
  -webkit-overflow-scrolling: touch;
  display: flex;
  justify-content: center;
}
.pp-panorama-scroll.is-dragging {
  cursor: grabbing;
  user-select: none;
}
.pp-panorama-scroll img {
  display: block;
  height: 85vh;
  width: auto;
  max-width: none;
  pointer-events: none;
}
/* 파노라마 아이콘 클릭 커서 */
.ib03 .slider li.wide {
  cursor: zoom-in;
}
/* 파노라마 미니맵 네비게이터 */
.pp-panorama-nav {
  position: relative;
  width: 100%;
  height: 50px;
  margin-top: 10px;
  border-radius: 3px;
  overflow: hidden;
  background: #111;
}
.pp-panorama-nav img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
}
.pp-panorama-nav-box {
  position: absolute;
  top: 0;
  height: 100%;
  border: 2px solid #fff;
  border-radius: 2px;
  box-sizing: border-box;
  pointer-events: none;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.4);
}

/* 프론트페이지 이용안내 플로팅 버튼 */
.front-help-fab {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 200;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  border: none;
  background: #427ec4;
  color: #fff;
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  transition:
    background 0.2s,
    transform 0.2s;
}
.front-help-fab:hover {
  background: #2d5f9e;
  transform: scale(1.08);
}

/* 이용안내 모달 */
.front-help-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9000;
}
.front-help-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
}
.front-help-box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 800px;
  max-height: 85vh;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.front-help-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid #eee;
  flex-shrink: 0;
}
.front-help-header h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
}
.front-help-close {
  border: none;
  background: none;
  font-size: 1.25rem;
  cursor: pointer;
  color: #666;
  padding: 0.25rem;
}
.front-help-close:hover {
  color: #000;
}
.front-help-body {
  padding: 1.5rem;
  overflow-y: auto;
  flex: 1;
  line-height: 1.8;
  font-size: 15px;
}
.front-help-body h2 {
  font-size: 1.3rem;
  margin-top: 1.5rem;
}
.front-help-body h3 {
  font-size: 1.1rem;
  margin-top: 1.2rem;
}
.front-help-body h4 {
  font-size: 1rem;
  margin-top: 1rem;
}
.front-help-body img {
  max-width: 100%;
  height: auto;
  border-radius: 4px;
  margin: 0.5rem 0;
}
.front-help-body table {
  width: 100%;
  margin: 0.5rem 0;
}

@media (max-width: 768px) {
  .front-help-fab {
    bottom: 1rem;
    right: 1rem;
    width: 3rem;
    height: 3rem;
    font-size: 1.25rem;
  }
  .front-help-box {
    width: 95%;
    max-height: 90vh;
    border-radius: 8px;
  }
  .front-help-body {
    padding: 1rem;
    font-size: 14px;
  }
}
