@charset "utf-8";

.active {border:none !important;}

::selection {
	background-color: #00a2ad;
	color: #fff;
}

body.scroll-disabled {
    overflow: hidden !important
}


.slow, .slow img, .slow a, .slow p, .slow li, .slow td, .slow input, .slow button, .slow select.slow textarea, .slow em, .slow img, .slow span, .slow hr, .slow h1, .slow h2, .slow h3, .slow h4, .slow h5, .slow h6, .slow b, .slow before, .slow after {
    -moz-transition: all 0.5s cubic-bezier(0.77,0,0.175,1);
    -webkit-transition: all 0.5s cubic-bezier(0.77,0,0.175,1);
    -ms-transition: all 0.5s cubic-bezier(0.77,0,0.175,1);
    transition: all 0.5s cubic-bezier(0.77,0,0.175,1);
}

.bg_test {
  width: 200px;
  height: 200px;
  background-image: url(/skin11/web/upload/idealnew/asset/img/laser.png);
  background-repeat: no-repeat;
  background-position: center;
}

.load {
    position: fixed;
    top: 0;
	left:0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    background: #fff;
}
.load .load-img {
	display: flex;
    justify-content: center;
    align-items: center;
    width: 100vw;
    height: 100vh;
}
.load .load-img img {max-width:150px;animation: loading-bounce 1s ease-in-out infinite;}


 @keyframes loading-bounce {
    0% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-10px);
    }
    100% {
      transform: translateY(0);
    }
  }



.root {
  position: relative;
  background-color: #fff;
}

#skipnav {
  position: absolute;
  left: -100%;
  color: #fff;
  background: #54565b;
  font-size: 1.6rem;
}

#skipnav:focus {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 29999;
  padding: 20px;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}

/* 
* header 
*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: 60px;
  -webkit-transition: background-color 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: background-color 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    background-color 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    background-color 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    background-color 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
}

.header::before {
  content: "";
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: rgba(16, 24, 32, 0.2);
  opacity: 0;
}

@media (min-width: 960px) {
  .header {
    height: 64px;
  }
}

.header.add-bg {
  background-color: #fff;
}

.header.add-bg::before {
  opacity: 1;
}

.header.is-rollup {
  -webkit-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  transform: translateY(-100%);
}

.header_wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  height: 100%;
}

.header_wrap .logo {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  display: inline-block;
}

.header_wrap .logo_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 60px;
}

.header_wrap .logo_link img {
  max-width: 100%;
}

.header_logo_svg {
  width: 144px;
}

.header_logo_svg path {
  height: 100%;
  fill: #fff;
}

.header_logo_svg .st0 {
  fill: #fff;
}
.header_logo_svg .st1 {
  fill: #fff;
}
.header_logo_svg .st2 {
  fill: #fff;
}
.header_logo_svg .st3 {
  fill: #fff;
}

.header.add-bg .header_logo_svg .st0 {
  fill: #dc092b;
}
.header.add-bg .header_logo_svg .st1 {
  fill: #00adbb;
}
.header.add-bg .header_logo_svg .st2 {
  fill: #231815;
}
.header.add-bg .header_logo_svg .st3 {
  fill: #676868;
}

/* .header.add-bg .header_logo_svg path {
  fill: #405364;
} */

.gnb {
  display: none;
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  bottom: 60px;
}

.d1.active {border-right:#fff;border-left:#fff;}

@media (min-width: 960px) {
  .header_wrap .logo_link {
    height: 64px;
  }

  .header_logo_svg {
    width: 144px;
  }

  .gnb {
    display: block;
    position: relative;
    top: unset;
    bottom: unset;
  }
}

.gnb .has-sublist:before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f107";
  position: absolute;
  top: 50%;
  right: 0;
  font-size: 1rem;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
}
.gnb .has-sublist.active::before {
  -webkit-transform: translateY(-50%) rotate(-180deg);
  -ms-transform: translateY(-50%) rotate(-180deg);
  transform: translateY(-50%) rotate(-180deg);
}

.gnb .d1::before {
  top: 33px;
  right: 20px;
}

.gnb .d1-item {
  display: block;
  color: #405364;
  position: relative;
  padding: 1.25rem 20px;
  font-size: 1.1rem;
  font-weight: 700;
}

.header_lang .hl-item {
  display: block;
  padding: 0rem 1rem;
  
}

.header_lang .hl-item .hl-text {
	color: #fff;
	font-size: 0.9rem;
	font-weight: 700;
}

.header.add-bg .header_lang .hl-item .hl-text {
	color: #405364;
}



.gnb .d2-list {
  background-color: #efefef;
  padding: 0 20px;
  display: none;
}

.gnb .d2 + .d2 {
  border-top: 1px solid rgba(16, 24, 32, 0.1);
}
.gnb .d2 + .d2 .d2-item {
  color: #404148;
  font-weight: 500;
}
.gnb .d2::before {
  top: 28px;
  right: 0;
}
.gnb .d2-item {
  display: block;
  -webkit-tap-highlight-color: transparent;
  font-size: 1rem;
  width: 100%;
  padding: 0.9rem 0;
  text-align: left;
  font-weight: 500;
}

.gnb .d3-list {
  margin-top: 0rem;
  padding: 0 0 0.6rem 1.25rem;
  display: none;
}
.gnb .d3-item {
  display: block;
  padding: 0.4rem 0;
  font-size: 0.9rem;
  color: #54565b;
  font-weight: 400;
}
.gnb .d3-item + .gnb .d3-item {
  padding-top: 0.7rem;
}

.header.is-gnb .gnb {
  display: block;
}

.gnb-wrap {
  overflow-y: auto;
  height: 100%;
  background-color: #fff;
}

.gnb .has-sublist {
  position: relative;
}

@media (min-width: 960px) {
  .gnb .d1-list {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 100%;
  }
  .gnb .d1 {
    position: relative;
    height: 100%;
  }
  .gnb .d1::before {
    display: none;
  }
  .gnb .d1-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    padding: 0 1.5rem;
    font-size: 1.1rem;
    color: #fff;
  }

  .gnb .d1-item:hover,
  .gnb .d1-item:focus {
    font-weight: 700;
  }
  .gnb-wrap {
    overflow-y: hidden;
    background-color: transparent;
  }

  .header.add-bg .gnb .d1-item {
    color: #333;
  }

  .gnb .sub-wrap {
    position: fixed;
    top: 64px;
    left: 0;
    right: 0;
    background-color: rgba(255, 255, 255, 0);
    -webkit-transition: 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
    -o-transition: 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  }

  .header.add-bg .gnb .sub-wrap {
    background-color: #fff;
  }

  .gnb .d2-list {
    width: calc(100% - 80px);
    max-width: 1360px;
    display: none;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: auto;
  }

  .gnb .d1.active .d2-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background-color: transparent;
  }

  .gnb .d2::before {
    display: none;
  }

  .gnb .d2 + .d2 {
    margin-left: 2.5rem;
    border-top: none;
  }
  .gnb .d2-item {
    font-size: 1rem;
    padding: 1.3rem 0;
    -webkit-tap-highlight-color: transparent;
  }

  .gnb .d2-item .d2-text {
    width: calc(100%);
    background-image: -o-linear-gradient(
      transparent calc(100% - 1px),
      #405364 1px
    );
    background-image: linear-gradient(
      transparent calc(100% - 1px),
      #405364 1px
    );
    background-repeat: no-repeat;
    background-size: 0% 100%;
    -webkit-transition: background-size 0.3s;
    -o-transition: background-size 0.3s;
    transition: background-size 0.3s;
    white-space: nowrap;
  }

  .gnb .d2-item:hover .d2-text,
  .gnb .d2-item:focus .d2-text {
    background-size: 100% 100%;
  }

  .gnb .d1:nth-child(3) .d2-item .d2-text {color:#00a2ad;font-weight:700;background-image: -o-linear-gradient(
      transparent calc(100% - 1px),
      #00a2ad 1px
    );
    background-image: linear-gradient(
      transparent calc(100% - 1px),
      #00a2ad 1px
    );}

  .gnb .d2.has-sublist .d2-item {
    padding-bottom: 0.3rem;
  }

  .gnb .d1-about .d2-list {
    -webkit-transform: translateX(-134px);
    -ms-transform: translateX(-134px);
    transform: translateX(-134px);
  }

  .gnb .d1-product .d2-list {
    -webkit-transform: translateX(-35px);
    -ms-transform: translateX(-35px);
    transform: translateX(-35px);
  }
  .gnb .d1-product .d2 + .d2 {
    margin-left: 2.4rem;
  }
  .gnb .d1-innovation .d2-list {
    -webkit-transform: translateX(-10px);
    -ms-transform: translateX(-10px);
    transform: translateX(-10px);
  }
  .gnb .d1-story .d2-list {
    -webkit-transform: translateX(100px);
    -ms-transform: translateX(100px);
    transform: translateX(100px);
  }
  .gnb .d1-esg .d2-list {
    -webkit-transform: translateX(150px);
    -ms-transform: translateX(150px);
    transform: translateX(150px);
  }
  .gnb .d1-career .d2-list {
    -webkit-transform: translateX(190px);
    -ms-transform: translateX(190px);
    transform: translateX(190px);
  }

  .gnb .d3-list {
    display: block;
    padding: 0;
    padding-bottom: 1.8rem;
  }

  .gnb .d3-item .d3-text {
    width: calc(100%);
    background-image: -o-linear-gradient(
      transparent calc(100% - 1px),
      #54565b 1px
    );
    background-image: linear-gradient(
      transparent calc(100% - 1px),
      #54565b 1px
    );
    background-repeat: no-repeat;
    background-size: 0% 100%;
    -webkit-transition: background-size 0.3s;
    -o-transition: background-size 0.3s;
    transition: background-size 0.3s;
  }

  .gnb .d3-item:hover .d3-text,
  .gnb .d3-item:focus .d3-text {
    background-size: 100% 100%;
  }

  #gnb-line {
    position: absolute;
    bottom: 0px;
    display: block;
    height: 3px;
    background-color: #405364;
    width: 0;
    pointer-events: none;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}

.gnb__lang {
  position: fixed;
  left: 0;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 60px;
  padding: 0 20px;
  background-color: #fff;
  font-family: "Roboto", "NotoSans", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  -webkit-box-shadow: 0px -10px 30px 0px rgba(16, 24, 32, 0.1);
  box-shadow: 0px -10px 30px 0px rgba(16, 24, 32, 0.1);
}

.gnb__lang .lang__item {
  display: inline-block;
  color: #b2b2b2;
  line-height: 1;
  position: relative;
  margin-left: 1rem;
  padding-left: 1rem;
  font-size: 1rem;
}
.gnb__lang .lang__item.lang__current {
  color: #333;
}
.gnb__lang .lang__item::after {
  content: "";
  position: absolute;
  top: 2px;
  left: -4px;
  width: 1px;
  height: 11px;
  background-color: rgba(16, 24, 32, 0.2);
}
.gnb__lang .lang__item:first-child {
  margin-left: 0;
  padding-left: 0;
}
.gnb__lang .lang__item:first-child::after {
  display: none;
}

.header_extend {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.header_lang {
  display: block;
  position: relative;
  margin-right: 0;
  margin-top: 0;
  font-size: 1rem;
  font-weight: bold;
  animation: bounce 0.9s ease-in-out infinite;
}

.header_lang .hl-item {
  display:block;
  padding:0;
}

.header_icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 60px;
  padding: 0.7rem 0.5rem;
  color: #fff;
  border: 0 none;
  outline: 0;
  background: none;
}

.header_icon .icon {
  position: relative;
  display: block;
  color: #fff;
}

.header_icon .icon::before {
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: inherit;
  font-size: 1.3rem;
}

.header_icon .icon.icon-search::before {
  content: "\f002";
}

.header_icon .icon.icon-close::before {
  content: "\f00d";
  font-size: 1.5rem;
}

.header.add-bg .header_icon .icon {
  color: #333;
}

.header_icon_search_close {
  visibility: hidden;
  position: absolute;
  right: -13px;
  top: 0px;
  z-index: 1;
}

.header_toggle {
  display: block;
  height: 60px;
  padding: 0.6rem;
  margin-right: -0.6rem;
  border: 0 none;
  outline: 0;
  background: none;
}
.header_toggle .bar {
  display: block;
  width: 20px;
  height: 2px;
  background-color: #fff;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.header_toggle .bar + .bar {
  margin-top: 0.4rem;
}

.header.add-bg .header_toggle .bar {
  background-color: #333;
}

.header_toggle.active .bar:nth-child(1) {
  transform: translate(0px, 8px) rotate(45deg);
}

.header_toggle.active .bar:nth-child(2) {
  transform: rotate(45deg);
}

.header_toggle.active .bar:nth-child(3) {
  transform: translate(0px, -8px) rotate(-45deg);
}

@media (max-width: 960px) {
  .header.active .header_icon_search {
    display: none;
  }
}

.header.is-search .header__search {
  display: block;
}

.header.is-search .header_icon_search_close {
  visibility: visible;
}

.header.is-search .header_icon_search {
  visibility: hidden;
}

.header.is-search .header_toggle {
  display: none;
}

.header_search {
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  bottom: 0;
  background: #fff;
  display: none;
}

.header.is-search .header_search {
  display: block;
}

.search {
  height: 100%;
  padding-bottom: 4rem;
}

.search-wrap {
  max-width: 670px;
}

.search__box {
  position: relative;
}
.search__input {
  border: none;
  outline:none;
  vertical-align: middle;
  -webkit-border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  max-height: none;
  padding: 1.2rem 0.8rem;
  font-size: 1.2rem;
  border-bottom: 1px solid rgba(16, 24, 32, 0.2);
  background: #fff;
}
.search__input:focus {
  border-bottom: 1px solid rgba(16, 24, 32, 1);
}

.search__btn {
  position: absolute;
  right: 0;
  top: 0;
  padding: 16px;
  border: 0 none;
  outline: 0;
  background-color: transparent;
}

.search__btn .icon-search {
  position: relative;
  display: block;
  font-size: 1.4rem;
  color: #333;
}

.search__btn .icon-search::before {
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: inherit;
  content: "\f002";
}

.search_tip {
  display: block;
  color: #76777b;
  font-size: 1.1rem;
}

.search_recommend {
  margin-top: 1rem;
}

.search_recommend .tag {
  margin-top: 1rem;
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid #d8d8d8;
  color: #76777b;
  font-size: 1rem;
  border-radius: 4px;
  background-color: #F6F7F8;
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s;
  margin-right: 4px;
  margin-top: 10px;
}

.search_recommend .tag:before {
  content: "#";
}

.search_recommend .tag:hover,
.search_recommend .tag:focus {
  color: #0066cc;
  border-color: #0066cc;
  background-color: transparent;
}

.page-contents-scroll-indicator {display:block;width:0;height:5px;background:#00a2ad;opacity:0.5;transition: 0.2s;pointer-events: none;}

#backdrop {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 90;
  opacity: 0;
  -webkit-transition: opacity 0.1s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: opacity 0.1s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: opacity 0.1s cubic-bezier(0.25, 0.45, 0.5, 1);
  cursor: pointer;
}

#backdrop.active {
  width: 100%;
  height: 100%;
  background-color: rgba(216, 216, 216, 0.1);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  backdrop-filter: saturate(180%) blur(10px);
  opacity: 1;
}

