@charset "UTF-8";
/************************************************************************************/
/************************************* Colors *************************************/
/************************************************************************************/
:root {
  --white:#fff;
  --black:#000;
  --red:#be1b23;
  --blue:#194bae;
  --light-blue:#5163c0;
  --deep-blue:#05014a;
  --orange:#ff9644;
  --gray-cd:#cdcdcd;
  --gray-af:#afafaf;
  --gray-e8:#e8e8e8;
  --gray-f8:#f8f8f8;
  --gray-fa:#fafafa;
  --gray-f2:#f2f2f2;
  --gray-f5:#f5f5f5;
  --gray-d2:#d2d2d2;
  --gray-d4:#d4d4d4;
  --gray-d5:#d5d5d5;
  --gray-dd:#dddddd;
  --gray-f0:#f0f0f0;
  --gray-f1:#f1f1f1;
  --gray-f3:#f3f3f3;
  --gray-f7:#f7f7f7;
  --gray-7c:#7c7c7c;
  --gray-95: #959595;
  --gray-55: #555555;
  --gray-27: #272727;
  --gray-33: #333333;
  --gray-88: #888888;
  --main-color:#1f396c;
  --point-color:#4f3126;
  --point01:#010A65;
  --gray-point: #606060;
  --black-point:#352f36;
  --gray-bg: #f8f8f8;
  --gray-bg2: #f3f3f3;
  --gray-dark-bg: #eaeaea;
  --font-basic: #252323;
  --border-color:#d7d7d7;
  --border-color2: #bfbfbf;
  --footer-bg: #252323;
  --footer-txt1: #aaaaaa;
  --instagram: #ff0074;
  --facebook: #0866ff;
  --naver: #03c75a;
  --youtube: #ff0000;
  --kakao: #fee500;
}

/* font-size */
/* absolute-center */
/* transition */
/************************************************************************************/
/*************************************** common ***************************************/
/************************************************************************************/
/* common */
html {
  font-size: 62.5%;
}

body {
  font-family: "Pretendard", 맑은고딕, "Dotum", 돋움, "Arial", "sans-serif";
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.4;
  word-break: keep-all;
  letter-spacing: -0.02em;
  color: var(--font-basic);
}
@media (max-width: 1024px) {
  body {
    font-size: 1.6rem;
  }
}
@media (max-width: 768px) {
  body {
    font-size: 1.5rem;
  }
}
body a {
  color: var(--font-basic);
  text-decoration: none;
}
body.en-body {
  letter-spacing: 0;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--black);
  line-height: 1.4;
  font-weight: 600;
}

a, input, button, select {
  outline-offset: 2px;
  outline-color: var(--font-basic);
}

table {
  width: 100%;
}

.center {
  text-align: center;
}

.wrap-in {
  max-width: 1380px;
  margin: 0 auto;
}
@media screen and (max-width: 1380px) {
  .wrap-in {
    max-width: calc(100% - 64px);
  }
}
@media screen and (max-width: 768px) {
  .wrap-in {
    max-width: calc(100% - 40px);
  }
}
@media screen and (max-width: 320px) {
  .wrap-in {
    max-width: calc(100% - 32px);
  }
}

.wrap-in2 {
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
}
@media screen and (max-width: 1380px) {
  .wrap-in2 {
    max-width: calc(100% - 64px);
  }
}
@media screen and (max-width: 768px) {
  .wrap-in2 {
    max-width: calc(100% - 40px);
  }
}
@media screen and (max-width: 320px) {
  .wrap-in2 {
    max-width: calc(100% - 32px);
  }
}

.inner {
  max-width: 1220px;
  margin: 0 auto;
}
@media screen and (max-width: 1220px) {
  .inner {
    max-width: calc(100% - 64px);
  }
}
@media screen and (max-width: 768px) {
  .inner {
    max-width: calc(100% - 40px);
  }
}
@media screen and (max-width: 320px) {
  .inner {
    max-width: calc(100% - 32px);
  }
}

.inner2 {
  max-width: 1180px;
  margin: 0 auto;
}
@media screen and (max-width: 1180px) {
  .inner2 {
    max-width: calc(100% - 64px);
  }
}
@media screen and (max-width: 768px) {
  .inner2 {
    max-width: calc(100% - 40px);
  }
}
@media screen and (max-width: 320px) {
  .inner2 {
    max-width: calc(100% - 32px);
  }
}

.wrap-in-m {
  max-width: 1600px;
  margin: 0 auto;
}
@media screen and (max-width: 1600px) {
  .wrap-in-m {
    max-width: calc(100% - 64px);
  }
}
@media screen and (max-width: 768px) {
  .wrap-in-m {
    max-width: calc(100% - 40px);
  }
}
@media screen and (max-width: 320px) {
  .wrap-in-m {
    max-width: calc(100% - 32px);
  }
}

.p-none {
  display: none;
}
@media screen and (max-width: 1280px) {
  .p-none {
    display: block;
  }
}

.pt-none {
  display: none;
}
@media screen and (max-width: 768px) {
  .pt-none {
    display: block;
  }
}