@media (min-width: 960px) {
  .header_extend {
    right: -12px;
  }
  .header_lang {
    display: block;
    position: relative;
    margin-right: 0rem;
	margin-top: 4px;
    font-size: 1rem;
    font-weight: bold;
    animation: bounce 0.9s ease-in-out infinite;
  }
  .header_extend:hover .header_lang .hl-item .hl-text {
    color: #00a2ad;
  }
  
  .header_lang .lang__current,
  .header_lang .lang__item {
    display: block;
    min-width: 110px;
    padding: 0 30px;
    text-align: center;
    line-height: 1;
  }
  .header_lang .lang__current {
    position: relative;
    color: #fff;
    border: 0 none;
    outline: none;
    background-color: transparent;
    font-size: 1rem;
    font-weight: bold;
    padding: 25px;
  }
  .header_lang .lang__current:before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f107";
    position: absolute;
    top: 50%;
    right: 18px;
    font-size: 1rem;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
    -o-transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
      -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  }

  .header_lang.open .lang__current:before {
    -webkit-transform: translateY(-50%) rotate(-180deg);
    -ms-transform: translateY(-50%) rotate(-180deg);
    transform: translateY(-50%) rotate(-180deg);
  }

  .header.add-bg .header_lang .lang__current {
    background-color: transparent;
    color: #405364;
  }

  .header_lang .lang__option {
    display: none;
    position: absolute;
    bottom: 1px;
    -webkit-transform: translateY(100%);
    -ms-transform: translateY(100%);
    transform: translateY(100%);
    border: 1px solid rgba(16, 24, 32, 0.2);
    border-top: none;
  }

  .header_lang.open .lang__option {
    display: block;
  }

  .header_lang .lang__item {
    display: block;
    min-width: 110px;
    padding: 20px 30px;
    text-align: center;
    line-height: 1;
    color: #b2b2b2;
    background-color: #fff;
  }

  .header_toggle {
    display: none;
  }

  .header_search {
    top: 0;
    bottom: auto;
    height: auto;
    padding-bottom: 3.75rem;
    border-bottom: 1px solid rgba(16, 24, 32, 0.2);
  }
}

/*
* main video swipe
*/

.swiper-container {
  width: 100%;
  height: 100%;
}

.swiper-slide {
  text-align: center;
  font-size: 18px;
  background-color: #00a2ad;
  display: flex;
  justify-content: center;
  align-items: center;
  position:relative;
}

@media (max-width: 959px) {
	.swiper-slide::before {
	  content:'';
	  position: absolute;
	  top: 0;
	  left: 0;
	  width: 100vw;
	  height: 100vh;
	  background-image: url(/skin11/web/upload/idealnew/asset/img/video/laser.png);
	  background-position: top right;
	  background-repeat: no-repeat;
	  background-size: 50%;
	}
}


.swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.swiper-controller {
  position: absolute;
  bottom: 4vh;
  left: 0;
  right: 0;
}

.swiper-controller__pad {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.swiper-controller--invert .swiper-button-prev,
.swiper-controller--invert .swiper-button-next,
.swiper-controller--invert .swiper-button-play,
.swiper-controller--invert .swiper-button-pause,
.swiper-controller--invert .swiper-pagination {
  color: #fff;
}

.swiper-controller--invert .swiper-pagination-bullet {
  border-color: #fff;
}

.swiper-controller--invert .swiper-pagination-bullet-active {
  background-color: transparent;
}

.swiper-pagination {
  position: relative;
  z-index: 15;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: left;
}

.swiper-pagination-bullet {
  position: relative;
  width: 40px;
  border: none;
  border-radius: 0;
  margin-right: 1rem;
  -webkit-transition: opacity 0.2s cubic-bezier(0.25, 0.45, 0.5, 1),
    color 0.2s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: opacity 0.2s cubic-bezier(0.25, 0.45, 0.5, 1),
    color 0.2s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: opacity 0.2s cubic-bezier(0.25, 0.45, 0.5, 1),
    color 0.2s cubic-bezier(0.25, 0.45, 0.5, 1);
  background-color: transparent;
  border-bottom: 3px solid white;
  height: 30px;
}

.no-touchevents .swiper-pagination-bullet:hover,
.no-touchevents .swiper-pagination-bullet:focus {
  background-color: transparent;
  opacity: 1;
}

.swiper-pagination-bullet.has-thumb {
  width: 100px;
  height: auto;
  border-radius: 0;
}

.swiper-button-prev,
.swiper-button-next {
  background-image: none;
  width: 40px;
  height: 40px;
  line-height: 38px;
  text-align: center;
  color: #fff;
}

.hero {
  position: relative;
  height: 100vh;
}
.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100%;
  background-color: rgba(16, 24, 32, 0.1);
}

.hero_bg {
  width: 100%;
}
.bg {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.bg__img,
.bg__video,
.bg img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}


.swiper-slide .video-container {
  width: 100%;
  height: 100vh;
  position: relative;
  padding-bottom: 56.25%;
}
.swiper-slide .video-container iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  visibility: hidden;
}

.swiper-slide .video-container .yt-player {
  width: 100%;
  height: 100vh;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
}
.swiper-slide .video-container .yt-player.bg01 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb01.png);}
.swiper-slide .video-container .yt-player.bg02 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb02.png);}
.swiper-slide .video-container .yt-player.bg03 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb03.png);}
.swiper-slide .video-container .yt-player.bg04 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb04.png);}
.swiper-slide .video-container .yt-player.bg05 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb05.png);}
.swiper-slide .video-container .yt-player.bg06 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb06.png);}
.swiper-slide .video-container .yt-player.bg07 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb07.png);}
.swiper-slide .video-container .yt-player.bg08 {background-image: url(/skin11/web/upload/idealnew/asset/img/video/poster_mb08.png);}



@media (min-width: 960px) {
  .swiper-slide .video-container iframe {
    visibility: visible;
  }
  .swiper-slide .video-container .yt-player {
    visibility: hidden;
  }
}

.video-rwd {
  background-color: green;
  display: block;
  width: 100vw;
  height: 100vh;
}

.bg_video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.hero_cont {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 14vh;
  width: 100%;
  z-index: 1;
  text-align: left;
}
.reveal {
  opacity: 1;
}

.hero_cont .h2 {
  font-size: 2.2rem;
  margin-bottom: 1rem;
  color: #fff;
  line-height: 1.4;
  word-break: keep-all;
  word-wrap: break-word;
}

.hero_cont .h6 {
  display: block;
  font-size: 1rem;
  margin-bottom: 1rem;
  color: #fff;
  line-height: 1.4;
  word-break: keep-all;
  word-wrap: break-word;
}

/* 
* footer 
*/

#footer {
  overflow: hidden;
  padding-top: 5.5rem;
  border-top: 1px solid rgba(16, 24, 32, 0.2);
  background-color: #405364;
}

.goTop {
  position: absolute;
  top: 0;
  right: 0;
  background: #405364;
  z-index:999;
}
.goTop button {
  display: block;
  width: 40px;
  height: 40px;
  text-align: center;
  background-color: transparent;
  border: 0 none;
  outline: 0;
}
.goTop button i {
  color: #fff;
  line-height: 40px;
  font-size: 1.5rem;
}

.copy_logo {
  position: absolute;
  top: 5px;
  left: 0;
}

.copy_logo .copy_link {
  display: block;
  line-height: 0;
  color:#00A2AD;
}

.copy_logo .copy_link .footer_logo_text {
  color:#00A2AD;
}

.copy_logo .copy_link .footer_logo_img {
  display:block;
  width:144px;
  height:auto;
}

.footer_logo_svg {
  width: 144px;
  height: 36px;
}

.copy_logo img {
  vertical-align: middle;
  max-width: 100%;
  max-height: 100%;
}

.copy_row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.copy_nav {
  margin-top: 3.2rem;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  padding: 0 5px;
}

.copy_nav .d1_item {
  position: relative;
  display: block;
  padding: 1.1rem 0;
  font-size: 1.1rem;
  font-weight: 500;
  overflow: hidden;
  line-height: 1.4;
  color: #fff;
}

.copy_nav .d1_item::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f107";
  position: absolute;
  top: 50%;
  right: 0;
  font-size: 1rem;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1),
    -webkit-transform 0.4s cubic-bezier(0.25, 0.45, 0.5, 1);
}

.copy_nav .d1.active .d1_item::before {
  -webkit-transform: translateY(-50%) rotate(-180deg);
  -ms-transform: translateY(-50%) rotate(-180deg);
  transform: translateY(-50%) rotate(-180deg);
}

.copy_nav .sub-wrap {
  position: relative;
}

.copy_nav .sub-wrap::after {
  content: "";
  position: absolute;
  width: 100vw;
  top: 0;
  left: -20px;
  background-color: #efefef;
  height: 100%;
}

.copy_nav .depth2-list {
  position: relative;
  left: -20px;
  width: 100vw;
  padding: 1rem 20px;
  display: none;
  z-index: 1;
  background: #405364;
}

.copy_nav .d2_item {
  display: block;
  padding: 0.5rem 0;
  color: #fff;
}

.copy_nav .d2_text {
  font-size: 0.9rem;
  line-height: 1.4;
  word-break: keep-all;
}

.copy_info {
  margin-top: 2rem;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  padding: 0 5px;
}

.copy-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.copy-links > li {
  position: relative;
  margin-right: 1.3rem;
}

.copy-links > li::before {
  content: "";
  position: absolute;
  top: 6px;
  right: -11px;
  width: 1px;
  height: 14px;
  background-color: #b2b2b2;
}

.copy-links > li:last-child::before {
  display: none;
}

.copy-links > li a {
  color: #fff;
}


.footer-link {
  
}

.footer-link strong {
  color: #fff;
}

.footer-link__icon {
  margin-left: 3px;
  display: inline-block;
  position: relative;
  width: 12px;
  height: 13px;
}

.footer-link__icon::before {
  margin-left: 5px;
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f08e";
  color: #405364;
  position: absolute;
  top: 0;
  right: 0;
  font-size: 0.8rem;
}

.copy-sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.copy-sns__link {
  display: block;
}

.copy-sns .icon {
  padding: 1rem 1rem;
  color: #405364;
  position: relative;
  display: block;
}

.copy-sns__item:first-child .icon {
  padding-left: 0;
  padding-right: 1rem;
}

.copy-sns .icon::before {
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: #405364;
  font-size: 1.5rem;
}

.copy-sns .icon:hover,
.copy-sns .icon:focus {
  opacity: 0.8;
}

.copy-sns .icon.instagram::before {
  font-family: "Font Awesome 5 Brands";
  content: "\f16d";
}

.copy-sns .icon.youtube::before {
  font-family: "Font Awesome 5 Brands";
  content: "\f167";
}

.copy-sns .icon.cafe::before {
  content: "\f0f4";
}

.copy-sns .icon.blog::before {
  font-family: "Font Awesome 5 Brands";
  content: "\f37c";
}

.copy-sns .icon.kakao::before {
  font-family: "Font Awesome 5 Free";
  content: "\f075";
}

.copy-links--bottom li {
  margin-top: 1.3rem;
}

.footer-toggle {
  position: relative;
  margin-top: 3.5rem;
}
.footer-toggle__item {
  position: relative;
}

@media (max-width: 959px) {
  .footer-toggle__item::after {
    content: "";
    position: absolute;
    width: 100vw;
    top: 0;
    left: -20px;
    border-top: 1px solid rgba(16, 24, 32, 0.2);
  }
}

.footer-toggle__btn {
  position: relative;
  display: block;
  width: 100%;
  margin: 0;
  padding: 1rem 0;
  color: #405364;
  text-align: left;
  overflow: hidden;
  background: none;
  border: 0 none;
  outline: 0;
  cursor: pointer;
}
.footer-toggle__pad {
  position: relative;
}

@media (max-width: 959px) {
  .footer-toggle__btn:before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f107";
    color: #405364;
    position: absolute;
    top: 50%;
    right: 0;
    font-size: 1rem;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
  }

  .footer-toggle__item.active .footer-toggle__btn:before {
    -webkit-transform: translateY(-50%) rotate(-180deg);
    -ms-transform: translateY(-50%) rotate(-180deg);
    transform: translateY(-50%) rotate(-180deg);
  }

  .footer-toggle__pad::after {
    content: "";
    position: absolute;
    width: 100vw;
    top: 0;
    left: -20px;
    background-color: #efefef;
    height: 100%;
    z-index: -1;
  }
}

.footer-toggle__cont {
  position: relative;
  margin: 0;
  padding: 1rem 0;
  zoom: 1;
  display: none;
}

.footer-family .footer-toggle__cont:before {
  content: "";
  display: block;
}

.footer-family .footer-toggle__cont:after {
  content: "";
  display: table;
  clear: both;
}

.footer-toggle__cont address {
  margin: 0.1rem 0;
  font-style: normal;
  color: #fff;
  font-size: 12px;
}
.footer-toggle__link {
  float: left;
  width: 50%;
  display: block;
  padding: 0.2rem 0;
  font-size: 0.9rem;
  line-height: 1.4;
}

@media (min-width: 960px) {
  #footer {
    padding-top: 3.5rem;
    padding-bottom: 1.5rem;
  }

  .footer_logo_svg {
    width: 144px;
    height: 36px;
  }

  .copy_row {
    padding-bottom: 4.5rem;
  }

  .copy_nav {
    margin-top: 0;
    width: 66.666%;
    max-width: 100%;
    min-height: 1px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 0 5px;
  }

  .copy_info {
    -webkit-box-ordinal-group: 0;
    -ms-flex-order: -1;
    order: -1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin-top: 3rem;
    width: 33.333%;
    max-width: 100%;
    min-height: 1px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 0 5px;
    order: -1;
  }

  .copy-sns {
    margin-top: 1rem;
    -webkit-box-ordinal-group: 0;
    -ms-flex-order: -1;
    order: -1;
  }

  .copy-links-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    margin: 0;
  }

  .footer-toggle {
    position: unset;
    margin-top: 0;
  }

  .footer-family {
    position: absolute;
    right: 0;
    bottom: 0;
  }

  .footer-address {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
  .footer-copyright {
    margin: 0.5rem 0 1rem;
    padding: 0;
    cursor: default;
    font-size: 0.9rem;
  }

  .footer-family .footer-toggle__btn {
    width: 210px;
    padding: 0.8rem 0;
    border-bottom: 1px solid rgba(16, 24, 32, 0.4);
  }

  .footer-family .footer-toggle__btn:before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f107";
    color: #405364;
    position: absolute;
    top: 50%;
    right: 0;
    font-size: 1rem;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
  }

  .footer-toggle__item.active .footer-toggle__btn:before {
    -webkit-transform: translateY(-50%) rotate(-180deg);
    -ms-transform: translateY(-50%) rotate(-180deg);
    transform: translateY(-50%) rotate(-180deg);
  }

  .footer-family .footer-toggle__cont {
    display: none;
  }
  .footer-family.active .footer-toggle__cont {
    display: block;
    position: absolute;
    top: -45px;
    left: 0;
    right: 0;
    padding: 1.5rem 0;
    border: 1px solid rgba(16, 24, 32, 0.2);
    background-color: #F6F7F8;
    -webkit-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    transform: translateY(-100%);
  }

  .footer-family.active .footer-toggle__link {
    display: block;
    width: auto;
    float: none;
    padding: 0.1rem 1rem;
  }

  .footer-address .footer-toggle__cont {
    display: block !important;
    padding: 0;
  }

  .copy_nav .depth1-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .copy_nav .depth1-list .d1 {
    width: 20%;
  }
  .copy_nav .depth1-list .d1 .d1_item .d1_text {
    font-size: 15px;
  }

  .copy_nav .d1_item {
    padding: 0;
    font-size: 15px;
  }

  .copy_nav .depth1-list .d1 .d1_item::before {
    display: none;
  }

  .copy_nav .sub-wrap {
    display: block;
  }
  .copy_nav .sub-wrap::after {
    display: none;
  }
  .copy_nav .depth2-list {
    position: static;
    display: block;
    margin-top: 1rem;
    width: auto;
    padding: 0;
  }
  .copy_nav .d2_item {
    display: block;
    padding: 0.3rem 0;
	font-size: 13px;
    color: #fff;
  }
}

#modalContainer {display:none !important;}

/*
* 메인
*/

.st {
  overflow: hidden;
  padding: 4.6rem 0;
}

.st-header {
  position: relative;
  margin-bottom: 2.1rem;
}

.st-header-more {
  position: absolute;
  top: 5px;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 33px;
  height: 33px;
  border: 1px solid #405364;
  -webkit-transition: 0.25s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: 0.25s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: 0.25s cubic-bezier(0.25, 0.45, 0.5, 1);
}

.st-header-more:before {
  content: "\2b";
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: inherit;
  font-size: 1.3rem;
  -webkit-transition: 0.3s cubic-bezier(0.25, 0.45, 0.5, 1);
  -o-transition: 0.3s cubic-bezier(0.25, 0.45, 0.5, 1);
  transition: 0.3s cubic-bezier(0.25, 0.45, 0.5, 1);
  color: #405364;
}

.st-header-more:hover,
.st-header-more:focus {
  background-color: #405364;
}

.st-header-more:hover::before,
.st-header-more:focus::before {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
  color: #fff;
}

@media (min-width: 960px) {
  .st-header {
    margin-bottom: 2.5rem;
  }
  .st-header-more {
    bottom: 0;
  }
}

.st-h1,
.st-h2,
.st-h3,
.st-h4,
.st-h5,
.st-h6 {
  color: #405364;
  font-weight: 700;
  line-height: 1.2;
}

.st-h1 {
  font-size: 2.8rem;
}

.st-h2 {
  font-size: 2.25rem;
}

.st-h3 {
  font-size: 2rem;
}

.st-h4 {
  font-size: 1.7rem;
}

.st-h5 {
  font-size: 1.5rem;
}

.st-h6 {
  font-size: 1.25rem;
}

.st-h1 small,
.st-h2 small,
.st-h3 small,
.st-h4 small,
.st-h5 small,
.st-h6 small {
  font-size: 1rem;
  opacity: 0.6;
  display: block;
  margin-top: 10px;
}

@media (min-width: 960px) {
  .st-h1 small,
  .st-h2 small,
  .st-h3 small,
  .st-h4 small,
  .st-h5 small,
  .st-h6 small {
    display: inline-block;
    margin-top: 0;
  }
}

/*
* section 1
*/
.mansonry-grid {
  /* background: #ddd; */
}
.mansonry-grid:after {
  content: "";
  display: block;
  clear: both;
}

.main-product li.main-product-sizer,
.main-product li.main-product-item {
  width: 49%;
}

.main-product li.main-product-item {
  float: left;
  margin-right:2%;
  margin-bottom: 2%;
}
.main-product li.main-product-item:nth-child(even){
  margin-right:0;
}
.main-product li a {
  position: relative;
  display: block;
  width: 100%;
  transition: 0.3s all ease-out;
}

.main-product li a div.main-product-image {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  background: #e9e9e9;
  min-height:370px;
  display: flex;
  align-items: center;
  transition: 0.3s all ease-out;
}
.main-product li a div.main-product-image:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: 3s all ease-out;
}

.main-product li a img {
  position: absolute;
  bottom: 50%;
  margin-bottom: -50%;
  max-width: 100%;
  display: block;
  transition: 0.3s all ease-out;
}



.main-product li a .tit {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  padding:15px;
}

.main-product li a .tit .inner {
  display: flex;
  height: 100%;
  flex-wrap: wrap;
  flex-direction: column;

}