/*************************************** new - header ***************************************
#header {
    position: fixed;
    top: 0; left: 0; width: 100%;
    height: calc(40px + (1.25vw + 8px) * 2 + 1px);
    z-index: 9999;
    font-size: clamp(1.6rem, 1.04166vw, 2.4rem);
    font-weight: 400;
    letter-spacing: -0.01em;
    line-height: 1;
    color: #fff;

    .header-wrapper {
        position: relative; height: 100%;
        border-bottom: 1px solid rgba(0,0,0,0);
        transition: background-color 350ms ease;
        box-sizing: border-box;
        padding: 0 max(1.6rem, 4.16666vw);
    }

    .header-inner {
        display:flex;
        justify-content:space-between;
        align-items:center;
        height:100%;
    }

    .header-units {
        display:flex;
        align-items:center;

        li { position: relative; }

        a, button { display:block; }

        .icon svg { display:block; width:1.1em; height:auto; }
        .txt { display:block; }

        &-subscribe {
            padding-right:1.2em; margin-right:1.2em; position:relative;

            button { display:flex; gap:.4em; align-items:center; cursor:pointer; }

            &::after {
            content:""; width:1px; height:18px; background:#fff; opacity:.3;
            position:absolute; right:0; top:50%; transform:translateY(-50%);
            }
        }

        &-lang {
            margin-right:1.2em; color:inherit;

            .icon { display:none; }
            .lang-list, .lang-toggle-btn { display:none; }
            .lang-list-m { display:flex; align-items:center; }
            a { color:#222222; }
        }

        &-search {
            button {
            cursor:pointer;
            .icon {
                svg.mobile { display:none; }
            }
            }
        }

        &-mobile { display:none; }
    }

    .header-logo {
        position:relative; width:7.25em; z-index:2;

        img {
            position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
            width:100%; opacity:0; transition:opacity 350ms ease;

            &.white { opacity:1; }
        }
  }

  .gnb-bg {
    position:absolute; top:0; left:0; background:#fff;
    width:100%; height:0; transition:350ms ease; transition-duration:.4s;

    &::before {
      content:""; position:absolute; top:calc(40px + (1.25vw + 8px) * 2 + 1px - 1px);
      left:0; width:100%; height:1px; background:#e5e5e5; opacity:0;
    }
  }

  .gnb-list {
    display:flex;

    > li {
      position:relative;

      &::before {
        content:""; position:absolute; left:50%; bottom:0; width:0; height:2px;
        background:#f37321; transition:350ms ease; transition-property:width,left;
      }

      &:last-child .gnb-2depth::after {
        content:""; position:absolute; top:0; right:0; width:1px; height:0;
        background:#e5e5e5; transition:350ms ease; transition-property:height;
      }
    }

    &.active {
      .gnb-about .gnb-1depth > a     { padding-left:2.2em;  padding-right:2.2em; }
      .gnb-industries .gnb-1depth > a{ padding-left:2.2em;  padding-right:2.2em; }
      .gnb-companies .gnb-1depth > a { padding-left:1.85em; padding-right:1.85em; }
      .gnb-sustainability .gnb-1depth > a { padding-left:1.475em; padding-right:1.475em; }
      .gnb-careers .gnb-1depth > a   { padding-left:2.6em;  padding-right:2.6em; }
      .gnb-newsroom .gnb-1depth > a  { padding-left:1.925em; padding-right:1.925em; }
    }

    &:not(.active) .hover::before { opacity:0; transition:none; }

    .hover:not(.gnb-companies, .gnb-careers) .gnb-2depth::before { opacity:1; }

    @media screen and (min-width:1281px) {
      .hover::before { width:100%; left:0; }
    }
  }

  .gnb-1depth {
    position:relative; height:calc(40px + (1.25vw + 8px) * 2 + 1px); display:flex; align-items:center;

    > a {
      padding:.5em 1.2em;
      transition:350ms ease;
      transition-property:color,padding;
      color: #fff;

      .font-hanwha {
        padding-left:.2em; font-size:max(1.3rem, .88542vw);
        font-weight:400; letter-spacing:-0.01em; line-height:1.2;
      }
      .icon { display:none; }
    }
  }

  .gnb-2depth {
    position:absolute; top:100%; left:0; width:100%; text-align:center;
    padding:1.1875em 0 2.4em; box-sizing:border-box;
    opacity:100; visibility:hidden; isolation:isolate; box-sizing:border-box;

    &::before {
      content:""; position:absolute; top:0; left:0; width:100%; height:100%;
      background:rgba(0,0,0,.02); opacity:0; transition:opacity 350ms ease; z-index:1;
    }

    &-list {
      position:relative; z-index:2;

      > li > a {
        display:block; padding:.4375em;
        font-size:clamp(1.3rem, .83333vw, 2rem); font-weight:400;
        letter-spacing:-0.01em; line-height:1.3; color:#222222;

        span {
          background-image:linear-gradient(transparent calc(100% - 1px), #222222 1px);
          background-repeat:no-repeat; background-size:0% 100%; transition:background-size .35s;
        }
      }

      @media screen and (min-width:1281px) {
        > li > a:hover span { background-size:100% 100%; }
      }
    }
  }

  .gnb-mobile-dimmed { display:none; }
  .mobile-subscribe-btn { display:none; }

  &.main-header {
    .header-wrapper::after {
      content:""; position:absolute; top:0; left:0; width:100%; height:100%;
      background:linear-gradient(180deg, rgba(0,0,0,.2) 0%, rgba(0,0,0,0) 100%);
      transition:400ms ease; transition-property:background-color; z-index:-1;
    }
  }

  &.dark, &.fixed, &[data-open=true] {
    .header { color:#222222; }
    .header-wrapper { background:#fff; }
    .header-wrapper::after { background:none; }

    .header-units {
      a, button { color:#222222; }

      &-subscribe {
        .icon svg path { fill:#222222; }
        &::after { background:#222222; }
      }

      &-lang { color:#222222; }

      &-search .icon {
        svg { path, rect { fill:#222222; } }
      }
    }

    .header-logo img.black { opacity:1; }
    .gnb-list .gnb-1depth a { color:#222222; }
  }

  &.fixed:not([data-open=true]) {
    .header-wrapper { border-bottom:1px solid #e5e5e5; }
    .header-wrapper::after { background:#fff; }
    .header-units-mobile .mobile-menu-btn .default path { fill:#222222; }
  }

  &.top { .header-wrapper { border-bottom-color:transparent; } }

  &[data-open=true] {
    .gnb-bg { height: var(--activeHeight); }
    .gnb-bg::before { opacity:1; transition-delay:.2s; }
    .gnb-1depth > a { color:#222222; }

    .gnb-list {
      > li:last-child .gnb-2depth { border-right:1px solid #e5e5e5; }

      .gnb-2depth {
        opacity:1; visibility:visible;
        transition:350ms ease; transition-property:opacity,visibility,background-color; transition-delay:.3s;
        border-left:1px solid #e5e5e5;
      }
    }
  }

  &.is-search {
    .header-wrapper::before { opacity:0; }
    .header-logo { z-index:10; }
    .header-logo img.black { opacity:1; }
    .header-units-lang { visibility:hidden; }
  }

  @media screen and (min-width:1281px) {
    #gnb { position:absolute; top:0; left:50%; transform:translateX(-50%); }
    .gnb-bg { width:100vw; left:50%; transform:translateX(-50%); }
    .gnb-1depth > a { white-space:nowrap; }
    .gnb-mobile-top { display:none; }

    .header-units-lang {
      position:relative;

      .lang-toggle-btn { display:block; cursor:pointer; }
      .lang-toggle-btn.open + .lang-list { opacity:1; visibility:visible; }

      .lang-list-m { display:none; }

      .lang-list {
        position:absolute; top:100%; left:50%; margin-top:.75em; transform:translateX(-50%);
        display:flex; flex-direction:column; background:#fff; width:4.5em; padding:.5em 0;
        box-shadow:0 0 10px 0 rgba(0,0,0,.1); border-radius:max(.6rem, .41667vw);
        opacity:0; visibility:hidden; transition:350ms ease; transition-property:opacity,visibility;
        font-size:clamp(1.3rem, .83333vw, 2rem); font-weight:400; letter-spacing:-0.01em; line-height:1.3;

        a {
          display:inline-flex; padding:.625em 0; justify-content:center;
          transition:background-color 350ms ease; color:#222222;

          &:hover {
            background:#F5F5F5;
            span { background-size:100% calc(100% - 3px); }
          }

          span {
            background-image:linear-gradient(transparent calc(100% - 1px), #222222 1px);
            background-repeat:no-repeat; background-size:0% calc(100% - 3px);
            transition:background-size .35s;
          }
        }
      }
    }
  }

  @media screen and (max-width:1280px) {
    height:7.2rem; font-size:1.6rem; font-weight:500;

    .header-logo { width:7.375em; }

    .header-units {
      width:100%; justify-content:space-between;

      &-subscribe, &-lang { display:none; }

      &-lang {
        display:none; align-items:center;
        font-size:1.6rem; font-weight:500; letter-spacing:-0.01em; line-height:1.5;

        .icon { display:block; margin-right:.8181818182em; }
        .icon svg { display:block; width:1.25em; }
        .active { color:#F37321 !important; }
      }

      &-search {
        margin-right:1.5384615385em;

        button .icon svg { display:block; width:1.5384615385em; }
        button .icon {
          svg.mobile { display:block; }
          svg.default { display:none; }
        }
      }

      &-mobile {
        display:inline-flex; align-items:center; width:24px; height:24px;

        .mobile-menu-btn {
          cursor:pointer; width:100%; height:100%;

          svg {
            position:absolute; top:0; left:0; width:100%; height:auto; transition:all 350ms ease;
          }
          .close { opacity:0; }
        }
      }
    }

    #gnb {
      position:absolute; top:7.2rem; top:0; left:0;
      padding:0 max(1.6rem, 4.16666vw);
      visibility:hidden; box-sizing:border-box; width:100vw; background:#fff;

      &.mobile {
        -webkit-transform: translate3d(100vw,0,0);
        transform: translate3d(100vw,0,0);
        transition: .5s cubic-bezier(.16,.68,.43,.99);
        transition-property: transform, visibility;
      }
    }

    .gnb-mobile-top {
      position:relative; height:7.2rem; margin:0 calc(-1 * max(1.6rem, 4.16666vw));

      &-inner {
        height:100%; opacity:0; transition:opacity .3s cubic-bezier(.16,.68,.43,.99);
      }

      .lang-box {
        display:flex; align-items:center; height:100%;
        font-size:1.6rem; font-weight:500; letter-spacing:-0.01em; line-height:1.5;

        .icon { display:block; margin-right:.5em; }
        .icon svg { display:block; width:1.25em; height:1.25em; }

        .lang-list-m {
          display:flex; align-items:center;

          a {
            display:flex; align-items:center; color:#222222;

            .txt { display:block; padding:0 .375em; }
            &.active { color:#F37321; }

            &:first-child::after {
              content:""; display:inline-flex; width:1px; height:.875em; background:#E5E5E5; margin:0 .5em;
            }
          }
        }
      }

      &::before {
        content:""; position:absolute; bottom:0; width:100vw; left:50%;
        transform:translateX(-50%); height:1px; background:#e5e5e5;
      }
    }

    .gnb-list {
      flex-direction:column; margin:1.5em 0 2.4230769231em;

      &-wrap {
        height:calc(100dvh - var(--topHeight, 7.2rem));
        overflow-y:scroll; opacity:0; transition:opacity .3s cubic-bezier(.16,.68,.43,.99);
        &::-webkit-scrollbar{ display:none; }
      }

      a { color:#222222; br { display:none; } }

      .gnb-1depth {
        display:block; height:auto;

        a {
          display:flex; justify-content:space-between; align-items:center; padding:.9230769231em 0;

          .font-hanwha { font-size:1.4rem; font-weight:700; letter-spacing:-0.01em; line-height:1.7; }

          .icon {
            display:block;

            svg {
              display:block; width:1.5384615385em; height:auto; isolation:isolate;

              path {
                transition:350ms ease; transition-property:fill, transform, opacity;
                transform-origin:center; will-change:fill, transform, opacity;
              }
            }
          }
        }
      }

      .gnb-2depth {
        position:relative; top:0; text-align:left; padding:0;
        overflow:hidden; transition:height 350ms ease;

        &-list {
          display:flex; flex-direction:column; gap:.9230769231em;
          padding:0 1.5384615385em 2.1538461538em;

          > li a { font-size:1.4rem; color:#222222; padding:0; }
        }
      }

      > li {
        border-bottom:1px solid #e5e5e5;

        &::before { display:none; }

        &:not([data-has-2dep]) .gnb-1depth .icon { opacity:0; }

        &.active .gnb-1depth a { color:#F37321; }

        &[data-open=true] {
          .gnb-1depth a {
            color:#F37321; padding-bottom:1.2307692308em;

            .icon svg path {
              transform:rotate(90deg);

              &:nth-child(1) { fill:#f37321; }
              &:nth-child(2) { opacity:0; }
            }
          }
        }
      }
    }

    .gnb-mobile-dimmed {
      position:fixed; top:0; left:0; width:100%;
      height:calc(100dvh + var(--topHeight, 7.2rem));
      background:rgba(0,0,0,.5); display:none; z-index:2;
    }

    .mobile-subscribe-btn {
      display:block; padding-bottom:2.4230769231em;

      button {
        display:flex; align-items:center; justify-content:center; gap:.5454545455em;
        width:100%; height:5.6rem; font-size:1.6rem; font-weight:500; letter-spacing:-0.01em; line-height:1.5;
        background:#F5F5F5; border-radius:max(.8rem, .83333vw); color:#222222;

        svg { display:block; width:1.25em; height:auto; }
      }
    }

    &.dark {
      .header-wrapper::before { display:none; }
      .header-units-mobile svg path { fill:#222222; }
    }

    &.open {
      .header-units-search { display:none; }
      .header-units-lang { display:flex; }
      .header-units-mobile { z-index:3; }
      .header-units-mobile .default { opacity:0; }
      .header-units-mobile .close { opacity:1; }

      #gnb { visibility:visible; -webkit-transform:translate3d(0,0,0); transform:translate3d(0,0,0); z-index:3; }
      .gnb-mobile-top-inner { opacity:1; }
      .gnb-list-wrap { opacity:1; }
      .gnb-mobile-dimmed { display:block; }
    }

    &:not(.open) {
      .gnb-mobile-top-inner, .gnb-list-wrap { transition-delay:0s; }
    }
  }

  @media screen and (max-width:767px) {
    height:6.4rem; font-size:1.6rem; font-weight:500;

    .header-logo { width:6.375em; }

    .header-units-lang {
      font-size:1.6rem; font-weight:500; letter-spacing:-0.01em; line-height:1.5;

      .icon { margin-right:.5em; }
      .icon svg { width:1.25em; }
      .icon svg path { vector-effect:non-scaling-stroke; }
      a .txt { padding:0 .375em; }
    }

    .header-units-search {
      margin-right:1.25em;
      button .icon svg { width:1.5em; }
    }

    .header-units-mobile { width:1.5em; height:1.5em; }

    .gnb-mobile-top { height:6.4rem; }

    .gnb-list {
      margin:1em 0 2em;

      &-wrap { height:calc(100dvh - var(--topHeight, 6.4rem)); }

      .gnb-1depth a { padding:1em 0; font-weight:500; }
      .gnb-1depth a .icon svg { width:1.5em; }

      .gnb-2depth-list {
        gap:1em; padding:0 1em 2.5625em;

        > li a { font-size:1.4rem; br { display:none; } }
      }

      > li[data-open=true] .gnb-1depth a { padding-bottom:1.5384615385em; }
    }

    .mobile-subscribe-btn button {
      font-size:1.6rem; font-weight:500; letter-spacing:-0.01em; line-height:1.5;
      gap:.5em; padding:1em 0;
    }
  }

  .header-search-bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 0px;
    background-color: #FFFFFF;
    transition: 0.35s ease;
    transition-property: height;
    z-index: 1;
    }
    .header-search-bg.open {
    height: var(--height);
    }
    .dimmed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9998;
    }
}

*/
/************************************************************************************/
/*************************************** header ***************************************/
/************************************************************************************/
.none-visible {
  overflow: hidden;
  position: absolute;
  width: 1px;
  height: 1px;
  font-size: 1px;
  line-height: 0;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  margin: -1px;
  padding: 0;
  border: 0;
}