.main-product li a .tit span {
  position: relative;
  display: block;
  width:90%;
  
}
.main-product li a .tit span.tp {}
.main-product li a .tit span.bt {font-size: 1rem;color:#fff;font-weight: 700;opacity:1;position: absolute; left: 5%; bottom: 1.2rem; transition: 0.3s all ease-out; background:#787878;background-color: rgba( 120, 120, 120, 0.3 );border-radius: 1rem; padding: 0.8rem;}
.main-product li a .tit span.tp em {position: relative;color:#fff;font-weight: 700;word-break: keep-all;font-size: 1.3rem;display: inline-block;font-style: normal;transition: 0.3s all ease-out;}
.main-product li a .tit span.tp em:after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  margin-top: 0;
  background: #109fab;
  transition: 1s all ease-out;
  opacity: 1;
}

.main-product li a:hover .tit span.tp em {font-size: 1.5rem;}
.main-product li a:hover .tit span.tp em:after {background: #109fab; opacity: 1;}
.main-product li a:hover .tit span.bt {opacity:1;}


@media (min-width: 960px) {
  .main-product li.main-product-sizer,
  .main-product li.main-product-item {
    width: 24.25%;
  }

  .main-product li.main-product-item {
	margin-right:1%;
	margin-bottom:1%;
  }

  .main-product li.main-product-item:nth-child(even){
	 margin-right:1%;
  }


  .main-product li.main-product-item:nth-child(4n){
    margin-right:0;
  }

  .main-product li a div.main-product-image {
     min-height: 420px;
  }

  .main-product li a div.main-product-image img {
     bottom: 15%;
	 margin-bottom: 0;
  }
  
  .main-product li a:hover {
    transform: scale(1.03);
  }
  .main-product li a:hover div.main-product-image {background: #c9c9c9}
  .main-product li a:hover div.main-product-image img {}
  .main-product li a:hover .tit span.tp em {font-size: 1.4rem;}
  .main-product li a .tit span.bt {top: auto;bottom: 0.9rem;opacity:0}

  .main-product li a .tit span.tp em:after {opacity:0}

}

.list-product-main {
  position: relative;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  padding: 0;
}
.list-product-main li {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 50vw;
  margin-bottom: 16px;
}

.list-product-main li:last-child {
  margin-bottom: 0;
}

.list-product-main a {
  display: block;
  width: 100%;
  height: 100%;
}

.list-product-main .product-main-image {
  width: 100%;
  height: 100%;
  background: center center no-repeat;
  background-size: cover;
  transition: 3s all ease-out;
}
.list-product-main .product-main-image:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  transition: 3s all ease-out;
}
.list-product-main li:hover .product-main-image {
  transform: scale(1.2);
}
.list-product-main li:hover .product-main-image:after {
  content: "";
  display: block;
}
.list-product-main .tit {
  position: absolute;
  font-weight: 700;
  color: #fff;
  left: 20px;
  bottom: 20px;
  font-size: 1.3rem;
}
.list-product-main .tit {
  position: absolute;
  left: 32px;
  bottom: 32px;
  font-size: 28px;
  font-weight: 700;
  color: #fff;
}
.list-product-main .tit:after {
  content: "";
  display: block;
  width: 0;
  height: 2px;
  margin-top: 0;
  background: #fff;
  transition: 0.3s all ease-out;
}
.list-product-main li:hover .tit:after {
  width: 100%;
}

.list-product-main li:nth-child(1) .product-main-image {
  background-image: url(/skin11/web/upload/idealnew/asset/img/product/01.png);
}
.list-product-main li:nth-child(2) .product-main-image {
  background-image: url(/skin11/web/upload/idealnew/asset/img/product/02.png);
}
.list-product-main li:nth-child(3) .product-main-image {
  background-image: url(/skin11/web/upload/idealnew/asset/img/product/03.png);
}
.list-product-main li:nth-child(4) .product-main-image {
  background-image: url(/skin11/web/upload/idealnew/asset/img/product/04.png);
}

@media (max-width: 400px) {
	.main-product li.main-product-item {width:100%; float:none}

	.main-product li a .tit span.tp em {font-size:1rem}
	.main-product li a .tit span.bt {font-size:0.8rem}
}

@media (min-width: 960px) {
  .list-product-main li {
    margin-bottom: 0;
  }
  .list-product-main li:nth-child(1) {
    width: 366px;
    height: 855px;
  }
  .list-product-main li:nth-child(2) {
    position: absolute;
    top: 0;
    right: 398px;
    width: 366px;
    height: 855px;
    border-left: 16px solid #fff;
  }
  .list-product-main li:nth-child(3) {
    position: absolute;
    top: 0;
    right: 0;
    width: 398px;
    height: 435px;
    border-left: 16px solid #fff;
    border-bottom: 15px solid #fff;
  }
  .list-product-main li:nth-child(4) {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 398px;
    height: 420px;
    border-left: 16px solid #fff;
  }


}

/*
* section 2
*/
.st02 {
  background-color: #F6F7F8;
}

.st02 .mo_sec03 {
  background-size: cover;
}

.st02 .mo_sec03 .sm_tab ul {
	max-width: 360px;
	width: 100%;
	margin: 0 auto 20px;
	text-align: center;
}
.st02 .mo_sec03 .sm_tab ul li {
	display: inline-block;
	width: 130px;
	margin-right: 7px;
	margin-bottom: 9px;
	padding: 0;
	height: 39px;
	border-radius: 20px;
	line-height: 37px;
	border: solid 1px rgb(225, 225, 225);
	transition: 0.5s;
}
.st02 .mo_sec03 .sm_tab ul li .pc_ico {display:none}
.st02 .mo_sec03 .sm_tab ul li .dot {display:none}
.st02 .mo_sec03 .sm_tab ul li > span {font-size: 0.8rem;font-weight: 500;color: #363636;letter-spacing: -1.54px;}

.st02 .mo_sec03 .sm_tab ul li.on {
	background-color: #232323;
	border: solid 1px #232323;
}

.st02 .mo_sec03 .sm_tab ul li.on > span {color: #fff;}


.st02 .mo_sec03 .sm_cont {
	text-align: center;	
	display: none;
}
.st02 .mo_sec03 .sm_cont.on {
	display: block;
}

.st02 .mo_sec03 .sm_cont .txt_wrap {
	text-align: center;
}
.st02 .mo_sec03 .sm_cont .txt_wrap > span {
	color: #000;
	font-size: 1.3rem;
	display:block;
	word-break:keep-all;
}
.st02 .mo_sec03 .sm_cont .txt_wrap > span.main_cont {
	color: #555;	
	font-size: 0.8rem;
	line-height: 1.5;
	text-align: left;
}

.st02 .mo_sec03 .sm_cont .btn_view {
	margin: 35px auto 0;	
}
.st02 .mo_sec03 .sm_cont .sm_img {
	display: inline-block;
	position: relative;
	padding: 15px 15px 0;
}
.st02 .mo_sec03 .sm_cont .sm_img > img {
	border-radius: 25px;
	max-width:100%;
}
.st02 .mo_sec03 .txt_wrap .main_tit {
    margin: 10px 0;
}
.st02 .mo_sec03 .sm_cont .sm_ico {	
    position: absolute;
    left: 30px;
    top: 0px;
    width: 55px;
    height: 55px;
    border-radius: 10px;
    background: #00a2ad;	
}
.st02 .mo_sec03 .sm_cont .sm_ico > div {
	position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.st02 .mo_sec03 .sm_cont .sm_ico > div i {
	color:#fff;
	font-size: 2.0rem;
}


.st02 .mo_sec03 .sm_cont .sm_ico > div img {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.st02 .mo_sec03 {
	text-align: center;
}

.st02 .mo_sec03 .bt_box {
	display: inline-block;
	margin-top: 35px;
}




@media (min-width: 960px) {
	.st02 .fd_container {max-width:1980px;width:100%;}
	.st02 .st-header {max-width:1130px;margin:0 auto 25px;}
	.st02 .mo_sec03 {position:relative;height: 645px;z-index: 1;display: flex;flex-wrap: wrap;flex-direction: column;justify-content: center;align-items: center;background: url("/skin11/web/upload/idealnew/asset/img/choice/bg_0.png") center center no-repeat;}
	.st02 .mo_sec03:before {content:'';position: absolute;top: 0;left: 0;right: 0;bottom: 0;background-color: rgba(0,0,0,0.5);z-index: -1;}
	.st02 .mo_sec03 .sm_cont .sm_img {display: none;}
	
	.st02 .mo_sec03 .sm_tab {order:2;padding-top: 10%;width:100%;}
	.st02 .mo_sec03 .sm_tabbox  {order:1;max-width:1130px}

	.st02 .mo_sec03 .sm_cont .txt_wrap {}
	.st02 .mo_sec03 .sm_cont .txt_wrap > span.main_tit {
		margin: 20px 0;
		color: #fff;
		font-size: 3.0rem;
	}
	.st02 .mo_sec03 .sm_cont .txt_wrap > span.main_cont {
		color: #fff;
		font-size: 1.0rem;
		text-align: center;
	}

	.st02 .mo_sec03 .sm_tab ul {
		position: relative;
		max-width: 100%;
		display: flex;
		justify-content: space-between;
	}
	.st02 .mo_sec03 .sm_tab ul:before {
		position: absolute;
		content: '';
		top: 77px;
		left: 0;
		width: 100%;
		height: 1px;
		background: rgba(255, 255, 255, 0.5);
		transition: 1.3s;
	}

	.st02 .mo_sec03 .sm_tab ul li {
		position: relative;
		width:14.68%;
		margin-right: 0;
		margin-bottom: 0;
		padding: 0;
		height: auto;
		border-radius: 20px;
		line-height: 1;
		border: 0 none;
		transition: all 1s 1s;
		opacity: 1;
		z-index: 2;
	}

	.st02 .mo_sec03 .sm_tab ul li .pc_ico {display:block;    text-align: center;}
	.st02 .mo_sec03 .sm_tab ul li .pc_ico i {font-size:3.0rem;color:#fff;}
	.st02 .mo_sec03 .sm_tab ul li .dot {display:block;width: 8px;height: 8px;border-radius: 4px;background: #fff;margin: 29px auto 14px;position: relative;}
	.st02 .mo_sec03 .sm_tab ul li > span {font-size: 1.25rem;font-weight: normal;letter-spacing: -1.5px;color: #fff;display: block;}
	.st02 .mo_sec03 .sm_tab ul li:before {
		content: '';
		position: absolute;
		left: 50%;
		bottom: -60px;
		transform: translateX(-50%);
		padding: 120px;
		border-radius: 25px;
		background: #00a2ad;
		transition: 0.5s;
		z-index: -5;
		opacity: 0;
	}
		.st02 .mo_sec03 .sm_tab ul li.on {background-color:transparent;border: 0 none;}
	.st02 .mo_sec03 .sm_tab ul li.on:before {opacity: 1;}
	


}

/*
* section 3
*/

.sec02_slider02_list li {
  border-radius: 0;
  height: auto;
  text-align: center;
}

.sec02_slider02_list li > div {
  border-radius: inherit;
  height: inherit;
}

.sec02_slider02_list li .logo_box {
  border: 0 none;
  height: 100%;
  position: relative;
  display: block;
  padding-top: 20px;
}

.sec02_slider02_list li .logo_box img {
  position: static;
  transform: none;
  max-width: 100%;
  display: inline-block;
  max-height: 60px;
}

.sec02_slider02_list .slick-list {overflow:visible !important;}
.sec02_slider01_list .slick-slide > div,
.sec02_slider02_list .slick-slide > div {
  margin: 0 2px;
}

.sec02_slider01_list .slick-list .slick-slide > div:last-child,
.sec02_slider02_list .slick-list .slick-slide > div:last-child {
  margin-top: 14px;
}

.sec02_slider02_list li .hover_box {
  display: block;
  margin-top:1.1rem;
}


  .sec02_slider02_list li .txt_box::before {
    content: "";
    display: block;
    width: 20px;
    height: 1px;
    background: rgba(0, 0, 0, 0.2);
    margin: 5px auto;
  }

  .sec02_slider02_list li .txt_box {
    height: 130px;
    overflow: hidden;
    font-size: 0.9rem;
    padding: 0 10px;
    line-height: 1.38;
    color: rgba(0, 0, 0, 0.8);
    text-align: center;
    transition: all 0.7s;
  }


  .sec02_slider02_list li .sec02_slider02_button {
    display: block;
  }



.sec02_slider02 .sec02_arrow {
  display: none;
}

.slick-dots {
  text-align: center;
  margin-top: 25px;
}

.slick-dots li {
  display: inline-block;
}

.slick-dots li + li {
  margin-left: 16px;
}

.slick-dots li button {
  font-size: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  opacity: 0.2;
  background-color: #1f1f1f;
}

.slick-dots li.slick-active button {
  opacity: 1;
}

@media (min-width: 960px) {

  .sec02_slider02_list {
    background: url(/skin11/web/upload/idealnew/asset/img/sns_bg.jpg);
    background-size: cover;
    background-position: center;
	}
  .sec02_slider02 .sec02_arrow {
    position: absolute;
    z-index: 10;
    top: 60%;
    /* transform: translateY(-50%); */
    cursor: pointer;
  }
  .sec02_slider02 .sec02_arrow.slick-disabled {
    opacity: 0.1;
  }

  .sec02_slider02 .sec02_arrow.prev {
    left: -25px;
  }

  .sec02_slider02 .sec02_arrow.next {
    right: -25px;
  }

  .sec02_slider02_list li {
    height: auto;
    overflow: hidden;
	border-radius: 10px;
	-webkit-transition: 0.4s cubic-bezier(0.25,0.45,0.5,1);
    -o-transition: 0.4s cubic-bezier(0.25,0.45,0.5,1);
    transition: 0.4s cubic-bezier(0.25,0.45,0.5,1);
  }

  .sec02_slider02_list li .logo_box img {
	min-height: 60px;
	max-height:auto;
	width: 50px;
	-webkit-transition: 0.4s cubic-bezier(0.25,0.45,0.5,1);
    -o-transition: 0.4s cubic-bezier(0.25,0.45,0.5,1);
    transition: 0.4s cubic-bezier(0.25,0.45,0.5,1);
  }


  .sec02_slider02_list li:hover {
    box-shadow: 0px 5px 15px 5px rgba(0, 0, 0, 0.09);
	transform: scale(1.02);
    background:#fff;
	background-color:rgba( 255,255,255,0.3 );
  }

  .sec02_slider02_list li:hover .logo_box img {
	-webkit-transform: scale(1.2) rotate(360deg);
    -moz-transform: scale(1.2) rotate(360deg);
    -ms-transform: scale(1.2) rotate(360deg));
    -o-transform: scale(1.2) rotate(360deg);
    transform: scale(1.2) rotate(360deg);
  }


	/*.ideal_link_ul li:hover {*/
	/*	background-color: #ffffff;*/
	/*	box-shadow: 0 0 10px 5px #c8c8c8;*/
	/*	transform: scale(1.02);*/
	/*}*/

  .sec02_slider02_list li .hover_box {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    position: relative;
    transition: all 0.7s;
  }


  .sec02_slider02_list .slick-slide {
    transition: transform 1s;
  }

  .section02 .sec02_slider02_list .slick-slide:hover {
    transform: translateY(-10px);
  }


}

/*
* section 4
*/

.call_blog {
  width: 100%;
  height: auto;
  position: relative;
}
.call_blog .blog_iframe {
  display: block;
  border: none;
  height: 229vh;
  width: 100%;
}

@media (min-width: 1069px) {
  .call_blog .blog_iframe {
     height: 140vh; 
  }
}

.shelf {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.shelf__item {
  width: 100%;
  opacity: 1;
}

.shelf__item + .shelf__item {
  margin-top: 2.1rem;
}

.shelf__link {
  display: block;
}

.shelf__thumb {
  width: 100%;
  position: relative;
  display: block;
  overflow: hidden;
}

.shelf__thumb img {
  width: 100%;
}

.shelf__thumb:only-child {
  margin-bottom: 0;
}


.shelf__icon {
  position: absolute;
  color: #fff;
  left: 0;
  bottom: 0;
  z-index: 1;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  padding: 15% 2rem 2rem;
  font-size: 2.6rem;
  text-align: right;
  line-height: 1;
}

.shelf__icon::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  /*@if is-direction($direction) == false {
    $color-stops: $direction, $color-stops;
    $direction: 180deg;
  }*/
  background: rgba(16, 24, 32, 0.2);
  background: -webkit-gradient(
    linear,
    left bottom,
    left top,
    from(rgba(16, 24, 32, 0.2)),
    to(rgba(16, 24, 32, 0))
  );
  background: -o-linear-gradient(
    bottom,
    rgba(16, 24, 32, 0.2),
    rgba(16, 24, 32, 0)
  );
  background: linear-gradient(0deg, rgba(16, 24, 32, 0.2), rgba(16, 24, 32, 0));
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='rgba(16, 24, 32, 0.2)', endColorstr='rgba(16, 24, 32, 0)',GradientType=1 );
}

.shelf__icon--instagram:before {
  content: "\ea18";
  display: inline-block;
  font-family: "icon";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  text-decoration: none;
  text-transform: none;
}

.shelf__icon--blog:before {
  content: "\ea16";
  display: inline-block;
  font-family: "icon";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  text-decoration: none;
  text-transform: none;
}

.shelf__icon--youtube {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0;
  font-size: 4rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.shelf__icon--youtube:before {
  content: "\ea11";
  display: inline-block;
  font-family: "icon";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  text-decoration: none;
  text-transform: none;
}

.shelf__icon--youtube::after {
  background: rgba(16, 24, 32, 0.2);
}

.shelf__cont {
  margin-top: 1.3rem;
}

.shelf__h {
  display: block;
  margin: 0.9rem 0 0.6rem;
  word-break: keep-all;
  word-wrap: break-word;
}

.shelf__date {
  display: block;
  margin-top: 0.9rem;
  color: #76777b;
  font-size: 0.9rem;
}

@media (min-width: 960px) {
  .shelf__item {
    width: calc(33.33% - 3.53%);
  }
  .shelf__item:nth-child(-n + 3) {
    margin-top: 0;
  }
  .shelf__item:nth-child(n + 4) {
    margin-top: 5.5rem;
  }
  .shelf__cont {
    margin-top: 1.5rem;
  }
  .shelf__gutter {
    width: 5.3%;
  }
}

.badge {
  display: inline-block;
  padding: 5px 9px;
  background-color: #54565b;
  color: #fff;
  font-size: 0.9rem;
  line-height: 1.4;
  font-style: normal;
}

.badge + .badge {
  margin-left: 0.2em;
}

.tagtext {
  margin-right: 4px;
  color: #54565b;
  font-size: 0.9rem;
  white-space: pre;
  line-height: 1.6;
  border: 1px solid #54565c;
  border-radius:5px;
  background-color: #ececec;
  padding:1px 6px;
}

.tagtext-box {
  line-height: 1.3;
}

.tagtext::before {
  content: "#";
}

/*
* section 5
*/

.port_area {
  margin-top: 25px;
  display: flex;
  flex-wrap: wrap;
}
.port_area div.portBn {
  width: 50%;
}
.port_area div.portBn a {
  display: block;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.port_area div.portBn:nth-child(1) a,
.port_area div.portBn:nth-child(4) a,
.port_area div.portBn:nth-child(5) a,
.port_area div.portBn:nth-child(8) a,
.port_area div.portBn:nth-child(9) a,
.port_area div.portBn:nth-child(12) a,
.port_area div.portBn:nth-child(13) a{
  background-color: #eef2f5;
}

.port_area div.portBn a img {
  width: 100%;
}

.port_area div.portBn a div.thumb {
  display: flex;
  justify-content: center;
  align-items: center;

  width: 100%;
  height: 170px;
}

.port_area div.portBn a div.thumb .mid {
  text-align: center;
}

.port_area div.portBn a div.thumb em {
  display: inline-block;
  width: 50px;
  height: 50px;
  background: url("/skin11/web/upload/idealnew/asset/img/port/solution_ico.png") 0 0 no-repeat;
}

.port_area div.portBn a div.thumb em.ico01 {
  background-position: 0 0;
}
.port_area div.portBn a div.thumb em.ico02 {
  background-position: -50px 0;
}
.port_area div.portBn a div.thumb em.ico03 {
  background-position: 0 -50px;
}
.port_area div.portBn a div.thumb em.ico04 {
  background-position: -50px -50px;
}
.port_area div.portBn a div.thumb em.ico05 {
  background-position: 0 -100px;
}
.port_area div.portBn a div.thumb em.ico06 {
  background-position: -50px -100px;
}
.port_area div.portBn a div.thumb em.ico07 {
  background-position: 0 -150px;
}
.port_area div.portBn a div.thumb em.ico08 {
  background-position: -50px -150px;
}
.port_area div.portBn a div.thumb em.ico09 {
  background-position: 0 -200px;
}
.port_area div.portBn a div.thumb em.ico10 {
  background-position: -50px -200px;
}
.port_area div.portBn a div.thumb em.ico11 {
  background-position: 0 -250px;
}
.port_area div.portBn a div.thumb em.ico12 {
  background-position: -50px -250px;
}
.port_area div.portBn a div.thumb em.ico13 {
  background-position: 0 -300px;
}
.port_area div.portBn a div.thumb em.ico14 {
  background-position: -50px -300px;
}
.port_area div.portBn:nth-child(even) a h6 {
  /* color: #fff; */
}

.port_area div.portBn a span {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 10px;
  position: absolute;
  left: -9999px;
  top: 0;
  bottom: 0;

  letter-spacing: -0.5px;
  background-color: rgba(0, 0, 0, 0.4);
  transition: all 0.3s;
}

.port_area div.portBn a span p {
  color: #fff;
  font-size: 0.8rem;
  word-break: keep-all;
  text-overflow: ellipsis;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.portBn_btn {
  position: relative;
  display: block;
  width: 191px;
  margin: 20px auto 0;
  padding-bottom: 23px;
  text-align: center;
  transition: all 0.5s ease;
}
.portBn_btn span {
  display: block;
  color: #313131;
  line-height: 1;
}
.portBn_btn:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #393939;
  width: 110px;
  height: 1px;
}
.portBn_btn:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 7px;
  left: 50px;
  background-color: #e8192a;
  width: 7px;
  height: 7px;
}

@media (min-width: 960px) {
  .port_area div.portBn {
    width: 14.28%;
    height: auto;
  }

    .port_area div.portBn:nth-child(1) a,
	.port_area div.portBn:nth-child(4) a,
	.port_area div.portBn:nth-child(5) a,
	.port_area div.portBn:nth-child(8) a,
	.port_area div.portBn:nth-child(9) a,
	.port_area div.portBn:nth-child(12) a,
	.port_area div.portBn:nth-child(13) a{
	  /*background-color: #eef2f5;*/
	  background-color: #fff;
	}

	.port_area div.portBn:nth-child(even) a{
	  background-color: #eef2f5;
	}

  .port_area div.portBn a span {
    top: -200px;
	left:0;
    height: 169px;
    font-size: 1rem;
  }

  .port_area div.portBn a span p {
    font-size: 0.9rem;
    -webkit-line-clamp: 4;
  }

  .port_area div.portBn a:hover span {
    top: 0;
  }

  .portBn_btn span {
    font-size: 1.1rem;
  }

  .portBn_btn:before {
    width: 190px;
    height: 1.5px;
  }
  .portBn_btn:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 3px;
    left: 10px;
    background-color: #e8192a;
    width: 15px;
    height: 15px;
    transition: all 1s ease;
  }

  .portBn_btn:hover span {
    color: #e8192a;
  }

  .portBn_btn:hover:after {
    left: 166px;
  }
}

/*
* section 6
*/

.st06 {
  padding: 0;
}
.st06 .inner {
  display: block;
}
.st06_con {
  position: relative;
  width: 100%;
  text-align: left;
  overflow: hidden;
}
.st06_con a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 80px;
  padding: 0 2.66% 0 2.66%;
}
.st06_con .st-h5 {
  color: #fff;
  position: relative;
}
.st06_con p {
  display: none;
}

.st06_con.left {
  background: url(/skin11/web/upload/idealnew/asset/img/main_bg01_mob.jpg) center left no-repeat;
  background-size: cover;
}

.st06_con span {
  position: relative;
  display: inline-block;
  width: 162px;
  height: 34px;
  border: 1px solid #fff;
  line-height: 32px;
  padding: 0 20px;
  font-size: 0.8rem;
  color: #fff;
}

.st06_con span em {
  color: inherit;
  font-style: normal;
  position: relative;
  z-index: 1;
  display: inline-block;
  pointer-events: none;
}

.st06_con.left span i {
  transform: translate(43px, 0);
}

.st06_con .anim {
  display: inline-block;
}

.st06_con .anim i {
  color: #fff;
}

.st06_con.right {
  background: url(/skin11/web/upload/idealnew/asset/img/main_bg02_mob.jpg) center right no-repeat;
  background-size: cover;
  text-align: left;
}

.st06_con.right span i {
  transform: translate(20px, 0);
}

@media (min-width: 960px) {
  .st06 {
    background: url(/skin11/web/upload/idealnew/asset/img/main_bg0102.jpg) center top;
  }
  .st06 .inner {
    display: flex;
  }
  .st06_con {
    width: 50%;
    text-align: right;
  }
  .st06_con a {
    display: block;
    height: auto;
    padding: 4.3rem 7.5rem 3.1rem 12.5rem;
  }
  .st06_con.right a {
    display: block;
    padding: 4.3rem 12.5rem 3.1rem 7.5rem;
  }

  .st06_con a span::before {
    content: "";
    position: absolute;
    top: -2px;
    right: -2px;
    bottom: -2px;
    left: -2px;
    background-color: #0071e3;
    -webkit-transition: -webkit-transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: -webkit-transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    -o-transition: transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1),
      -webkit-transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    -webkit-transform: scale(0, 1);
    -ms-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right center;
    -ms-transform-origin: right center;
    transform-origin: right center;
  }

  .st06_con a span::after {
    position: relative;
    -webkit-transition: -webkit-transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: -webkit-transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    -o-transition: transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
    transition: transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1),
      -webkit-transform 0.28s cubic-bezier(0.25, 0.45, 0.5, 1);
  }

  .st06_con a span:hover,
  .st06_con a span:focus {
    text-decoration: none;
    color: #fff;
  }

  .st06_con a span:hover::before,
  .st06_con a span:focus::before {
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
  }

  .st06_con p {
    font-size: 1rem;
    color: #fff;
    line-height: 1.5;
    margin-top: 1.25rem;
    display: block;
  }

  .st06_con span {
    margin-top: 1.25rem;
  }

  .st06_con.left span i {
    transform: rotate(180deg) translate(114px, 2px);
  }

  .st06_con.right span i {
    transform: translate(20px, 0);
  }

  .st06_con .anim {
    display: block;
    position: absolute;
  }
  .st06_con .anim i {
    font-size: 2.5rem;
  }
  .anim.plane {
    top: 0%;
    left: 20px;
    transition: 1.5s;
  }

  .anim.location {
    top: 0%;
    right: -10px;
  }

  .st06_con a:hover .anim.plane {
    transform: translate(100px, -200px) scale(0.2);
    opacity: 0;
  }

  .st06_con a:hover .anim.location {
    animation: bounce 1s ease-in-out infinite;
  }

  @keyframes bounce {
    0% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-10px);
    }
    100% {
      transform: translateY(0);
    }
  }
}

@media (min-width: 1100px) {
  .anim.plane {
    top: 0%;
    left: 42%;
  }

  .anim.location {
    top: 0%;
    right: 20%;
  }
}

@media (min-width: 1500px) {
  .anim.plane {
    top: 150%;
    left: 50%;
  }

  .anim.location {
    top: 150%;
    right: 50%;
  }
}


.talk_banner_div {
    position: fixed;
    right: 10px;
    bottom: 10px;
    z-index: 9990;
}

.talk_preview_area .talk_banner_preview_inner {
    padding: 10px !important;
}

.talk_preview_area .banner_type_card {
    border-radius: 15px;
	width:120px !important;
	height:100px !important;
}


.banner_type_card .talk_banner_desc,
.banner_type_card .talk_banner_detail {
	display:none !important;
}

.banner_type_card .talk_banner_consult {
	margin-top:10px !important;
}


@media (min-width: 960px) {
	.talk_banner_div {
		right: 22px;
		bottom: 22px;
	}

	.talk_preview_area .talk_banner_preview_inner {
		padding: 24px 21px 22px !important;
	}

	.talk_preview_area .banner_type_card {
		width:inherit !important;
		height:inherit !important;
	}

	.banner_type_card .talk_banner_desc,
	.banner_type_card .talk_banner_detail {
		display:block !important;
	}

	.banner_type_card .talk_banner_consult {
		margin-top:19px !important;
	}

}

.youtube {
  padding-top: 56.25%;
  position: relative;
}
.youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Ledi-inspired header dropdown renewal */
.category-preview {
  display: none;
}

@media (min-width: 960px) {
  .header {
    height: 68px;
  }

  .header_wrap .logo_link {
    height: 68px;
  }

  .header.is-gnb,
  .header:hover {
    background-color: #fff;
  }

  .header.is-gnb::before,
  .header:hover::before {
    opacity: 1;
  }

  .header.is-gnb .header_logo_svg .st0,
  .header:hover .header_logo_svg .st0 {
    fill: #dc092b;
  }

  .header.is-gnb .header_logo_svg .st1,
  .header:hover .header_logo_svg .st1 {
    fill: #00adbb;
  }

  .header.is-gnb .header_logo_svg .st2,
  .header:hover .header_logo_svg .st2 {
    fill: #231815;
  }

  .header.is-gnb .header_logo_svg .st3,
  .header:hover .header_logo_svg .st3 {
    fill: #676868;
  }

  .header.is-gnb .gnb .d1-item,
  .header:hover .gnb .d1-item {
    color: #213544;
  }

  .header.is-gnb .header_lang .hl-item .hl-text,
  .header:hover .header_lang .hl-item .hl-text {
    color: #213544;
  }

  .gnb .d1-item {
    padding: 0 24px;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0;
  }

  .gnb .sub-wrap {
    top: 68px;
    min-height: 0;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.98);
    border-top: 1px solid rgba(18, 41, 58, 0.08);
    box-shadow: 0 22px 45px rgba(21, 36, 47, 0.12);
    transform: translateY(-14px);
    transition: max-height 360ms ease, opacity 260ms ease, transform 360ms ease, visibility 0s linear 360ms;
  }

  .header.add-bg .gnb .sub-wrap {
    background: rgba(255, 255, 255, 0.98);
  }

  .gnb .d1.active > .sub-wrap {
    max-height: 560px;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition: max-height 420ms ease, opacity 240ms ease, transform 360ms ease, visibility 0s;
  }

  .gnb .d1:not(.d1-product) > .sub-wrap {
    padding: 8px 0 12px;
  }

  .gnb .d1:not(.d1-product).active .d2-list {
    min-height: 58px;
    align-items: center;
  }

  .gnb .sub-wrap .d2-list {
    background: transparent;
  }

  .gnb .d2-item {
    font-size: 15px;
    line-height: 1.35;
    color: #263846;
  }

  .gnb .d2-item .d2-text,
  .gnb .d3-item .d3-text {
    letter-spacing: 0;
  }

  .gnb .d1-product > .sub-wrap {
    padding: 0;
  }

  .gnb .d1-product .visible_sub_category {
    display: grid;
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
    gap: 36px;
    width: calc(100% - 80px);
    max-width: 1280px;
    margin: 0 auto;
    padding: 28px 0 32px;
  }

  .gnb .d1-product .position {
    padding-right: 24px;
    border-right: 1px solid #e7edf2;
  }

  .gnb .d1-product .position .d2-list,
  .gnb .d1-product.active .position .d2-list {
    display: flex;
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
    flex-direction: column;
    justify-content: flex-start;
    transform: none;
  }

  .gnb .d1-product .position .d2 {
    width: 100%;
  }

  .gnb .d1-product .position .d2 + .d2 {
    margin-left: 0;
    border-top: 1px solid #edf2f5;
  }

  .gnb .d1-product .position .d2-item {
    position: relative;
    padding: 12px 38px 12px 0;
    font-size: 15px;
    font-weight: 700;
    color: #243746;
  }

  .gnb .d1-product .position .d2-item::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 4px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #f2f6f8;
    transform: translateY(-50%);
    transition: background 180ms ease, transform 180ms ease;
  }

  .gnb .d1-product .position .d2-item::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 11px;
    z-index: 1;
    width: 5px;
    height: 5px;
    border-top: 1px solid #738391;
    border-right: 1px solid #738391;
    transform: translateY(-50%) rotate(45deg);
    transition: border-color 180ms ease;
  }

  .gnb .d1-product .position .d2.is-preview-active .d2-item,
  .gnb .d1-product .position .d2:hover .d2-item {
    color: #00a2ad;
  }

  .gnb .d1-product .position .d2.is-preview-active .d2-item::after,
  .gnb .d1-product .position .d2:hover .d2-item::after {
    background: #00a2ad;
    transform: translateY(-50%) scale(1.06);
  }

  .gnb .d1-product .position .d2.is-preview-active .d2-item::before,
  .gnb .d1-product .position .d2:hover .d2-item::before {
    border-color: #fff;
  }

  .gnb .d1-product .position .d2-item .d2-text {
    color: inherit;
    background-image: none;
    white-space: normal;
  }

  .gnb .d1-product .sub-category {
    padding: 0 0 12px 14px;
  }

  .gnb .d1-product .sub-category .d3-list {
    display: block;
    padding: 0;
  }

  .gnb .d1-product .sub-category .d3-item {
    padding: 4px 0;
    font-size: 13px;
    line-height: 1.35;
    color: #687987;
  }

  .gnb .d1-product .sub-category .d3-item:hover,
  .gnb .d1-product .sub-category .d3-item:focus {
    color: #00a2ad;
  }

  .gnb .d1-product.active .category-preview,
  .gnb .d1-product:hover .category-preview,
  .gnb .d1-product:focus-within .category-preview {
    display: block;
    min-width: 0;
  }

  .category-preview__head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
  }

  .category-preview__eyebrow {
    margin: 0;
    font-size: 11px;
    font-weight: 800;
    color: #00a2ad;
    letter-spacing: 0;
  }

  .category-preview__title {
    margin-left: auto;
    font-size: 20px;
    font-weight: 800;
    color: #1d2f3d;
    letter-spacing: 0;
  }

  .category-preview__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    min-height: 208px;
  }

  .category-preview__card {
    display: flex;
    min-width: 0;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid #e6edf2;
    border-radius: 8px;
    background: #f8fafb;
    color: #223442;
    text-decoration: none;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
  }

  .category-preview__card:hover,
  .category-preview__card:focus {
    border-color: #00a2ad;
    box-shadow: 0 12px 26px rgba(0, 162, 173, 0.16);
    color: #223442;
    text-decoration: none;
    transform: translateY(-3px);
  }

  .category-preview__image {
    display: block;
    aspect-ratio: 4 / 3;
    background: #fff;
  }

  .category-preview__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 12px;
  }

  .category-preview__meta {
    display: flex;
    min-height: 74px;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: 12px 14px 14px;
  }

  .category-preview__kicker {
    font-size: 11px;
    font-weight: 800;
    color: #00a2ad;
    letter-spacing: 0;
  }

  .category-preview__name {
    overflow: hidden;
    display: -webkit-box;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
    color: #223442;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .category-preview__empty {
    display: flex;
    min-height: 208px;
    align-items: center;
    justify-content: center;
    border: 1px dashed #d6e0e7;
    border-radius: 8px;
    background: #f8fafb;
    font-size: 14px;
    font-weight: 700;
    color: #687987;
  }

  .category-preview.is-loading .category-preview__grid {
    opacity: 0.55;
  }
}


/* Shared header dropdown panel tuning */
@media (min-width: 960px) {
  .gnb {
    --gnb-panel-height: 0px;
    --gnb-panel-top: 68px;
  }

  .gnb::after {
    content: "";
    position: fixed;
    top: var(--gnb-panel-top);
    left: 0;
    z-index: -1;
    width: 100%;
    height: var(--gnb-panel-height);
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    background: rgba(255, 255, 255, 0.985);
    border-top: 1px solid rgba(18, 41, 58, 0.08);
    box-shadow: 0 22px 45px rgba(21, 36, 47, 0.12);
    transform: translateY(-8px);
    transition: height 320ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms ease, transform 300ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 220ms;
  }

  .header.is-gnb .gnb.has-open::after {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: height 320ms cubic-bezier(0.22, 1, 0.36, 1), opacity 150ms ease, transform 300ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0s;
  }

  .gnb .sub-wrap {
    background: transparent !important;
    border-top: 0;
    box-shadow: none;
    max-height: none;
    overflow: visible;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-6px);
    transition: opacity 120ms ease, transform 220ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 120ms;
  }

  .gnb .d1.active > .sub-wrap {
    max-height: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition: opacity 160ms ease 40ms, transform 260ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0s;
  }

  .gnb.is-switching .sub-wrap,
  .gnb.is-switching .d1.active > .sub-wrap {
    transition: opacity 90ms ease, transform 180ms ease, visibility 0s;
  }

  .gnb.is-closing::after {
    height: 0;
    opacity: 0;
    transform: translateY(-8px);
  }
}

/* Ideal Korea brand introduction page */
.ideal-brand-page {
  overflow: hidden;
  background: #fff;
  color: #203442;
}

.ib-shell {
  width: calc(100% - 80px);
  max-width: 1280px;
  margin: 0 auto;
}

.ib-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  color: #00a9b6;
  text-transform: uppercase;
}

.ib-eyebrow::before {
  content: "";
  width: 28px;
  height: 2px;
  background: #00a9b6;
}

.ib-hero {
  position: relative;
  min-height: 720px;
  display: flex;
  align-items: center;
  padding-top: 68px;
  color: #fff;
}

.ib-hero__media {
  position: absolute;
  inset: 0;
  background: #07131f;
}

.ib-hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(4, 15, 27, 0.9), rgba(4, 15, 27, 0.58) 45%, rgba(4, 15, 27, 0.12));
}

.ib-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ib-hero__content {
  position: relative;
  z-index: 1;
  padding: 120px 0 90px;
}

.ib-hero h1 {
  max-width: 820px;
  margin: 0;
  font-size: 58px;
  line-height: 1.16;
  font-weight: 900;
  letter-spacing: 0;
}

.ib-hero h1 strong {
  color: #36e0eb;
}

.ib-hero p {
  max-width: 720px;
  margin: 28px 0 0;
  font-size: 20px;
  line-height: 1.8;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
}

.ib-tabs {
  position: sticky;
  top: 68px;
  z-index: 15;
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid #e5ebef;
  backdrop-filter: blur(12px);
}

.ib-tabs .ib-shell {
  display: flex;
  justify-content: center;
  gap: 0;
}

.ib-tabs a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 170px;
  height: 58px;
  padding: 0 24px;
  font-size: 15px;
  font-weight: 800;
  color: #435564;
  text-decoration: none;
  border-bottom: 3px solid transparent;
}

.ib-tabs a.is-active,
.ib-tabs a:hover {
  color: #009eaa;
  border-color: #00a9b6;
}

.ib-section {
  padding: 110px 0;
}

.ib-intro__grid,
.ib-process__layout {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 70px;
  align-items: center;
}

.ib-intro__copy h2,
.ib-section-head h2,
.ib-process__body h2,
.ib-numbers__head h2,
.ib-cta h2 {
  margin: 0;
  font-size: 40px;
  line-height: 1.28;
  font-weight: 900;
  letter-spacing: 0;
  color: #1d3040;
}

.ib-intro__copy p,
.ib-process__body p,
.ib-cta p {
  margin: 24px 0 0;
  font-size: 17px;
  line-height: 1.85;
  font-weight: 600;
  color: #607282;
}

.ib-intro__image,
.ib-process__media {
  overflow: hidden;
  min-height: 440px;
  border-radius: 8px;
  background: #eef4f6;
}

.ib-intro__image img,
.ib-process__media img {
  width: 100%;
  height: 100%;
  min-height: 440px;
  object-fit: cover;
  transition: transform 500ms ease;
}

.ib-intro__image:hover img,
.ib-process__media:hover img {
  transform: scale(1.035);
}

.ib-numbers {
  position: relative;
  overflow: hidden;
  padding: 115px 0;
  color: #fff;
  background: #071827;
}

.ib-numbers__bg {
  position: absolute;
  inset: 0;
  opacity: 0.45;
}

.ib-numbers__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(3, 15, 25, 0.96), rgba(3, 15, 25, 0.66));
}

.ib-numbers__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ib-numbers .ib-shell {
  position: relative;
  z-index: 1;
}

.ib-numbers__head h2 {
  color: #fff;
}

.ib-number-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 54px;
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.ib-number {
  min-height: 168px;
  padding: 34px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.18);
}

.ib-number:last-child {
  border-right: 0;
}

.ib-number strong {
  display: block;
  font-size: 42px;
  line-height: 1;
  font-weight: 900;
  color: #fff;
}

.ib-number span {
  display: block;
  margin-top: 18px;
  font-size: 15px;
  line-height: 1.6;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.78);
}

.ib-section-head {
  margin-bottom: 42px;
}

.ib-value-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: 1px solid #dfe8ed;
  border-left: 1px solid #dfe8ed;
}

.ib-value {
  min-height: 270px;
  padding: 34px 28px;
  border-right: 1px solid #dfe8ed;
  border-bottom: 1px solid #dfe8ed;
  background: #fff;
  transition: background 220ms ease, transform 220ms ease, box-shadow 220ms ease;
}

.ib-value.is-active,
.ib-value:hover {
  background: #f4fbfc;
  box-shadow: 0 18px 36px rgba(11, 52, 70, 0.1);
  transform: translateY(-4px);
}

.ib-value span {
  display: block;
  font-size: 14px;
  font-weight: 900;
  color: #00a9b6;
}

.ib-value h3 {
  margin: 28px 0 14px;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 900;
  color: #203442;
}

.ib-value p {
  margin: 0;
  font-size: 15px;
  line-height: 1.75;
  font-weight: 600;
  color: #657687;
}

.ib-process {
  background: #f5f8fa;
}

.ib-process__layout {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}

.ib-steps {
  margin: 34px 0 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid #dce6ec;
}

.ib-steps li {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid #dce6ec;
}

.ib-steps b {
  font-size: 17px;
  font-weight: 900;
  color: #1d3040;
}

.ib-steps span {
  font-size: 15px;
  line-height: 1.75;
  font-weight: 600;
  color: #637586;
}

.ib-timeline {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.ib-time {
  min-height: 230px;
  padding: 34px 30px;
  border-radius: 8px;
  background: #f7fafb;
  border: 1px solid #e0e8ed;
}

.ib-time strong {
  display: block;
  font-size: 28px;
  font-weight: 900;
  color: #00a9b6;
}

.ib-time h3 {
  margin: 28px 0 12px;
  font-size: 22px;
  font-weight: 900;
  color: #213544;
}

.ib-time p {
  margin: 0;
  font-size: 15px;
  line-height: 1.75;
  font-weight: 600;
  color: #637586;
}

.ib-cta {
  padding: 90px 0 120px;
}

.ib-cta__box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  padding: 54px 58px;
  border-radius: 8px;
  background: #102536;
  color: #fff;
}

.ib-cta h2,
.ib-cta p {
  color: #fff;
}

.ib-cta p {
  color: rgba(255, 255, 255, 0.74);
}

.ib-cta a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 170px;
  height: 54px;
  padding: 0 28px;
  border-radius: 3px;
  background: #00a9b6;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  text-decoration: none;
}