.ir {
  display: inline-block;
  text-indent: -9999px;
  overflow: hidden;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  text-align: left !important;
}

header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 7rem;
  z-index: 1000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  padding: 3rem 0 0;
}
header .header-top-inner {
  margin: 0 auto;
  border-radius: 50px;
  width: 138rem;
  height: 7rem;
}
header .header-top-inner .header-top {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 5rem 0 3.6rem;
}
header .header-top-inner .header-left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
header .header-top-inner .header-left .logo a {
  display: block;
  width: 13.4rem;
  height: 4.5rem;
  background: url(/images/common/logo_w.svg) no-repeat;
}
@media screen and (max-width: 1300px) {
  header .header-top-inner .header-left .logo a {
    background: url(/images/common/logo.svg) no-repeat;
  }
}
header .header-top-inner .header-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .header-top-inner .header-right .click-close {
  display: none;
}
header .header-top-inner .header-right nav {
  height: 100%;
}
header .header-top-inner .header-right nav .gnb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
}
header .header-top-inner .header-right nav .gnb > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.6rem;
  color: #fff;
}
@media (max-width: 1024px) {
  header .header-top-inner .header-right nav .gnb > li > a {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  header .header-top-inner .header-right nav .gnb > li > a {
    font-size: 1.4rem;
  }
}
header .header-top-inner .header-right nav .gnb .wem {
  padding: 1rem 5.5rem;
  font-weight: 500;
  letter-spacing: 0;
}
header .header-top-inner .header-right nav .gnb .wem:hover {
  color: #194bae;
}
header .header-top-inner .header-right nav .gnb .menu-item {
  position: relative;
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  cursor: pointer;
}
header .header-top-inner .header-right nav .gnb .menu-item::after {
  content: "";
  display: inline-block;
  margin-left: 10px;
  vertical-align: middle;
  width: 8px;
  height: 8px;
  border-left: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  top: -2px;
  position: relative;
}
header .header-top-inner .header-right nav .gnb .menu-item:hover {
  color: #194bae;
}
header .header-top-inner .header-right nav .gnb .layer-menu {
  padding-top: 1rem;
  height: 220px;
  display: none;
}
header .header-top-inner .header-right nav .gnb .layer-menu ul {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
  top: 0;
}
header .header-top-inner .header-right nav .gnb .layer-menu ul::before {
  content: "";
  width: 1px;
  height: 0;
  border-right: 1px solid var(--main-color);
  display: block;
  position: absolute;
  left: -20px;
  top: 5px;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
header .header-top-inner .header-right nav .gnb .layer-menu ul li {
  position: relative;
  height: 100%;
  margin-top: 1rem;
  white-space: nowrap;
}
header .header-top-inner .header-right nav .gnb .layer-menu ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
}
header .header-top-inner .header-right nav .gnb .layer-menu ul li a:hover {
  color: #194bae;
}
header .header-top-inner .header-right nav .gnb .layer-menu ul:hover::before {
  height: 100%;
}
@media screen and (max-width: 1300px) {
  header .header-top-inner .header-right {
    display: none;
    position: absolute;
    top: 60px;
    right: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.5);
  }
  header .header-top-inner .header-right .click-close {
    display: block;
    width: 20%;
    height: 100vh;
    position: absolute;
    left: 0;
    top: 0;
  }
  header .header-top-inner .header-right nav {
    display: block;
    position: absolute;
    width: 80%;
    height: 100vh;
    margin-left: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    background-color: #ffffff;
  }
  header .header-top-inner .header-right nav .gnb {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  header .header-top-inner .header-right nav .gnb > li .wem {
    height: 60px;
    padding: 1.2em 2em;
    color: #000;
  }
  header .header-top-inner .header-right nav .gnb .layer-menu {
    background-color: #f8f8f8;
    padding: 1em 0 2em;
    height: auto;
  }
  header .header-top-inner .header-right nav .gnb .layer-menu ul {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: relative;
    left: 0;
    -webkit-transform: none;
            transform: none;
    top: 0;
  }
  header .header-top-inner .header-right nav .gnb .layer-menu ul li {
    margin-top: 0;
  }
  header .header-top-inner .header-right nav .gnb .layer-menu ul li a {
    padding: 0.5em 2em;
    display: block;
  }
  header .header-top-inner .header-right .--open {
    margin-left: 20%;
  }
}
header.--navopen .header-top-inner .header-left .logo a {
  background: url(/images/common/logo.svg) no-repeat;
}
header.--navopen .header-top-inner .header-right nav .gnb > li > a {
  color: #000;
}
header .gnb_bg {
  position: absolute;
  left: 50%;
  top: -3rem;
  height: 0;
  width: 100%;
  background-color: #fff;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  z-index: -9;
}
header .on {
  height: 320px;
}
@media screen and (max-width: 1300px) {
  header {
    padding: 0;
  }
  header .header-top-inner {
    width: 100%;
    height: 60px;
    max-width: 100%;
    border-radius: 0px;
    border-bottom: 1px solid rgb(0, 0, 0);
  }
  header .header-top-inner .header-top {
    padding: 0 3rem 0;
  }
}

.bt_aside_menu {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--main-color) url(/images/common/ico_menu_line.svg) no-repeat 50% 50%;
  background-size: 20px 20px;
  top: 50%;
  position: relative;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 1300px) {
  .bt_aside_menu {
    width: 35px;
    height: 35px;
    background-size: 15px;
  }
}

.open {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.menu-icon {
  width: 50px;
  height: 50px;
  background-color: var(--main-color);
  border-radius: 50%;
  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;
  cursor: pointer;
  position: relative;
  text-decoration: none;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
  position: absolute;
  right: 4rem;
  top: 4rem;
}
.menu-icon span {
  position: absolute;
  background-color: #fff;
  width: 20px;
  height: 2px;
  border-radius: 2px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.menu-icon span:first-child {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.menu-icon span:last-child {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.menu-icon:hover {
  background-color: #000;
}
.menu-icon:active {
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
}

/************************************************************************************/
/*************************************** footer ***************************************/
/************************************************************************************/
.footer {
  border-top: 1px solid #ddd;
  padding: 40px 20px;
  background-color: #fff;
  text-align: center;
  font-size: 16px;
  color: #999;
}
.footer .footer-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
.footer .footer-logo {
  width: 150px;
  height: auto;
}
.footer .footer-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 0;
  color: #666;
  font-weight: 300;
}
.footer .footer-info li {
  position: relative;
  padding-left: 12px;
}
.footer .footer-info li:not(:first-child)::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1px;
  height: 12px;
  background-color: #ccc;
}
.footer .footer-copyright {
  color: #bcbcbc;
  font-size: 1.6rem;
}
@media (max-width: 1024px) {
  .footer .footer-copyright {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .footer .footer-copyright {
    font-size: 1.4rem;
  }
}

/************************************************************************************/
/*************************************** animation ***************************************/
/************************************************************************************/
@-webkit-keyframes scaleAnimation {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2); /* 크게 시작 */
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1); /* 원래 크기로 안정적 수렴 */
  }
}
@keyframes scaleAnimation {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2); /* 크게 시작 */
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1); /* 원래 크기로 안정적 수렴 */
  }
}
/************************************************************************************/
/************************************* Colors *************************************/
/************************************************************************************/
:root {
  --white:#fff;
  --black:#000;
  --red:#be1b23;
  --blue:#194bae;
  --light-blue:#5163c0;
  --deep-blue:#05014a;
  --orange:#ff9644;
  --gray-cd:#cdcdcd;
  --gray-af:#afafaf;
  --gray-e8:#e8e8e8;
  --gray-f8:#f8f8f8;
  --gray-fa:#fafafa;
  --gray-f2:#f2f2f2;
  --gray-f5:#f5f5f5;
  --gray-d2:#d2d2d2;
  --gray-d4:#d4d4d4;
  --gray-d5:#d5d5d5;
  --gray-dd:#dddddd;
  --gray-f0:#f0f0f0;
  --gray-f1:#f1f1f1;
  --gray-f3:#f3f3f3;
  --gray-f7:#f7f7f7;
  --gray-7c:#7c7c7c;
  --gray-95: #959595;
  --gray-55: #555555;
  --gray-27: #272727;
  --gray-33: #333333;
  --gray-88: #888888;
  --main-color:#1f396c;
  --point-color:#4f3126;
  --point01:#010A65;
  --gray-point: #606060;
  --black-point:#352f36;
  --gray-bg: #f8f8f8;
  --gray-bg2: #f3f3f3;
  --gray-dark-bg: #eaeaea;
  --font-basic: #252323;
  --border-color:#d7d7d7;
  --border-color2: #bfbfbf;
  --footer-bg: #252323;
  --footer-txt1: #aaaaaa;
  --instagram: #ff0074;
  --facebook: #0866ff;
  --naver: #03c75a;
  --youtube: #ff0000;
  --kakao: #fee500;
}