@media (max-width: 959px) {
  .ib-shell {
    width: calc(100% - 36px);
  }

  .ib-hero {
    min-height: 620px;
    padding-top: 60px;
  }

  .ib-hero__content {
    padding: 90px 0 70px;
  }

  .ib-hero h1 {
    font-size: 38px;
  }

  .ib-hero p {
    font-size: 17px;
  }

  .ib-tabs {
    top: 60px;
    overflow-x: auto;
  }

  .ib-tabs .ib-shell {
    width: max-content;
    min-width: 100%;
    justify-content: flex-start;
  }

  .ib-tabs a {
    min-width: 132px;
    height: 54px;
    padding: 0 16px;
    font-size: 14px;
  }

  .ib-section {
    padding: 70px 0;
  }

  .ib-intro__grid,
  .ib-process__layout,
  .ib-number-list,
  .ib-value-grid,
  .ib-timeline {
    grid-template-columns: 1fr;
  }

  .ib-intro__copy h2,
  .ib-section-head h2,
  .ib-process__body h2,
  .ib-numbers__head h2,
  .ib-cta h2 {
    font-size: 30px;
  }

  .ib-number {
    min-height: 130px;
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.18);
  }

  .ib-steps li {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .ib-cta__box {
    display: block;
    padding: 38px 28px;
  }

  .ib-cta a {
    margin-top: 28px;
  }
}

@media (max-width: 959px) {
  .ib-tabs {
    scrollbar-width: none;
  }
  .ib-tabs::-webkit-scrollbar {
    display: none;
  }
}

/* Ideal Korea history page */
.ideal-history-page .ih-hero .ib-hero__media::after {
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.92) 0%, rgba(10, 33, 54, 0.68) 46%, rgba(10, 33, 54, 0.28) 100%);
}

.ih-overview {
  background: #f5f8fb;
}

.ih-overview__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 520px;
  gap: 54px;
  align-items: start;
}

.ih-overview h2,
.ih-section-head h2 {
  margin: 14px 0 0;
  color: #19344d;
  font-size: 34px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.ih-overview p,
.ih-section-head p {
  margin: 20px 0 0;
  color: #5f6f7e;
  font-size: 17px;
  line-height: 1.8;
  word-break: keep-all;
}

.ih-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ih-stats li {
  min-height: 150px;
  padding: 26px 24px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 32px rgba(24, 48, 74, 0.06);
}

.ih-stats strong {
  display: block;
  color: #07a8b8;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 700;
}

.ih-stats span {
  display: block;
  margin-top: 14px;
  color: #455c70;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}

.ih-timeline-section {
  background: #fff;
}

.ih-section-head {
  max-width: 760px;
  margin-bottom: 46px;
}

.ih-timeline {
  position: relative;
  display: grid;
  gap: 20px;
}

.ih-timeline::before {
  content: '';
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 93px;
  width: 1px;
  background: linear-gradient(180deg, rgba(7, 168, 184, 0.65), rgba(25, 52, 77, 0.08));
}

.ih-year-card {
  position: relative;
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  gap: 28px;
  padding: 0;
}

.ih-year {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 116px;
  height: 116px;
  border-radius: 50%;
  background: #f0f7f9;
  color: #19344d;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 24px;
  font-weight: 700;
  box-shadow: inset 0 0 0 1px rgba(7, 168, 184, 0.18);
}

.ih-year-card.is-current .ih-year {
  background: #07a8b8;
  color: #fff;
  box-shadow: 0 18px 34px rgba(7, 168, 184, 0.24);
}

.ih-year-body {
  padding: 30px 34px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.06);
}

.ih-year-body h3 {
  margin: 0;
  color: #19344d;
  font-size: 24px;
  line-height: 1.4;
  font-weight: 800;
  letter-spacing: 0;
}

.ih-year-body p {
  margin: 14px 0 0;
  color: #5d6f80;
  font-size: 16px;
  line-height: 1.75;
  word-break: keep-all;
}

.ih-year-body ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.ih-year-body li {
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef7f8;
  color: #2c5b67;
  font-size: 13px;
  line-height: 1.35;
}

.ih-field-section {
  background: #f6f9fb;
}

.ih-field-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.ih-field-grid article,
.ih-case-grid article {
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(24, 48, 74, 0.08);
}

.ih-field-grid img {
  display: block;
  width: 100%;
  aspect-ratio: 1.28 / 1;
  object-fit: cover;
  background: #e8eef2;
}

.ih-field-grid h3 {
  margin: 22px 22px 0;
  color: #19344d;
  font-size: 20px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.ih-field-grid p {
  margin: 12px 22px 24px;
  color: #667889;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}

.ih-cases-section {
  background: #fff;
}

.ih-case-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.ih-case-grid img {
  display: block;
  width: 100%;
  aspect-ratio: 1.34 / 1;
  object-fit: cover;
  background: #e8eef2;
}

.ih-case-grid div {
  padding: 20px 22px 24px;
}

.ih-case-grid strong,
.ih-case-grid span {
  display: block;
  word-break: keep-all;
}

.ih-case-grid strong {
  color: #19344d;
  font-size: 19px;
  line-height: 1.35;
  font-weight: 800;
}

.ih-case-grid span {
  margin-top: 8px;
  color: #667889;
  font-size: 14px;
  line-height: 1.5;
}

.ideal-history-page .ih-cta {
  background: #19344d url('/skin11/asset/img/ledi/bg_365.png') center/cover no-repeat;
}

@media (max-width: 1180px) {
  .ih-overview__grid {
    grid-template-columns: 1fr;
  }

  .ih-field-grid,
  .ih-case-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .ih-overview h2,
  .ih-section-head h2 {
    font-size: 27px;
  }

  .ih-overview p,
  .ih-section-head p {
    font-size: 15px;
  }

  .ih-stats {
    grid-template-columns: 1fr;
  }

  .ih-stats li {
    min-height: 0;
    padding: 22px 20px;
  }

  .ih-timeline::before {
    left: 18px;
  }

  .ih-year-card {
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 14px;
  }

  .ih-year {
    width: 44px;
    height: 44px;
    font-size: 12px;
  }

  .ih-year-body {
    padding: 24px 20px;
  }

  .ih-year-body h3 {
    font-size: 21px;
  }

  .ih-year-body p {
    font-size: 15px;
  }

  .ih-year-body ul {
    display: grid;
  }

  .ih-year-body li {
    border-radius: 8px;
  }

  .ih-field-grid,
  .ih-case-grid {
    grid-template-columns: 1fr;
  }
}


@media (max-width: 768px) {
  .ideal-history-page .ib-hero h1 {
    max-width: 335px;
    font-size: 34px;
    line-height: 1.18;
    word-break: keep-all;
  }

  .ideal-history-page .ib-hero h1 br {
    display: none;
  }

  .ideal-history-page .ib-hero p {
    max-width: 330px;
    font-size: 16px;
    line-height: 1.7;
  }
}

@media (max-width: 768px) {
  .ideal-history-page .ib-hero h1 br {
    display: block;
  }
}

/* Ideal Korea history archive */
.ih-archive-section {
  background: linear-gradient(180deg, #f6f9fb 0%, #fff 100%);
}

.ih-archive-viewer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 28px;
  align-items: stretch;
}

.ih-archive-main {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  border-radius: 8px;
  background: #0f273c;
  box-shadow: 0 22px 48px rgba(24, 48, 74, 0.14);
}

.ih-archive-main img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 560px;
  object-fit: cover;
}

.ih-archive-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 28px 32px;
  background: linear-gradient(180deg, rgba(8, 28, 44, 0) 0%, rgba(8, 28, 44, 0.88) 100%);
  color: #fff;
}

.ih-archive-caption span {
  display: block;
  color: #35d6df;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 14px;
  font-weight: 700;
}

.ih-archive-caption strong {
  display: block;
  margin-top: 10px;
  font-size: 24px;
  line-height: 1.45;
  font-weight: 800;
  letter-spacing: 0;
  word-break: keep-all;
}

.ih-archive-side {
  padding: 28px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(24, 48, 74, 0.08);
}

.ih-archive-side h3 {
  margin: 0;
  color: #19344d;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.ih-archive-side p {
  margin: 10px 0 20px;
  color: #667889;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}

.ih-archive-thumbs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  max-height: 452px;
  overflow: auto;
  padding-right: 4px;
}

.ih-archive-thumb {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 0.78;
  border: 2px solid transparent;
  border-radius: 6px;
  background: #eef4f7;
  cursor: pointer;
}

.ih-archive-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 240ms ease;
}

.ih-archive-thumb span {
  position: absolute;
  right: 5px;
  bottom: 5px;
  min-width: 24px;
  padding: 3px 5px;
  border-radius: 999px;
  background: rgba(8, 28, 44, 0.78);
  color: #fff;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 11px;
  line-height: 1;
  text-align: center;
}

.ih-archive-thumb:hover,
.ih-archive-thumb:focus-visible,
.ih-archive-thumb.is-active {
  border-color: #08b9c6;
  outline: none;
}

.ih-archive-thumb:hover img,
.ih-archive-thumb.is-active img {
  transform: scale(1.06);
}

.ih-archive-details {
  margin-top: 28px;
  border: 1px solid rgba(20, 55, 82, 0.12);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(24, 48, 74, 0.06);
}

.ih-archive-details summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 26px;
  color: #19344d;
  font-size: 18px;
  font-weight: 800;
  cursor: pointer;
  list-style: none;
}

.ih-archive-details summary::-webkit-details-marker {
  display: none;
}

.ih-archive-details summary::after {
  content: '+';
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #eef7f8;
  color: #08aebb;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 22px;
  line-height: 1;
}

.ih-archive-details[open] summary::after {
  content: '-';
}

.ih-archive-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  padding: 0 26px 28px;
}

.ih-archive-card {
  overflow: hidden;
  border: 1px solid rgba(20, 55, 82, 0.08);
  border-radius: 8px;
  background: #fff;
}

.ih-archive-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1.25 / 1;
  object-fit: cover;
  background: #e8eef2;
}

.ih-archive-card p {
  margin: 0;
  padding: 14px 14px 16px;
  color: #314b61;
  font-size: 14px;
  line-height: 1.55;
  word-break: keep-all;
}

@media (max-width: 1180px) {
  .ih-archive-viewer {
    grid-template-columns: 1fr;
  }

  .ih-archive-thumbs,
  .ih-archive-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .ih-archive-main,
  .ih-archive-main img {
    min-height: 330px;
  }

  .ih-archive-caption {
    padding: 70px 20px 20px;
  }

  .ih-archive-caption strong {
    font-size: 18px;
  }

  .ih-archive-side {
    padding: 20px;
  }

  .ih-archive-thumbs {
    display: flex;
    max-height: none;
    overflow-x: auto;
    padding: 0 0 8px;
    scroll-snap-type: x proximity;
  }

  .ih-archive-thumb {
    flex: 0 0 76px;
    height: 62px;
    scroll-snap-align: start;
  }

  .ih-archive-details summary {
    padding: 18px 18px;
    font-size: 16px;
  }

  .ih-archive-grid {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 0 18px 20px;
  }
}

/* History archive readability refinements */
.ih-archive-main img {
  object-fit: contain;
  background: #eef2f5;
}

.ih-archive-caption strong {
  overflow-wrap: anywhere;
}

@media (max-width: 768px) {
  .ih-archive-caption strong {
    font-size: 17px;
    line-height: 1.45;
  }
}

@media (max-width: 768px) {
  .ih-archive-main img {
    height: 330px;
    min-height: 0;
  }
}

@media (max-width: 768px) {
  .ih-archive-main img {
    object-position: center bottom;
  }

  .ih-archive-caption {
    position: static;
    padding: 16px 18px 18px;
    background: #102b42;
  }
}

@media (max-width: 768px) {
  .ih-archive-main img {
    object-fit: cover;
    object-position: center center;
  }
}

@media (max-width: 768px) {
  .ih-archive-main img {
    object-fit: contain;
    object-position: center center;
  }
}

/* History archive mobile overflow guard */
.ih-archive-viewer,
.ih-archive-main,
.ih-archive-side,
.ih-archive-caption,
.ih-archive-caption strong {
  min-width: 0;
  max-width: 100%;
}