/* absolute-center */
/* transition */
/************************************************************************************/
/************************************* Colors *************************************/
/************************************************************************************/
:root {
  --white:#fff;
  --black:#000;
  --red:#be1b23;
  --blue:#194bae;
  --light-blue:#5163c0;
  --deep-blue:#05014a;
  --orange:#ff9644;
  --gray-cd:#cdcdcd;
  --gray-af:#afafaf;
  --gray-e8:#e8e8e8;
  --gray-f8:#f8f8f8;
  --gray-fa:#fafafa;
  --gray-f2:#f2f2f2;
  --gray-f5:#f5f5f5;
  --gray-d2:#d2d2d2;
  --gray-d4:#d4d4d4;
  --gray-d5:#d5d5d5;
  --gray-dd:#dddddd;
  --gray-f0:#f0f0f0;
  --gray-f1:#f1f1f1;
  --gray-f3:#f3f3f3;
  --gray-f7:#f7f7f7;
  --gray-7c:#7c7c7c;
  --gray-95: #959595;
  --gray-55: #555555;
  --gray-27: #272727;
  --gray-33: #333333;
  --gray-88: #888888;
  --main-color:#1f396c;
  --point-color:#4f3126;
  --point01:#010A65;
  --gray-point: #606060;
  --black-point:#352f36;
  --gray-bg: #f8f8f8;
  --gray-bg2: #f3f3f3;
  --gray-dark-bg: #eaeaea;
  --font-basic: #252323;
  --border-color:#d7d7d7;
  --border-color2: #bfbfbf;
  --footer-bg: #252323;
  --footer-txt1: #aaaaaa;
  --instagram: #ff0074;
  --facebook: #0866ff;
  --naver: #03c75a;
  --youtube: #ff0000;
  --kakao: #fee500;
}