.ih-archive-caption strong {
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

@media (max-width: 768px) {
  .ih-archive-main {
    width: 100%;
  }

  .ih-archive-main img {
    width: 100%;
    max-width: 100%;
  }
}

/* Expandable year history records */
.ih-timeline--expandable .ih-year-card {
  align-items: start;
}

.ih-timeline--expandable .ih-year {
  border: 0;
  cursor: pointer;
}

.ih-year-hit {
  display: flex;
  width: 100%;
  align-items: flex-start;
  justify-content: space-between;
  gap: 22px;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.ih-year-hit h3,
.ih-year-hit p {
  pointer-events: none;
}

.ih-year-hit em {
  flex: 0 0 auto;
  margin-top: 3px;
  padding: 8px 13px;
  border-radius: 999px;
  background: #eaf7f8;
  color: #078e9a;
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.3;
}

.ih-year-card.is-expanded .ih-year-hit em {
  background: #07a8b8;
  color: #fff;
}

.ih-year-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.ih-year-tags li {
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef7f8;
  color: #2c5b67;
  font-size: 13px;
  line-height: 1.35;
}

.ih-timeline--expandable .ih-year-body > .ih-year-tags + ul {
  display: none;
}

.ih-year-more {
  display: grid;
  grid-template-rows: 0fr;
  overflow: hidden;
  transition: grid-template-rows 360ms ease, margin-top 360ms ease;
}

.ih-year-more > * {
  min-height: 0;
}

.ih-year-card.is-expanded .ih-year-more {
  grid-template-rows: 1fr;
  margin-top: 24px;
}

.ih-record-list {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 22px;
  border-radius: 8px;
  background: #f6fafb;
  list-style: none;
}

.ih-record-list li {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid rgba(20, 55, 82, 0.08);
}

.ih-record-list li:last-child {
  border-bottom: 0;
}

.ih-record-list span {
  color: #07a8b8;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.6;
}

.ih-record-list p {
  margin: 0;
  color: #344f66;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}

.ih-mini-carousel {
  position: relative;
  min-width: 0;
  margin-top: 18px;
  padding: 20px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
}

.ih-mini-carousel__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.ih-mini-carousel__head strong {
  color: #19344d;
  font-size: 17px;
  font-weight: 800;
}

.ih-mini-carousel__head span {
  color: #6b7d8e;
  font-size: 13px;
}

.ih-mini-carousel__viewport {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  padding-bottom: 6px;
}

.ih-mini-carousel figure {
  flex: 0 0 158px;
  margin: 0;
  scroll-snap-align: start;
}

.ih-mini-carousel img {
  display: block;
  width: 158px;
  height: 112px;
  border-radius: 6px;
  object-fit: cover;
  background: #e8eef2;
}

.ih-mini-carousel figcaption {
  display: -webkit-box;
  min-height: 40px;
  margin-top: 8px;
  overflow: hidden;
  color: #4c6275;
  font-size: 12px;
  line-height: 1.45;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  word-break: keep-all;
}

.ih-mini-carousel__controls {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

.ih-mini-carousel__controls button {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(7, 168, 184, 0.22);
  border-radius: 50%;
  background: #eef7f8;
  color: #078e9a;
  font-size: 23px;
  line-height: 1;
  cursor: pointer;
}

.ih-mini-carousel__controls button:hover {
  background: #07a8b8;
  color: #fff;
}

@media (max-width: 768px) {
  .ih-year-hit {
    display: block;
  }

  .ih-year-hit em {
    display: inline-block;
    margin-top: 14px;
  }

  .ih-record-list {
    padding: 16px;
  }

  .ih-record-list li {
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 10px;
  }

  .ih-record-list p {
    font-size: 14px;
  }

  .ih-mini-carousel {
    padding: 16px;
  }

  .ih-mini-carousel__head {
    display: block;
  }

  .ih-mini-carousel__head span {
    display: block;
    margin-top: 4px;
  }

  .ih-mini-carousel figure {
    flex-basis: 132px;
  }

  .ih-mini-carousel img {
    width: 132px;
    height: 94px;
  }
}

/* Expandable year collapse correction */
.ih-year-more {
  max-height: 0;
  opacity: 0;
  visibility: hidden;
  transition: max-height 420ms ease, opacity 240ms ease, margin-top 360ms ease, visibility 0s linear 420ms;
}

.ih-year-card.is-expanded .ih-year-more {
  max-height: 2600px;
  opacity: 1;
  visibility: visible;
  transition: max-height 520ms ease, opacity 260ms ease, margin-top 360ms ease;
}

.ih-record-list li {
  border-radius: 0;
  background: transparent;
  color: inherit;
}

.ih-mini-carousel figure,
.ih-mini-carousel__controls li {
  padding: 0;
  border-radius: 0;
  background: transparent;
}

@media (max-width: 768px) {
  .ih-year-card.is-expanded .ih-year-more {
    max-height: 4200px;
  }
}

/* Year card anchor scroll behavior */
.ih-year-card {
  scroll-margin-top: 92px;
}

@media (max-width: 768px) {
  .ih-year-card {
    scroll-margin-top: 76px;
  }
}

/* Ideal Korea CI brand page */
.ideal-ci-page .ici-hero .ib-hero__media::after {
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.9) 0%, rgba(10, 33, 54, 0.62) 48%, rgba(10, 33, 54, 0.24) 100%);
}

.ici-section {
  background: linear-gradient(180deg, #f6f9fb 0%, #fff 42%, #f6f9fb 100%);
}

.ici-head {
  max-width: 780px;
  margin-bottom: 42px;
}

.ici-content.brand {
  max-width: none;
  margin: 0;
  padding: 0;
}

.ici-content .ci {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  margin: 0;
}

.ici-content .ci dl {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  min-width: 0;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
}

.ici-content .ci dt,
.ici-content .ci dd {
  flex-basis: auto;
  text-align: left;
}

.ici-content .ci dt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 62px;
  padding: 20px 24px;
  border: 0;
  border-bottom: 1px solid rgba(20, 55, 82, 0.1);
  color: #19344d;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0;
}

.ici-content .ci dt::after {
  content: 'Logo Type';
  color: #07a8b8;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.ici-content .ci dd {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 220px;
  padding: 30px;
  border: 0;
  background: #f9fbfc;
}

.ici-content .ci dd.white {
  background: #102b42;
}

.ici-content .ci dd img {
  display: block;
  width: auto;
  max-width: 72%;
  max-height: 110px;
}

.ici-content .ci-box {
  margin-top: 34px;
  padding: 34px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.06);
}

.ici-content .ci-box h3 {
  position: relative;
  margin: 0;
  padding: 0 0 0 18px;
  color: #19344d;
  font-size: 28px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.ici-content .ci-box h3::before {
  content: '';
  position: absolute;
  top: 15px;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #07a8b8;
}

.ici-content .ci-box p.desc {
  margin: 18px 0 0;
  color: #5d6f80;
  font-size: 16px;
  line-height: 1.8;
  word-break: keep-all;
}

.ici-symbol {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.ici-symbol h3 {
  align-self: start;
}

.ici-color-box h4 {
  position: relative;
  margin: 30px 0 14px;
  padding: 0 0 0 16px;
  color: #19344d;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.ici-color-box h4::before {
  content: '';
  position: absolute;
  top: 10px;
  left: 0;
  width: 8px;
  height: 2px;
  background: #07a8b8;
}

.ici-color-box ul {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ici-color-box h4 + ul {
  grid-template-columns: minmax(0, 1fr);
}

.ici-color-box ul li {
  display: flex;
  align-items: flex-end;
  min-height: 148px;
  margin: 0;
  padding: 22px;
  border-radius: 8px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.ici-color-box ul li.main-color {
  min-height: 118px;
  background: #00a2ad;
}

.ici-color-box ul li.sub-color1 { background: #dc092b; }
.ici-color-box ul li.sub-color2 { background: #3b4c5b; }
.ici-color-box ul li.sub-color3 { background: #231815; }
.ici-color-box ul li.sub-color4 {
  background: #fff;
  border: 1px solid rgba(20, 55, 82, 0.16);
  box-shadow: none;
}

.ici-color-box ul li p {
  margin: 0;
  color: #fff;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 14px;
  line-height: 1.65;
  font-weight: 600;
}

.ici-color-box ul li.sub-color4 p {
  color: #19344d;
}

@media (max-width: 1024px) {
  .ici-content .ci,
  .ici-symbol,
  .ici-color-box ul {
    grid-template-columns: 1fr;
  }

  .ici-color-box h4 + ul {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .ideal-ci-page .ib-hero h1 {
    max-width: 335px;
    font-size: 35px;
    line-height: 1.18;
    word-break: keep-all;
  }

  .ideal-ci-page .ib-hero p {
    max-width: 330px;
    font-size: 16px;
    line-height: 1.7;
  }

  .ici-head {
    margin-bottom: 28px;
  }

  .ici-content .ci {
    gap: 18px;
  }

  .ici-content .ci dt {
    min-height: 56px;
    padding: 17px 18px;
    font-size: 17px;
  }

  .ici-content .ci dd {
    min-height: 160px;
    padding: 24px 18px;
  }

  .ici-content .ci dd img {
    max-width: 84%;
    max-height: 86px;
  }

  .ici-content .ci-box {
    margin-top: 22px;
    padding: 24px 20px;
  }

  .ici-content .ci-box h3 {
    font-size: 24px;
  }

  .ici-content .ci-box p.desc {
    font-size: 15px;
  }

  .ici-color-box ul li,
  .ici-color-box ul li.main-color {
    min-height: 116px;
    padding: 18px;
  }
}

/* CI page legacy sub.css override */
.ideal-ci-page .ici-content .ci {
  display: grid !important;
}

.ideal-ci-page .ici-content .ci dl {
  display: grid !important;
  flex-basis: auto !important;
}

.ideal-ci-page .ici-content .ci dt,
.ideal-ci-page .ici-content .ci dd {
  flex-basis: auto !important;
}

.ideal-ci-page .ici-content .ci dl:first-child dt,
.ideal-ci-page .ici-content .ci dl:first-child dd {
  border-right: 0 !important;
}

/* CI page mobile title fit */
@media (max-width: 768px) {
  .ideal-ci-page .ib-hero h1 {
    font-size: 32px;
    line-height: 1.2;
  }

  .ideal-ci-page .ib-hero h1 br {
    display: none;
  }

  .ideal-ci-page .ici-head h2 {
    font-size: 29px;
    line-height: 1.25;
    word-break: keep-all;
  }
}

/* Ideal Korea location/contact page */
.ideal-location-page .iloc-hero .ib-hero__media::after {
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.92) 0%, rgba(10, 33, 54, 0.66) 48%, rgba(10, 33, 54, 0.22) 100%);
}

.iloc-section {
  background: linear-gradient(180deg, #f6f9fb 0%, #fff 34%, #f6f9fb 100%);
}

.iloc-head {
  max-width: 780px;
  margin-bottom: 42px;
}

.iloc-contact-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 34px;
}

.iloc-contact-grid article {
  min-width: 0;
  min-height: 214px;
  padding: 28px 24px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(24, 48, 74, 0.07);
}

.iloc-contact-grid i {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: #eef8f9;
  color: #07a8b8;
  font-size: 20px;
}

.iloc-contact-grid span,
.iloc-transport span,
.iloc-cta-card span {
  display: block;
  margin-top: 18px;
  color: #07a8b8;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 12px;
  line-height: 1.3;
  font-weight: 800;
  text-transform: uppercase;
}

.iloc-contact-grid strong {
  display: block;
  margin-top: 8px;
  color: #19344d;
  font-size: 20px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
  word-break: keep-all;
}

.iloc-contact-grid p {
  margin: 12px 0 0;
  color: #667889;
  font-size: 14px;
  line-height: 1.65;
  word-break: keep-all;
}

.iloc-content.location {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(390px, 0.85fr);
  gap: 28px;
  max-width: none;
  margin: 0;
  padding: 0;
}

.iloc-map-card,
.iloc-info-card {
  overflow: hidden;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
}

.ideal-location-page .map_box {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 560px;
}

.ideal-location-page .map_box .bg,
.ideal-location-page .map_box #map {
  width: 100%;
  height: 100%;
  min-height: 560px;
}

.ideal-location-page .addr_box {
  padding: 34px;
}

.ideal-location-page .addr_box h3 {
  position: relative;
  margin: 14px 0 22px;
  padding: 0;
  color: #19344d;
  font-size: 28px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.ideal-location-page .addr_box h3::before {
  display: none;
}

.ideal-location-page .addr_box .a_list {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ideal-location-page .addr_box .a_list li {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 14px;
  min-height: 0;
  margin: 0;
  padding: 15px 0;
  border-bottom: 1px solid rgba(20, 55, 82, 0.09);
}

.ideal-location-page .addr_box .a_list li:last-child {
  border-bottom: 0;
}

.ideal-location-page .addr_box .a_list li em {
  position: static;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-height: 34px;
  margin: 0;
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef8f9;
  color: #078e9a;
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
}

.ideal-location-page .addr_box .a_list li span {
  display: block;
  align-self: center;
  color: #344f66;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}

.ideal-location-page .addr_box .a_list .bus_btn {
  display: inline-flex;
  margin-top: 8px;
  color: #07a8b8;
  font-size: 13px;
  font-weight: 800;
}

.iloc-transport {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.iloc-transport div {
  padding: 28px 26px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(24, 48, 74, 0.06);
}

.iloc-transport span {
  margin-top: 0;
}

.iloc-transport h3,
.iloc-office-grid h3,
.iloc-cta-card strong {
  margin: 10px 0 0;
  color: #19344d;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.iloc-transport p,
.iloc-cta-card p {
  margin: 12px 0 0;
  color: #667889;
  font-size: 15px;
  line-height: 1.7;
  word-break: keep-all;
}

.iloc-office-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-top: 28px;
}

.iloc-office-grid article {
  padding: 32px;
  border-radius: 8px;
  background: #19344d;
  color: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.12);
}

.iloc-office-grid article:nth-child(2) {
  background: #07a8b8;
}

.iloc-office-grid h3 {
  margin: 0 0 20px;
  color: #fff;
}

.iloc-office-grid dl,
.iloc-office-grid div {
  margin: 0;
}

.iloc-office-grid dl {
  display: grid;
  gap: 12px;
}

.iloc-office-grid dl > div {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
}

.iloc-office-grid dt {
  color: rgba(255, 255, 255, 0.72);
  font-size: 13px;
  font-weight: 800;
}

.iloc-office-grid dd {
  margin: 0;
  color: #fff;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}

.iloc-cta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 28px;
}

.iloc-cta-card {
  overflow: hidden;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
  text-decoration: none;
}

.iloc-cta-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1.65 / 1;
  object-fit: cover;
  background: #e8eef2;
}

.iloc-cta-card div {
  padding: 24px;
}

.iloc-cta-card span {
  margin-top: 0;
}

.iloc-cta-card strong {
  display: block;
}

@media (max-width: 1180px) {
  .iloc-contact-grid,
  .iloc-transport,
  .iloc-cta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .iloc-content.location,
  .iloc-office-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .ideal-location-page .ib-hero h1 {
    max-width: 335px;
    font-size: 32px;
    line-height: 1.2;
    word-break: keep-all;
  }

  .ideal-location-page .ib-hero h1 br {
    display: none;
  }

  .ideal-location-page .ib-hero p {
    max-width: 330px;
    font-size: 16px;
    line-height: 1.7;
  }

  .iloc-head {
    margin-bottom: 28px;
  }

  .iloc-head h2 {
    font-size: 29px;
    line-height: 1.25;
  }

  .iloc-contact-grid,
  .iloc-transport,
  .iloc-office-grid,
  .iloc-cta-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .iloc-contact-grid article {
    min-height: 0;
    padding: 24px 20px;
  }

  .ideal-location-page .map_box,
  .ideal-location-page .map_box .bg,
  .ideal-location-page .map_box #map {
    min-height: 360px;
  }

  .ideal-location-page .addr_box {
    padding: 24px 20px;
  }

  .ideal-location-page .addr_box h3 {
    font-size: 24px;
  }

  .ideal-location-page .addr_box .a_list li {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 14px 0;
  }

  .ideal-location-page .addr_box .a_list li em {
    justify-self: start;
  }

  .iloc-transport div,
  .iloc-office-grid article {
    padding: 24px 20px;
  }

  .iloc-office-grid dl > div {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .iloc-cta-card div {
    padding: 22px 20px;
  }
}

/* Location map fallback for preview domains */
.iloc-map-fallback {
  display: grid;
  place-content: center;
  min-height: 560px;
  padding: 34px;
  background:
    linear-gradient(135deg, rgba(16, 43, 66, 0.88), rgba(7, 168, 184, 0.62)),
    url('/skin11/asset/img/ledi/banner_contact.png') center/cover no-repeat;
  color: #fff;
  text-align: center;
}

.iloc-map-fallback span {
  color: #35d6df;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.iloc-map-fallback strong {
  display: block;
  margin-top: 12px;
  font-size: 34px;
  line-height: 1.25;
  font-weight: 800;
}

.iloc-map-fallback p {
  margin: 14px 0 0;
  font-size: 17px;
  line-height: 1.65;
  word-break: keep-all;
}

.iloc-map-fallback a {
  justify-self: center;
  margin-top: 22px;
  padding: 12px 18px;
  border-radius: 999px;
  background: #fff;
  color: #078e9a;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

@media (max-width: 768px) {
  .iloc-map-fallback {
    min-height: 360px;
    padding: 26px 20px;
  }

  .iloc-map-fallback strong {
    font-size: 28px;
  }

  .iloc-map-fallback p {
    font-size: 15px;
  }
}

/* Location mobile hero text flow */
@media (max-width: 768px) {
  .ideal-location-page .ib-hero h1 strong br {
    display: block;
  }
}

@media (max-width: 768px) {
  .ideal-location-page .ib-hero h1 br {
    display: block;
  }
}

/* Ideal Korea sample test page */
.ideal-support-page {
  overflow: hidden;
  background: #f6f9fb;
  color: #19344d;
}

.isup-shell {
  width: min(1280px, calc(100% - 80px));
  margin: 0 auto;
}

.isup-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #07a8b8;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 13px;
  line-height: 1.3;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.isup-eyebrow::before {
  content: '';
  width: 28px;
  height: 2px;
  background: currentColor;
}

.isup-hero {
  position: relative;
  min-height: 720px;
  display: flex;
  align-items: center;
  isolation: isolate;
}

.isup-hero__media {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  background: #102b42;
}

.isup-hero__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.92) 0%, rgba(10, 33, 54, 0.7) 46%, rgba(10, 33, 54, 0.22) 100%);
}

.isup-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
}

.isup-hero__content {
  padding-top: 68px;
  color: #fff;
}

.isup-hero h1 {
  max-width: 780px;
  margin: 22px 0 0;
  color: #fff;
  font-size: 58px;
  line-height: 1.18;
  font-weight: 900;
  letter-spacing: 0;
  word-break: keep-all;
}

.isup-hero h1 strong {
  color: #35d6df;
  font-weight: 900;
}

.isup-hero p {
  max-width: 650px;
  margin: 24px 0 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: 19px;
  line-height: 1.8;
  font-weight: 700;
  word-break: keep-all;
}

.isup-section {
  padding: 110px 0;
}

.isup-section__head {
  max-width: 790px;
  margin-bottom: 42px;
}

.isup-section__head h2 {
  margin: 14px 0 0;
  color: #19344d;
  font-size: 38px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
}

.isup-section__head p {
  margin: 18px 0 0;
  color: #5d6f80;
  font-size: 17px;
  line-height: 1.8;
  word-break: keep-all;
}

.isample-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 30px;
}

.isample-benefits article {
  min-height: 210px;
  padding: 30px 28px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
}

.isample-benefits i {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #eef8f9;
  color: #07a8b8;
  font-size: 20px;
}

.isample-benefits strong {
  display: block;
  margin-top: 20px;
  color: #19344d;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
}

.isample-benefits p {
  margin: 12px 0 0;
  color: #667889;
  font-size: 15px;
  line-height: 1.7;
  word-break: keep-all;
}

.isample-content.sample {
  max-width: none;
  margin: 0;
  padding: 0;
}

.isample-card {
  margin: 0;
  padding: 36px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.07);
}

.isample-card + .isample-card,
.isample-card + .isample-flow,
.isample-flow + .isample-card {
  margin-top: 28px;
}

.isample-card h3 {
  position: relative;
  margin: 14px 0 0;
  padding: 0;
  color: #19344d;
  font-size: 30px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
}

.isample-card h3::before {
  display: none;
}

.isample-card .a_list {
  display: grid;
  gap: 12px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

.isample-card .a_list li {
  position: relative;
  display: block;
  min-height: 0;
  margin: 0;
  padding: 0 0 0 20px;
  color: #40596e;
  font-size: 16px;
  line-height: 1.8;
  word-break: keep-all;
}

.isample-card .a_list li::before {
  content: '';
  position: absolute;
  top: 13px;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #07a8b8;
}

.isample-card .a_list li span {
  display: block;
}

.isample-download {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #fff 0%, #f2fbfc 100%);
}

.isample-download::after {
  content: '';
  position: absolute;
  right: -80px;
  bottom: -120px;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  background: rgba(7, 168, 184, 0.08);
  pointer-events: none;
}

.isample-download .dlc {
  position: relative;
  z-index: 1;
  margin-top: 28px;
}

.isample-download .dlc .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  background: #07a8b8;
  color: #fff;
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 14px 26px rgba(7, 168, 184, 0.22);
}

.isample-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.isample-flow article {
  position: relative;
  min-height: 180px;
  padding: 28px 24px;
  border-radius: 8px;
  background: #19344d;
  color: #fff;
  overflow: hidden;
}

.isample-flow article:nth-child(even) {
  background: #07a8b8;
}

.isample-flow article span {
  position: absolute;
  right: 18px;
  top: 14px;
  color: rgba(255, 255, 255, 0.22);
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 52px;
  line-height: 1;
  font-weight: 900;
}

.isample-flow article strong {
  position: relative;
  display: block;
  margin-top: 28px;
  color: #fff;
  font-size: 21px;
  line-height: 1.35;
  font-weight: 900;
}

.isample-flow article p {
  position: relative;
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: 14px;
  line-height: 1.65;
  word-break: keep-all;
}

.isample-notice {
  border-color: rgba(220, 9, 43, 0.16);
}

.isample-notice .isup-eyebrow,
.isample-notice .a_list li::before {
  color: #dc092b;
  background: #dc092b;
}

.isample-notice .isup-eyebrow {
  background: transparent;
}

@media (max-width: 1180px) {
  .isample-benefits,
  .isample-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .isup-shell {
    width: min(100% - 36px, 1280px);
  }

  .isup-hero {
    min-height: 560px;
  }

  .isup-hero__content {
    padding-top: 60px;
  }

  .isup-hero h1 {
    max-width: 340px;
    font-size: 34px;
    line-height: 1.2;
  }

  .isup-hero p {
    max-width: 330px;
    font-size: 16px;
    line-height: 1.7;
  }

  .isup-section {
    padding: 72px 0;
  }

  .isup-section__head {
    margin-bottom: 28px;
  }

  .isup-section__head h2 {
    font-size: 30px;
    line-height: 1.25;
  }

  .isup-section__head p {
    font-size: 15px;
  }

  .isample-benefits,
  .isample-flow {
    grid-template-columns: 1fr;
  }

  .isample-benefits article,
  .isample-card,
  .isample-flow article {
    min-height: 0;
    padding: 24px 20px;
  }

  .isample-card h3 {
    font-size: 24px;
  }

  .isample-card .a_list li {
    font-size: 15px;
  }

  .isample-flow article strong {
    margin-top: 10px;
  }

  .isample-flow article span {
    font-size: 44px;
  }
}

/* Ideal Korea policy funds page */
.ideal-funds-page .ifunds-hero .isup-hero__media::after {
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.94) 0%, rgba(10, 33, 54, 0.72) 48%, rgba(10, 33, 54, 0.28) 100%);
}

.ifunds-section {
  background: linear-gradient(180deg, #f6f9fb 0%, #fff 40%, #f6f9fb 100%);
}

.ifunds-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 30px;
}

.ifunds-summary article {
  min-height: 210px;
  padding: 30px 28px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
}

.ifunds-summary i {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #eef8f9;
  color: #07a8b8;
  font-size: 20px;
}

.ifunds-summary strong {
  display: block;
  margin-top: 20px;
  color: #19344d;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
}

.ifunds-summary p {
  margin: 12px 0 0;
  color: #667889;
  font-size: 15px;
  line-height: 1.7;
  word-break: keep-all;
}

.ifunds-content.funds {
  max-width: none;
  margin: 0;
  padding: 0;
}

.ifunds-card {
  position: relative;
  margin: 0;
  padding: 34px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.07);
}