/************************************************************************************/
/*************************************** Form ***************************************/
/************************************************************************************/
input[type=text],
input[type=date],
input[type=time],
input[type=number],
input[type=password],
select {
  height: 64px;
  padding: 10px 20px;
  border-color: var(--border-color);
  border-radius: 0;
}
@media (max-width: 1024px) {
  input[type=text],
  input[type=date],
  input[type=time],
  input[type=number],
  input[type=password],
  select {
    height: 52px;
  }
}
@media (max-width: 768px) {
  input[type=text],
  input[type=date],
  input[type=time],
  input[type=number],
  input[type=password],
  select {
    height: 42px;
    padding: 10px 14px;
  }
}

textarea {
  border-radius: 0;
}

/* font-size */
/************************************************************************************/
/*************************************** default_visual ***************************************/
/************************************************************************************/
.hero {
  position: relative;
  width: 100%;
  height: auto;
  color: white;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow-x: hidden;
}
@media screen and (max-width: 1300px) {
  .hero {
    margin-top: 60px;
  }
}

.swiper {
  width: 100%;
  height: 100%;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

.swiper-slide {
  background-size: cover;
  background-position: center;
}
.swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
  -webkit-transition: 2s;
  transition: 2s;
}

.hero-content {
  position: absolute;
  z-index: 10;
  top: 18rem;
}
@media screen and (max-width: 1300px) {
  .hero-content {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

.hero-content h1 {
  font-weight: 700;
  color: white;
  font-size: 6rem;
}
@media (max-width: 1024px) {
  .hero-content h1 {
    font-size: 5.2rem;
  }
}
@media (max-width: 768px) {
  .hero-content h1 {
    font-size: 3.4rem;
  }
}

.hero-content p {
  margin: 1rem 0;
}

.inquiry-btn {
  position: absolute;
  bottom: 5rem;
  right: 18rem;
  background-color: black;
  color: white;
  padding: 1.5rem 9rem 1.5rem 4rem;
  border-radius: 999px;
  text-decoration: none;
  z-index: 9;
  font-size: 1.6rem;
}
@media (max-width: 1024px) {
  .inquiry-btn {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .inquiry-btn {
    font-size: 1.4rem;
  }
}
.inquiry-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 4rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 18px;
  height: 12px;
  background: url(/images/main/bn_icon.png) no-repeat center center;
  background-size: contain;
}
.inquiry-btn:hover {
  background-color: var(--red);
}
@media screen and (max-width: 1300px) {
  .inquiry-btn {
    display: none;
  }
}

/*************************************** con01 ***************************************/
.section-con01 {
  margin-top: 12rem;
  margin-bottom: 14rem;
}
.section-con01 h2 {
  font-weight: 400;
  font-size: 3.2rem;
}
@media (max-width: 1024px) {
  .section-con01 h2 {
    font-size: 2.6rem;
  }
}
@media (max-width: 768px) {
  .section-con01 h2 {
    font-size: 2.2rem;
  }
}
.section-con01 h2 span {
  color: var(--main-color);
  font-weight: 900;
}
.section-con01 p {
  margin-top: 4rem;
  margin-bottom: 5rem;
}
.section-con01 a {
  background-color: black;
  color: white;
  padding: 1.5rem 8rem 1.5rem 4rem;
  border-radius: 999px;
  text-decoration: none;
  position: relative;
  display: inline-block;
  font-size: 1.6rem;
}
@media (max-width: 1024px) {
  .section-con01 a {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .section-con01 a {
    font-size: 1.4rem;
  }
}
.section-con01 a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 4rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url(/images/main/con1_icon.svg) no-repeat center center;
  background-size: 20px 20px;
}
.section-con01 a:hover {
  background-color: var(--blue);
}
@media screen and (max-width: 768px) {
  .section-con01 {
    margin-top: 8rem;
    margin-bottom: 0;
  }
}

.section-patterned-bg {
  position: relative;
  overflow: hidden;
}
.section-patterned-bg::before, .section-patterned-bg::after {
  content: "";
  position: absolute;
  width: 240px;
  height: 240px;
  background: url(/images/main/mainbg01.svg) no-repeat center center;
  background-size: contain;
  z-index: 0;
}
.section-patterned-bg::before {
  top: 100px;
  left: 80px;
}
.section-patterned-bg::after {
  top: 260px;
  right: -120px;
  background: url(/images/main/mainbg02.svg) no-repeat center center;
  width: 450px;
  height: 450px;
  opacity: 0.7;
  z-index: -1;
}
@media screen and (max-width: 1200px) {
  .section-patterned-bg::before, .section-patterned-bg::after {
    display: none;
  }
}

/*************************************** con02 ***************************************/
/* overview */
.overview .flex-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.overview .item {
  width: calc((50% - 90px) / 3);
  background: #f5f5f5;
  margin-right: 30px;
  border-radius: 0;
  overflow: hidden;
  position: relative;
  -webkit-transition: width 0.5s, border-radius 0.5s;
  transition: width 0.5s, border-radius 0.5s;
}
.overview .item figure {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  opacity: 0;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
  margin: 0;
}
.overview .item figure::before {
  content: "";
  width: 100%;
  height: 80%;
  background: -webkit-gradient(linear, left top, left bottom, from(transparent), to(#000));
  background: linear-gradient(to bottom, transparent, #000);
  opacity: 0.9;
  position: absolute;
  bottom: 0;
  left: 0;
}
.overview .item figure img {
  min-width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.overview .item:last-of-type {
  margin-right: 0;
}
.overview .item .text {
  position: relative;
  margin-top: 176px;
}
.overview .item .absolute {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: top 0.5s, -webkit-transform 0.5s;
  transition: top 0.5s, -webkit-transform 0.5s;
  transition: top 0.5s, transform 0.5s;
  transition: top 0.5s, transform 0.5s, -webkit-transform 0.5s;
  will-change: transform, top;
}
.overview .item dl:not(.absolute) {
  opacity: 0;
  pointer-events: none;
}
.overview .item dl dt {
  font-weight: 700;
  color: #333;
  letter-spacing: -0.02em;
  line-height: 1.5;
  -webkit-transition: color 0.5s;
  transition: color 0.5s;
  text-align: center;
  font-size: 2.4rem;
}
@media (max-width: 1024px) {
  .overview .item dl dt {
    font-size: 2rem;
  }
}
@media (max-width: 768px) {
  .overview .item dl dt {
    font-size: 1.8rem;
  }
}
.overview .item dl dd {
  width: calc(200% + 60px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  font-weight: 300;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.75;
  margin-top: 50px;
  opacity: 0;
  -webkit-transition: width 0.5s, opacity 0.5s, color 0.5s;
  transition: width 0.5s, opacity 0.5s, color 0.5s;
  font-size: 1.8rem;
}
@media (max-width: 1024px) {
  .overview .item dl dd {
    font-size: 1.6rem;
  }
}
@media (max-width: 768px) {
  .overview .item dl dd {
    font-size: 1.5rem;
  }
}
.overview .item dl dd p {
  width: calc(100% - 180px);
  font-weight: inherit;
  line-height: inherit;
}
.overview .item dl dd div {
  width: 180px;
  justify-items: end;
  -webkit-justify-items: end;
}
.overview .item .icon {
  margin-bottom: 20px;
  filter: invert(0) brightness(0);
  -webkit-filter: invert(0) brightness(0);
  -webkit-transition: -webkit-filter 0.5s;
  transition: -webkit-filter 0.5s;
  transition: filter 0.5s;
  transition: filter 0.5s, -webkit-filter 0.5s;
  margin: 0 auto 20px;
}
.overview .item .icon01 {
  width: 50px;
  height: 44px;
}
.overview .item .icon02 {
  width: 50px;
  height: 36px;
}
.overview .item .icon03 {
  width: 37px;
  height: 31px;
}
.overview .item .icon04 {
  width: 35px;
  height: 34px;
}
.overview .item.on {
  width: 50%;
  border-radius: 30px;
}
.overview .item.on figure {
  opacity: 1;
}
.overview .item.on .absolute {
  top: 100%;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}
.overview .item.on dl {
  padding: 8rem;
}
.overview .item.on dl dt {
  color: #fff;
  text-align: left;
  font-size: 3.2rem;
}
@media (max-width: 1024px) {
  .overview .item.on dl dt {
    font-size: 2.6rem;
  }
}
@media (max-width: 768px) {
  .overview .item.on dl dt {
    font-size: 2.2rem;
  }
}
.overview .item.on dl dd {
  width: 100%;
  opacity: 1;
}
.overview .item.on .icon {
  filter: invert(1) brightness(2);
  -webkit-filter: invert(1) brightness(2);
  margin: 0 0 20px;
}
@media screen and (max-width: 1280px) {
  .overview .item.on-m {
    width: 50%;
    border-radius: 30px;
  }
  .overview .item.on-m figure {
    opacity: 1;
  }
  .overview .item.on-m .absolute {
    top: 100%;
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  .overview .item.on-m dl {
    padding: 8rem;
  }
  .overview .item.on-m dl dt {
    color: #fff;
    text-align: left;
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 1280px) and (max-width: 1024px) {
  .overview .item.on-m dl dt {
    font-size: 2.6rem;
  }
}
@media screen and (max-width: 1280px) and (max-width: 768px) {
  .overview .item.on-m dl dt {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 1280px) {
  .overview .item.on-m dl dd {
    width: 100%;
    opacity: 1;
    color: #fff;
  }
  .overview .item.on-m .icon {
    filter: invert(1) brightness(2);
    -webkit-filter: invert(1) brightness(2);
    margin: 0 0 20px;
  }
  .overview .item.on-m .absolute {
    position: relative;
    top: 0;
    left: 0;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: top 0.5s, -webkit-transform 0.5s;
    transition: top 0.5s, -webkit-transform 0.5s;
    transition: top 0.5s, transform 0.5s;
    transition: top 0.5s, transform 0.5s, -webkit-transform 0.5s;
    will-change: transform, top;
  }
  .overview .item.on-m dl:not(.absolute) {
    display: none;
  }
}
@media screen and (max-width: 1600px) {
  .overview .item dl {
    padding: 40px;
  }
  .overview .item dl dd {
    margin-top: 30px;
  }
}
@media screen and (max-width: 1400px) {
  .overview .item dl {
    padding: 30px;
  }
  .overview .item dl dd {
    margin-top: 20px;
  }
  .overview .item .icon {
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 1300px) {
  .overview .item {
    width: calc((60% - 40px) / 2);
    margin-right: 20px;
  }
  .overview .item dl dd {
    width: calc(120% + 40px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1300px) and (max-width: 1024px) {
  .overview .item dl dd {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 1300px) and (max-width: 768px) {
  .overview .item dl dd {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 1300px) {
  .overview .item dl dd p {
    width: 100%;
  }
  .overview .item dl dd div {
    width: 100%;
    margin-top: 10px;
  }
  .overview .item.on {
    width: 40%;
  }
}
@media screen and (max-width: 1280px) {
  .overview .item {
    width: 100% !important;
    margin-right: 0;
  }
  .overview .item br {
    display: none;
  }
  .overview .item:not(:last-of-type) {
    margin-bottom: 20px;
  }
  .overview .item .text {
    margin-top: 120px;
  }
  .overview .item .absolute {
    top: 100%;
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  .overview .item .icon {
    -webkit-transition: unset;
    transition: unset;
  }
  .overview .item dl dd {
    width: 100%;
    color: #111;
    opacity: 1;
  }
  .overview .item dl dd div {
    margin-top: 0;
  }
  .overview .item.on .absolute {
    -webkit-transition-delay: unset;
            transition-delay: unset;
  }
  .overview .item.on .icon {
    filter: invert(1) brightness(3);
    -webkit-filter: invert(1) brightness(3);
  }
  .overview .item.on dl dd {
    color: #fff;
  }
}
@media screen and (max-width: 700px) {
  .overview .item .text {
    margin-top: 80px;
  }
}

/*************************************** con03 ***************************************/
.notice-section {
  padding: 14rem 0 12rem;
}
@media screen and (max-width: 1200px) {
  .notice-section {
    padding: 10rem 0 8rem;
  }
}
@media screen and (max-width: 992px) {
  .notice-section {
    padding: 8rem 0 6rem;
  }
}
@media screen and (max-width: 768px) {
  .notice-section {
    padding: 6rem 0 4rem;
  }
}

.notice-title {
  font-weight: 700;
  margin-bottom: 30px;
  position: relative;
  font-size: 3.2rem;
}
@media (max-width: 1024px) {
  .notice-title {
    font-size: 2.6rem;
  }
}
@media (max-width: 768px) {
  .notice-title {
    font-size: 2.2rem;
  }
}
.notice-title .dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  background-color: var(--main-color);
  border-radius: 50%;
  margin-left: 6px;
}

.notice-list {
  border-top: 1px solid #000;
  list-style: none;
  margin: 0;
  padding: 0;
}
.notice-list .notice-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 45px 30px;
  border-bottom: 1px solid #e0e0e0;
}
.notice-list .notice-item .category {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 150px;
          flex: 0 0 150px;
  color: var(--main-color);
}
.notice-list .notice-item .title {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  color: #000;
  text-decoration: none;
  font-weight: 600;
  font-size: 2.4rem;
}
@media (max-width: 1024px) {
  .notice-list .notice-item .title {
    font-size: 2rem;
  }
}
@media (max-width: 768px) {
  .notice-list .notice-item .title {
    font-size: 1.8rem;
  }
}
.notice-list .notice-item .date {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100px;
          flex: 0 0 100px;
  text-align: right;
  color: #333;
}
@media screen and (max-width: 1200px) {
  .notice-list .notice-item {
    padding: 35px 20px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .notice-list .notice-item .category {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 120px;
            flex: 0 0 120px;
  }
}
@media screen and (max-width: 992px) {
  .notice-list .notice-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 25px 15px;
  }
  .notice-list .notice-item .category {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    margin-bottom: 10px;
  }
  .notice-list .notice-item .date {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    text-align: left;
  }
}
@media screen and (max-width: 768px) {
  .notice-list .notice-item {
    padding: 20px 10px;
  }
  .notice-list .notice-item .category {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    margin-bottom: 10px;
  }
}

/*************************************** con04 ***************************************/
.recruit-banner {
  position: relative;
  background: url(/images/main/main_footer_box.jpg) center center/cover no-repeat;
  color: #fff;
  text-align: center;
  padding: 120px 20px;
}
.recruit-banner .content {
  max-width: 900px;
  margin: 0 auto;
}
.recruit-banner p {
  font-weight: 700;
  margin-bottom: 40px;
  font-size: 2.8rem;
}
@media (max-width: 1024px) {
  .recruit-banner p {
    font-size: 2.2rem;
  }
}
@media (max-width: 768px) {
  .recruit-banner p {
    font-size: 2rem;
  }
}
.recruit-banner .buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20px;
}
.recruit-banner .buttons .btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 15px 50px;
  font-weight: 500;
  border: 1px solid #fff;
  background: transparent;
  color: #fff;
  cursor: pointer;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border-radius: 0;
  font-size: 1.6rem;
}
@media (max-width: 1024px) {
  .recruit-banner .buttons .btn {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .recruit-banner .buttons .btn {
    font-size: 1.4rem;
  }
}
.recruit-banner .buttons .btn::after {
  content: "";
  display: inline-block;
  margin-left: 10px;
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.recruit-banner .buttons .btn:hover {
  background-color: #fff;
  color: #000;
}
.recruit-banner .buttons .btn:hover::after {
  border-top-color: #000;
  border-right-color: #000;
}
@media screen and (max-width: 768px) {
  .recruit-banner .buttons {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 5rem;
  }
}