.ifunds-card + .ifunds-card,
.ifunds-card + .ifunds-program-grid,
.ifunds-program-grid + .ifunds-card {
  margin-top: 28px;
}

.ifunds-portal {
  overflow: hidden;
  background: linear-gradient(135deg, #fff 0%, #effafb 100%);
}

.ifunds-portal::after {
  content: '';
  position: absolute;
  right: -100px;
  bottom: -140px;
  width: 390px;
  height: 390px;
  border-radius: 50%;
  background: rgba(7, 168, 184, 0.08);
  pointer-events: none;
}

.ifunds-card__head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 20px;
}

.ifunds-card__head h3,
.ifunds-consult h3 {
  margin: 0;
  color: #19344d;
  font-size: 28px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
  word-break: keep-all;
}

.ifunds-card__head .isup-eyebrow {
  flex: 0 0 auto;
  margin-top: 8px;
}

.ifunds-number {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: #07a8b8;
  color: #fff;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 15px;
  font-weight: 900;
}

.ifunds-program-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-top: 28px;
}

.ifunds-program-grid .ifunds-card {
  display: flex;
  min-height: 100%;
  flex-direction: column;
}

.ifunds-card .a_list {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ifunds-card .a_list li {
  position: relative;
  display: block;
  min-height: 0;
  margin: 0;
  padding: 0 0 0 20px;
  color: #40596e;
  font-size: 15px;
  line-height: 1.8;
  word-break: keep-all;
}

.ifunds-card .a_list li::before {
  content: '';
  position: absolute;
  top: 13px;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #07a8b8;
}

.ifunds-card .a_list li span {
  display: block;
}

.ifunds-card .a_list strong {
  color: #19344d;
  font-weight: 900;
}

.ifunds-card .dlc {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding-top: 24px;
}

.ifunds-card .dlc .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 20px;
  border-radius: 999px;
  background: #07a8b8;
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 14px 26px rgba(7, 168, 184, 0.2);
}

.ifunds-table-card {
  overflow: hidden;
}

.ifunds-table-card table {
  width: 100%;
  margin: 4px 0 0;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 8px;
  font-size: 15px;
}

.ifunds-table-card th,
.ifunds-table-card td {
  padding: 18px 20px;
  border-bottom: 1px solid rgba(20, 55, 82, 0.08);
  text-align: left;
  line-height: 1.6;
  word-break: keep-all;
}

.ifunds-table-card th {
  background: #19344d;
  color: #fff;
  font-weight: 900;
}

.ifunds-table-card td:first-child {
  color: #19344d;
  font-weight: 900;
}

.ifunds-table-card tbody tr:nth-child(even) td {
  background: #f6fafb;
}

.ifunds-tip-card {
  background: #f6fafb;
}

.ifunds-consult {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 24px;
  align-items: center;
  margin-top: 28px;
  padding: 38px;
  border-radius: 8px;
  background: #19344d url('/skin11/asset/img/ledi/banner_contact.png') center/cover no-repeat;
  color: #fff;
  box-shadow: 0 22px 48px rgba(24, 48, 74, 0.14);
}

.ifunds-consult::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 8px;
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.9), rgba(10, 33, 54, 0.48));
}

.ifunds-consult > * {
  position: relative;
  z-index: 1;
}

.ifunds-consult .isup-eyebrow,
.ifunds-consult h3,
.ifunds-consult p {
  color: #fff;
}

.ifunds-consult .isup-eyebrow {
  color: #35d6df;
}

.ifunds-consult h3 {
  margin-top: 12px;
}

.ifunds-consult p {
  max-width: 720px;
  margin: 14px 0 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 16px;
  line-height: 1.75;
  word-break: keep-all;
}

.ifunds-consult a,
.ifunds-consult strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 900;
  white-space: nowrap;
}

.ifunds-consult a {
  padding: 0 22px;
  background: #07a8b8;
  color: #fff;
  text-decoration: none;
}

.ifunds-consult strong {
  padding: 0 20px;
  background: #fff;
  color: #19344d;
}

@media (max-width: 1180px) {
  .ifunds-summary,
  .ifunds-program-grid {
    grid-template-columns: 1fr;
  }

  .ifunds-consult {
    grid-template-columns: 1fr;
    align-items: start;
  }
}

@media (max-width: 768px) {
  .ideal-funds-page .isup-hero h1 {
    max-width: 340px;
    font-size: 33px;
    line-height: 1.22;
  }

  .ideal-funds-page .isup-hero p {
    max-width: 330px;
  }

  .ifunds-summary article,
  .ifunds-card,
  .ifunds-consult {
    padding: 24px 20px;
  }

  .ifunds-card__head {
    display: grid;
    gap: 14px;
  }

  .ifunds-card__head h3,
  .ifunds-consult h3 {
    font-size: 24px;
  }

  .ifunds-card .a_list li {
    font-size: 14px;
  }

  .ifunds-table-card {
    overflow-x: auto;
  }

  .ifunds-table-card table {
    min-width: 620px;
  }

  .ifunds-table-card th,
  .ifunds-table-card td {
    padding: 14px 16px;
    font-size: 14px;
  }

  .ifunds-consult a,
  .ifunds-consult strong {
    width: 100%;
  }
}

/* Funds consult overlay containment */
.ifunds-consult {
  position: relative;
  overflow: hidden;
}

/* Ideal Korea inquiry page */
.ideal-inquiry-page .iinq-hero .isup-hero__media::after {
  background: linear-gradient(90deg, rgba(10, 33, 54, 0.93) 0%, rgba(10, 33, 54, 0.7) 48%, rgba(10, 33, 54, 0.18) 100%);
}

.iinq-section {
  background: linear-gradient(180deg, #f6f9fb 0%, #fff 42%, #f6f9fb 100%);
}

.iinq-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 30px;
}

.iinq-benefits article {
  min-height: 210px;
  padding: 30px 28px;
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
}

.iinq-benefits i {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #eef8f9;
  color: #07a8b8;
  font-size: 20px;
}

.iinq-benefits strong {
  display: block;
  margin-top: 20px;
  color: #19344d;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
}

.iinq-benefits p {
  margin: 12px 0 0;
  color: #667889;
  font-size: 15px;
  line-height: 1.7;
  word-break: keep-all;
}

.iinq-content.inquiry {
  display: grid;
  grid-template-columns: 390px minmax(0, 1fr);
  gap: 28px;
  max-width: none;
  margin: 0;
  padding: 0;
}

.iinq-guide-card,
.iinq-form-card {
  border: 1px solid rgba(20, 55, 82, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(24, 48, 74, 0.08);
}

.iinq-guide-card {
  align-self: start;
  position: sticky;
  top: 92px;
  padding: 32px 28px;
}

.iinq-guide-card h3,
.iinq-form-head h3 {
  margin: 14px 0 0;
  color: #19344d;
  font-size: 27px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
  word-break: keep-all;
}

.iinq-guide-card ul {
  display: grid;
  gap: 14px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}

.iinq-guide-card li {
  padding: 16px 0;
  border-bottom: 1px solid rgba(20, 55, 82, 0.09);
}

.iinq-guide-card li:last-child {
  border-bottom: 0;
}

.iinq-guide-card li strong,
.iinq-guide-card li span {
  display: block;
  word-break: keep-all;
}

.iinq-guide-card li strong {
  color: #07a8b8;
  font-size: 14px;
  font-weight: 900;
}

.iinq-guide-card li span {
  margin-top: 6px;
  color: #4c6275;
  font-size: 15px;
  line-height: 1.6;
}

.iinq-contact-box {
  margin-top: 26px;
  padding: 24px;
  border-radius: 8px;
  background: #19344d;
  color: #fff;
}

.iinq-contact-box span,
.iinq-contact-box strong,
.iinq-contact-box p {
  display: block;
}

.iinq-contact-box span {
  color: #35d6df;
  font-size: 13px;
  font-weight: 900;
}

.iinq-contact-box strong {
  margin-top: 8px;
  font-family: Poppins, 'Noto Sans KR', sans-serif;
  font-size: 26px;
  line-height: 1.2;
  font-weight: 900;
}

.iinq-contact-box p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 14px;
}

.iinq-form-card {
  overflow: hidden;
}

.iinq-form-head {
  padding: 32px 34px 24px;
  background: linear-gradient(135deg, #fff 0%, #effafb 100%);
  border-bottom: 1px solid rgba(20, 55, 82, 0.1);
}

.iinq-form-head p {
  margin: 12px 0 0;
  color: #667889;
  font-size: 15px;
  line-height: 1.7;
  word-break: keep-all;
}

.iinq-form-card iframe {
  display: block;
  width: 100%;
  min-height: 1000px;
  border: 0;
  background: #fff;
}

@media (max-width: 1180px) {
  .iinq-content.inquiry {
    grid-template-columns: 1fr;
  }

  .iinq-guide-card {
    position: static;
  }
}

@media (max-width: 768px) {
  .ideal-inquiry-page .isup-hero h1 {
    max-width: 340px;
    font-size: 33px;
    line-height: 1.22;
  }

  .ideal-inquiry-page .isup-hero p {
    max-width: 330px;
  }

  .iinq-benefits {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .iinq-benefits article,
  .iinq-guide-card {
    min-height: 0;
    padding: 24px 20px;
  }

  .iinq-guide-card h3,
  .iinq-form-head h3 {
    font-size: 24px;
  }

  .iinq-form-head {
    padding: 24px 20px 20px;
  }

  .iinq-form-card iframe {
    min-height: 1760px;
  }
}

/* Ideal Korea service request page */
.ideal-service-page .iinq-hero .isup-hero__media::after {
  background: linear-gradient(90deg, rgba(9, 35, 56, 0.94) 0%, rgba(9, 35, 56, 0.72) 48%, rgba(9, 35, 56, 0.18) 100%);
}

.ideal-service-page .iinq-benefits article:nth-child(2) i {
  background: #19344d;
}

.ideal-service-page .iinq-benefits article:nth-child(3) i {
  background: #dc092b;
}

.ideal-service-page .iinq-contact-box {
  background: linear-gradient(135deg, #19344d 0%, #0e263c 100%);
}

.ideal-service-page .iinq-form-card iframe {
  min-height: 1540px;
}

@media (max-width: 720px) {
  .ideal-service-page .iinq-form-card iframe {
    min-height: 1620px;
  }
}

/* Loader removed: keep legacy markup inert */
body.scroll-disabled {
  overflow: auto !important;
}

.load {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

