@charset "UTF-8";
/***************************************
 *
 *base CSS
 *
 *2019/XX
 *
 ****************************************** */
/*****************************
 *
 *settings
 *
 ***************************** */
.trans_txt_parent .inner {
  overflow: hidden; }
.trans_txt_parent s {
  display: inline-block;
  transform: translateY(100px); }

.scroll_fadein {
  transform: translateY(100px);
  opacity: 0; }

/***********************
 *
 *common
 *
 ********************** */
* {
  box-sizing: border-box; }

a {
  text-decoration: none;
  color: inherit; }

i, em {
  font-style: normal; }

body, html {
  margin: 0px;
  padding: 0px;
  font-family: YuGothic, "游ゴシック Medium", 游ゴシック, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, メイリオ, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-feature-settings: "palt";
  -webkit-text-size-adjust: 100%;
  color: #282828;
  font-weight: normal; }

ul {
  margin: 0;
  padding-left: 20px; }
  ul li {
    font-size: 16px;
    line-height: 1.7; }

h2, h3, h4, h5 {
  font-weight: bold; }

.ib {
  width: 1100px;
  margin: 0 auto;
  position: relative;
  max-width: 100%;
  height: 100%; }
  .ib.product {
    width: 1160px; }

table {
  border-collapse: collapse; }

#wpadminbar {
  display: none; }

.pc_content {
  display: block !important; }

.sp_content {
  display: none !important; }

::-webkit-scrollbar {
  width: 10px; }

::-webkit-scrollbar-track {
  background: #fff;
  border: none;
  border-radius: 10px;
  box-shadow: inset 0 0 2px #777; }

::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 10px;
  box-shadow: none; }

.btn_border {
  text-align: center;
  display: block;
  margin: 20px auto;
  position: relative;
  max-width: 300px;
  background: #f1f1f1; }
  .btn_border::before {
    right: 0;
    top: 0; }
  .btn_border::after {
    left: 0;
    bottom: 0; }
  .btn_border::before, .btn_border::after {
    content: "";
    width: 0;
    height: 1px;
    position: absolute;
    transition: all 0.2s linear;
    background: #000;
    transition-delay: 0s; }
  .btn_border:hover::before, .btn_border:hover::after {
    width: 100%;
    transition-delay: 0.2s; }
  .btn_border:hover span::before, .btn_border:hover span::after {
    height: 100%;
    transition-delay: 0s; }
  .btn_border span {
    display: block;
    padding: 15px;
    font-size: 16px;
    color: #000;
    position: relative; }
    .btn_border span::before {
      left: 0;
      top: 0; }
    .btn_border span::after {
      right: 0;
      bottom: 0; }
    .btn_border span::before, .btn_border span::after {
      content: "";
      width: 1px;
      height: 0;
      position: absolute;
      transition: all 0.2s linear;
      background: #000;
      transition-delay: 0.2s; }

/*************************************
 *
 *404
 *
 ************************************* */
p.p404 {
  padding: 40px;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  background: #f1f1f1;
  margin: 40px 0; }

/***************************************
 *
 *header
 *
 ************************************* */
header {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  background: #fff;
  height: 167px; }
  header .ib {
    padding: 20px 50px;
    display: flex;
    align-items: center;
    width: 100%;
    height: 100px; }
    header .ib nav:not(.sub) {
      width: fit-content;
      position: absolute;
      left: 0;
      right: 0;
      margin-right: auto;
      margin-left: auto;
      top: 114px;
      display: flex;
      align-items: center; }
      header .ib nav:not(.sub) a, header .ib nav:not(.sub) span.nav_parent {
        font-size: 16px;
        margin-right: 50px;
        position: relative;
        font-weight: 600;
        cursor: pointer; }
        header .ib nav:not(.sub) a.mg0, header .ib nav:not(.sub) span.nav_parent.mg0 {
          margin-right: 0; }
        header .ib nav:not(.sub) a:hover, header .ib nav:not(.sub) span.nav_parent:hover {
          font-weight: bold; }
          header .ib nav:not(.sub) a:hover:after, header .ib nav:not(.sub) span.nav_parent:hover:after {
            width: 100%; }
        header .ib nav:not(.sub) a:after, header .ib nav:not(.sub) span.nav_parent:after {
          position: absolute;
          width: 0;
          height: 2px;
          background: #E6001B;
          content: "";
          position: absolute;
          bottom: -8px;
          left: 0;
          transition: 0.4s ease; }
        header .ib nav:not(.sub) a:last-child, header .ib nav:not(.sub) span.nav_parent:last-child {
          margin-right: 0; }
        header .ib nav:not(.sub) a .nav_child, header .ib nav:not(.sub) span.nav_parent .nav_child {
          background: #f1f1f1;
          padding: 20px;
          padding-bottom: 13px;
          display: block;
          position: absolute;
          width: max-content;
          top: calc(50% + 20px );
          z-index: 3;
          left: 50%;
          transform: translate(-50%, 0%);
          display: none; }
          header .ib nav:not(.sub) a .nav_child a, header .ib nav:not(.sub) span.nav_parent .nav_child a {
            font-weight: normal;
            display: block;
            margin-bottom: 7px;
            margin-right: 0;
            font-size: 16px;
            transition: 0.4s ease;
            display: flex;
            align-items: center; }
            header .ib nav:not(.sub) a .nav_child a:before, header .ib nav:not(.sub) span.nav_parent .nav_child a:before {
              content: "";
              width: 4px;
              height: 4px;
              position: relative;
              top: 2px;
              border-radius: 50%;
              margin-right: 6px;
              background: #E6001B; }
            header .ib nav:not(.sub) a .nav_child a:hover, header .ib nav:not(.sub) span.nav_parent .nav_child a:hover {
              color: #E6001B; }
            header .ib nav:not(.sub) a .nav_child a:after, header .ib nav:not(.sub) span.nav_parent .nav_child a:after {
              display: none; }
      header .ib nav:not(.sub) .nav_parent:before {
        content: "";
        color: #8f8f8f;
        position: absolute;
        right: -16px;
        top: 7px;
        font-size: 12px;
        transform: rotate(-90deg);
        font-family: "material icons"; }
    header .ib .sub_menu {
      top: 26px;
      right: 50px;
      align-items: center;
      display: flex;
      position: absolute;
      z-index: 2; }
      header .ib .sub_menu nav.sub {
        align-items: center;
        display: flex;
        margin-right: 12px; }
        header .ib .sub_menu nav.sub a {
          font-size: 16px;
          color: #888585;
          margin-right: 22px;
          transition: 0.4s ease;
          font-weight: 500; }
          header .ib .sub_menu nav.sub a:hover {
            color: #E6001B; }
      header .ib .sub_menu a.contact {
        width: 134px;
        height: 30px;
        padding-top: 2px;
        font-size: 15px;
        font-weight: bold;
        color: #fff;
        background: #E6001B;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: 0.4s ease; }
        header .ib .sub_menu a.contact:hover {
          background: #E6001B; }
        header .ib .sub_menu a.contact img {
          margin-right: 5px; }
    header .ib .logos {
      align-items: center;
      display: flex; }
      header .ib .logos .th {
        margin-right: 25px;
        padding-right: 25px;
        border-right: 1px solid #282828; }
        header .ib .logos .th img {
          width: 215px; }
      header .ib .logos .hi {
        width: 68px; }

.dnone {
  display: none !important; }

.fv_slide_btn {
  width: 92px;
  bottom: 66px;
  margin-top: 24px;
  display: flex;
  justify-content: space-between;
  height: 5px;
  position: relative;
  z-index: 9;
  bottom: 0;
  left: 0;
  justify-content: center;
  z-index: 9; }
  .fv_slide_btn span {
    width: 22px;
    height: 100%;
    opacity: 1;
    border-radius: 0;
    background: #c3c3c3; }
    .fv_slide_btn span.swiper-pagination-bullet-active {
      background: #E6001B; }

#fv_new {
  height: 550px;
  width: 100%;
  position: relative; }
  #fv_new .fv_slide2 {
    height: 100%; }
    #fv_new .fv_slide2 .swiper-slide {
      width: 1100px;
      height: 100%; }
      #fv_new .fv_slide2 .swiper-slide .box {
        position: absolute;
        width: 528px;
        height: 257px;
        background: #fff;
        bottom: 65px;
        z-index: 2;
        padding: 30px 40px;
        padding-right: 30px; }
        #fv_new .fv_slide2 .swiper-slide .box:after {
          content: "";
          display: block;
          z-index: 2;
          width: 8px;
          height: 190px;
          position: absolute;
          background: #E6001B;
          left: 0;
          top: calc(50%  - 95px); }
        #fv_new .fv_slide2 .swiper-slide .box h2 {
          font-size: 35px;
          font-weight: bold;
          margin: 0;
          line-height: 1.2; }
        #fv_new .fv_slide2 .swiper-slide .box a.btn_black {
          height: 50px;
          margin-top: 30px; }
      #fv_new .fv_slide2 .swiper-slide.top {
        padding: 63px 56px;
        position: relative; }
        #fv_new .fv_slide2 .swiper-slide.top .effect {
          position: absolute;
          z-index: 2;
          bottom: 0px;
          left: 0px;
          width: auto;
          opacity: 0.5; }
        #fv_new .fv_slide2 .swiper-slide.top .inner {
          position: relative;
          z-index: 3; }
          #fv_new .fv_slide2 .swiper-slide.top .inner .biz_row .row {
            position: relative;
            height: 45px;
            display: flex;
            align-items: center;
            padding: 8px 25px;
            margin-bottom: 20px;
            width: max-content; }
            #fv_new .fv_slide2 .swiper-slide.top .inner .biz_row .row:nth-of-type(2) {
              margin-bottom: 0; }
            #fv_new .fv_slide2 .swiper-slide.top .inner .biz_row .row:hover:after {
              width: 100%; }
            #fv_new .fv_slide2 .swiper-slide.top .inner .biz_row .row span {
              font-size: 24px;
              font-weight: bold;
              color: #fff;
              position: relative;
              z-index: 2;
              position: relative;
              top: 1px; }
            #fv_new .fv_slide2 .swiper-slide.top .inner .biz_row .row:after {
              content: "";
              width: 8px;
              height: 100%;
              position: absolute;
              transition: 0.4s ease;
              background: #E6001B;
              display: block;
              left: 0;
              top: 0; }
          #fv_new .fv_slide2 .swiper-slide.top .inner p {
            margin: 40px 0;
            color: #fff;
            text-transform: uppercase;
            font-size: 21px;
            color: #E6001B;
            font-weight: 600;
            letter-spacing: 0.08rem;
            line-height: 1.2;
            font-family: "din-2014", sans-serif; }
          #fv_new .fv_slide2 .swiper-slide.top .inner h2 {
            margin: 0; }
            #fv_new .fv_slide2 .swiper-slide.top .inner h2 span {
              display: block;
              padding: 10px 25px;
              height: 68px;
              display: flex;
              align-items: center;
              color: #fff;
              font-weight: bold;
              font-size: 47px;
              margin-bottom: 20px;
              position: relative;
              width: max-content;
              overflow: hidden; }
              #fv_new .fv_slide2 .swiper-slide.top .inner h2 span:after {
                content: "";
                position: absolute;
                width: 100%;
                height: 100%;
                z-index: 1;
                background: rgba(255, 255, 255, 0.4);
                backdrop-filter: blur(10px);
                top: 0;
                left: 0; }
              #fv_new .fv_slide2 .swiper-slide.top .inner h2 span em {
                position: relative;
                z-index: 2;
                padding-top: 2px; }
      #fv_new .fv_slide2 .swiper-slide img:not(.effect) {
        object-fit: cover;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1; }

#fv {
  position: relative;
  width: 100%;
  height: 730px;
  background: #ccc;
  overflow: hidden;
  background: url(../img/slide/fv_bg1.jpg);
  background-size: cover; }
  #fv .fv_shape {
    width: 1350px;
    height: auto;
    z-index: 2;
    top: 80px;
    position: absolute;
    left: calc(50% - 675px);
    mix-blend-mode: overlay; }
  #fv .hide_plate {
    position: absolute;
    height: 90px;
    z-index: 3;
    background: #fff;
    width: 880px;
    top: 0;
    left: calc(50% - 440px); }
    #fv .hide_plate:before, #fv .hide_plate:after {
      content: "";
      width: calc(50vw - 440px);
      height: 90px;
      display: block;
      left: calc(0px - calc(50vw - 50% - 1px));
      top: 0;
      position: absolute;
      background: #fff;
      clip-path: polygon(0 0, 100% 0, 100% 100%);
      z-index: 2; }
    #fv .hide_plate:after {
      right: calc(0px - calc(50vw - 50% - 1px));
      left: auto;
      transform: scale(-1, 1); }
    #fv .hide_plate:nth-of-type(2) {
      top: auto;
      bottom: 0; }
      #fv .hide_plate:nth-of-type(2):before {
        transform: scale(1, -1); }
      #fv .hide_plate:nth-of-type(2):after {
        transform: scale(-1, -1); }
  #fv .ib {
    z-index: 2;
    width: 880px;
    padding: 100px 0; }
    #fv .ib:before, #fv .ib:after {
      position: absolute;
      width: 10px;
      height: 730px;
      display: block;
      content: "";
      top: 0;
      left: 0;
      content: "";
      background: #fff; }
    #fv .ib:after {
      left: auto;
      right: 0; }
    #fv .ib h2 {
      margin: 0;
      margin-top: 100px;
      padding-left: 30px;
      margin-left: -100px;
      font-size: 107px;
      font-family: "din-2014", sans-serif;
      color: #E6001B;
      line-height: 1.27;
      letter-spacing: 0.25rem; }
      #fv .ib h2 .inner .row {
        position: relative;
        line-height: 1;
        margin-bottom: 30px;
        width: max-content;
        opacity: 0;
        align-items: center;
        display: flex; }
        #fv .ib h2 .inner .row:nth-of-type(1):after {
          display: none; }
        #fv .ib h2 .inner .row:nth-of-type(2):after {
          left: 190px;
          bottom: 6px;
          top: auto; }
        #fv .ib h2 .inner .row:nth-of-type(3):after {
          left: auto;
          right: 150px; }
        #fv .ib h2 .inner .row:before, #fv .ib h2 .inner .row:after {
          content: "";
          display: block;
          height: 10px;
          width: 10px;
          background: #E6001B;
          position: absolute;
          top: 11px;
          left: -4px; }
        #fv .ib h2 .inner .row span {
          font-size: 18px;
          position: relative;
          color: #fff;
          font-weight: bold;
          width: 230px;
          padding-bottom: 5px;
          margin-left: 30px;
          line-height: 1.3; }
          #fv .ib h2 .inner .row span:after {
            width: 30px;
            height: 30px;
            content: "";
            background: #fff;
            opacity: 0.2;
            position: absolute;
            right: -15px;
            top: 60px;
            border-radius: 50%;
            transition: 0.6s ease;
            transform-origin: center;
            display: block; }
          #fv .ib h2 .inner .row span.active:after {
            opacity: 0.4;
            transform: scale(2.6667); }
          #fv .ib h2 .inner .row span.active:before {
            width: 100%; }
          #fv .ib h2 .inner .row span:before {
            content: "";
            height: 1px;
            width: 0;
            background: #fff;
            transition: 0.6s ease;
            display: block;
            position: absolute;
            bottom: 0;
            left: 0; }
          #fv .ib h2 .inner .row span em {
            display: flex;
            align-items: center;
            position: relative;
            width: 100%;
            justify-content: space-between; }
            #fv .ib h2 .inner .row span em:before {
              content: "";
              width: 30px;
              height: 30px;
              background: #fff;
              opacity: 0.4;
              border-radius: 50%;
              position: absolute;
              right: -15px;
              top: calc(50% - -24px); }
            #fv .ib h2 .inner .row span em:after {
              content: "";
              position: absolute;
              z-index: 2;
              width: 11px;
              height: 11px;
              background: #E6001B;
              border-radius: 50%;
              right: -6px;
              bottom: -10px; }
  #fv .screens {
    align-items: center;
    display: flex;
    height: 100%;
    width: 100vw;
    position: absolute;
    top: 0;
    opacity: 0; }
    #fv .screens .fv_slide_btn {
      width: 92px;
      position: absolute;
      bottom: 66px;
      right: 0;
      display: flex;
      justify-content: space-between;
      height: 5px;
      z-index: 3;
      left: calc(50% + 337px); }
      #fv .screens .fv_slide_btn span {
        width: 22px;
        height: 100%;
        opacity: 1;
        border-radius: 0;
        background: #c3c3c3; }
        #fv .screens .fv_slide_btn span.swiper-pagination-bullet-active {
          background: #E6001B; }
    #fv .screens .swiper {
      height: 105%; }
      #fv .screens .swiper .swiper-slide img {
        object-fit: cover;
        width: 100%;
        height: 100%; }
    #fv .screens .vision {
      background: #ccc; }
      #fv .screens .vision.l, #fv .screens .vision.r {
        height: 100%;
        width: calc(50vw - 445px);
        position: relative;
        clip-path: polygon(0 90px, 100% 0, 100% 100%, 0 calc(100% - 90px));
        background: url(../img/slide/sl_r.jpg) 70% 50%;
        background-size: cover; }
      #fv .screens .vision.l {
        clip-path: polygon(0 0, 100% 90px, 100% calc(100% - 90px), 0 100%);
        background: url(../img/slide/sl_l.jpg) 50% 50%;
        background-size: cover; }
      #fv .screens .vision.center {
        width: 880px;
        height: 550px;
        background: url(../img/slide/fv_bg1.jpg);
        background-size: cover; }

a.btn {
  display: flex;
  position: relative;
  width: max-content;
  font-size: 16px; }
  a.btn.center {
    margin: 20px auto !important;
    width: max-content !important; }
  a.btn span {
    display: block;
    position: relative;
    width: 100%;
    display: flex;
    align-items: center; }
    a.btn span:before, a.btn span:after {
      content: "";
      width: 5px;
      height: 5px;
      background: #E6001B;
      border-radius: 50%;
      margin-right: 7px;
      position: relative;
      transition: 0.4s ease; }
    a.btn span:before {
      z-index: 2; }
    a.btn span:after {
      position: absolute;
      left: 0px;
      top: calc(50% - 2.5px);
      opacity: 0.33; }
  a.btn:hover:before {
    width: 100%; }
  a.btn:hover span:after {
    transform: scale(5); }
  a.btn:before {
    content: "";
    position: absolute;
    bottom: -6px;
    left: 0;
    height: 1px;
    background: #C3C3C3;
    width: 0;
    transition: 0.4s ease; }

a.btn_black, input[type="submit"] {
  width: 250px;
  padding: 8px;
  height: 60px;
  display: flex;
  background: #282828;
  color: #fff;
  transition: 0.4s ease;
  font-size: 18px;
  font-weight: bold;
  align-items: center;
  justify-content: center;
  position: relative;
  text-decoration: none !important; }
  a.btn_black:after, input[type="submit"]:after {
    content: "";
    font-family: "material icons";
    position: absolute;
    right: 14px;
    font-weight: normal;
    position: absolute;
    top: calc(50% - 9px);
    font-size: 20px;
    transition: 0.4s ease;
    line-height: 1; }
  a.btn_black:hover:after, input[type="submit"]:hover:after {
    right: 5px; }
  a.btn_black.conv, input[type="submit"].conv {
    background: #E6001B; }
  a.btn_black.w, input[type="submit"].w {
    width: max-content;
    padding: 8px 30px;
    max-width: 100%; }
  a.btn_black.center, input[type="submit"].center {
    margin: 50px auto; }
  a.btn_black.external, input[type="submit"].external {
    padding-right: 50px; }
    a.btn_black.external:after, input[type="submit"].external:after {
      content: "";
      top: calc(50% - 18px); }
  a.btn_black.red, input[type="submit"].red {
    background: #E6001B !important; }
  a.btn_black img, input[type="submit"] img {
    margin-right: 10px; }
  a.btn_black:hover, input[type="submit"]:hover {
    background: #E6001B; }
  a.btn_black input[type="submit"], input[type="submit"] input[type="submit"] {
    background: #E6001B;
    border: none; }

.yarpp {
  display: none !important; }

#content {
  overflow: hidden; }
  #content .ib {
    padding: 100px 0; }
  #content .target_top .ib {
    width: 1060px;
    padding: 50px 0; }
    #content .target_top .ib h2:after {
      display: none; }
    #content .target_top .ib .target_list {
      width: 100%;
      flex-wrap: wrap;
      display: flex;
      justify-content: space-between; }
      #content .target_top .ib .target_list .box {
        width: 330px;
        height: 292px;
        position: relative;
        padding: 20px;
        display: flex;
        align-items: center;
        background: #282828; }
        #content .target_top .ib .target_list .box:hover img {
          opacity: 1; }
        #content .target_top .ib .target_list .box .txt {
          width: 100%;
          padding-top: 15px;
          position: relative;
          z-index: 3; }
          #content .target_top .ib .target_list .box .txt p {
            font-size: 18px;
            color: #fff;
            font-weight: bold;
            width: 100%;
            text-align: center; }
            #content .target_top .ib .target_list .box .txt p span {
              display: block;
              width: 100%;
              text-align: center;
              padding-bottom: 13px;
              margin-bottom: 13px;
              position: relative;
              line-height: 1.5; }
              #content .target_top .ib .target_list .box .txt p span:last-child:before {
                display: none; }
              #content .target_top .ib .target_list .box .txt p span:before {
                bottom: 0px;
                width: 28px;
                height: 2px;
                background: #E6001B;
                content: "";
                display: block;
                left: calc(50% - 14px);
                position: absolute; }
        #content .target_top .ib .target_list .box img {
          position: absolute;
          opacity: 0;
          transition: 0.4s ease;
          width: 100%;
          height: 100%;
          bottom: 0;
          left: 0;
          z-index: 1; }
  #content h2 {
    color: #E6001B;
    font-size: 50px;
    font-weight: bold;
    letter-spacing: 0.1rem;
    text-align: center;
    font-family: "din-2014", "Zen Kaku Gothic New", sans-serif;
    margin: 40px 0;
    position: relative; }
    #content h2.s {
      font-size: 32px;
      text-align: center; }
      #content h2.s:before, #content h2.s:after {
        display: none !important; }
    #content h2.mgt {
      margin-top: 0 !important; }
    #content h2.mg {
      margin: 60px 0; }
    #content h2.bdb {
      font-size: 36px;
      display: table;
      margin: 40px auto;
      position: relative;
      color: #282828;
      padding-bottom: 60px; }
      #content h2.bdb:after {
        bottom: 0px;
        width: 68px;
        content: "";
        height: 1px;
        display: block;
        right: auto;
        background: #E6001B;
        position: absolute;
        left: calc(50% - 34px); }
    #content h2.dot {
      font-size: 36px;
      display: table;
      margin: 40px auto;
      position: relative;
      color: #282828; }
      #content h2.dot.mg {
        margin: 60px auto; }
      #content h2.dot:after, #content h2.dot:before {
        content: "";
        width: 10px;
        height: 10px;
        background: #E6001B;
        position: absolute;
        right: auto;
        left: -30px;
        top: calc(50% - 5px);
        bottom: auto; }
      #content h2.dot:after {
        left: auto;
        right: -30px; }
    #content h2:after {
      content: "";
      width: 0.5px;
      background: #212121;
      left: 0;
      right: 0;
      margin: auto;
      width: fit-content;
      bottom: -60px;
      height: 50px;
      position: absolute;
      width: 0.5px; }
    #content h2 + h3 {
      margin-top: 86px; }
  #content h3 {
    font-size: 22px;
    font-weight: bold;
    position: relative;
    margin: 40px 0; }
    #content h3.bdb {
      font-size: 24px;
      margin: 40px 0;
      padding-bottom: 20px;
      border-bottom: 1px solid #C3C3C3;
      position: relative; }
      #content h3.bdb:after {
        display: none; }
      #content h3.bdb:before {
        content: "";
        position: absolute;
        bottom: -1px;
        width: 74px;
        background: #E6001B;
        display: block;
        left: 0;
        height: 1px; }
    #content h3.center {
      text-align: center; }
      #content h3.center:after {
        right: 0;
        margin: auto;
        width: fit-content; }
    #content h3:after {
      content: url(../img/h3_after.svg);
      position: absolute;
      bottom: -25px;
      left: 0; }
  #content h4 {
    font-size: 20px;
    font-weight: bold;
    margin: 30px 0; }
    #content h4.bd {
      line-height: 1;
      margin: 20px 0;
      border-left: 4px solid #E6001B;
      padding-left: 16px; }
  #content p {
    font-size: 16px;
    line-height: 1.9;
    margin: 20px 0; }
    #content p.tar {
      text-align: right; }
    #content p.center, #content p.tac {
      text-align: center; }
    #content p.s {
      font-size: 14px; }
    #content p.emp {
      font-size: 18px; }
  #content .bullet_a {
    margin: 20px 0; }
    #content .bullet_a a {
      display: block;
      padding: 20px 0;
      border-bottom: 1px solid #C3C3C3;
      position: relative;
      display: flex;
      font-size: 18px;
      align-items: center;
      width: 100%;
      line-height: 1.3; }
      #content .bullet_a a:hover:after {
        height: 100%; }
      #content .bullet_a a:hover span:after {
        right: 10px; }
      #content .bullet_a a:before {
        content: "";
        width: 5px;
        height: 5px;
        background: #E6001B;
        margin-right: 10px; }
      #content .bullet_a a span {
        display: flex;
        width: 100%;
        position: relative;
        align-items: center;
        z-index: 2;
        font-weight: bold; }
        #content .bullet_a a span:after {
          width: 20px;
          height: 20px;
          content: "";
          font-family: "material icons";
          color: #fff;
          font-size: 13px;
          background: #E6001B;
          position: absolute;
          right: 26px;
          transition: 0.4s ease;
          top: calc(50% - 10px);
          display: flex;
          align-items: center;
          justify-content: center; }
      #content .bullet_a a:after {
        content: "";
        position: absolute;
        width: 100%;
        bottom: 0;
        left: 0;
        height: 0;
        background: #C3C3C3;
        transition: 0.4s ease; }
  #content .whats_new {
    position: relative; }
    #content .whats_new .ib h2 {
      margin-top: 20px; }
    #content .whats_new .ib .sq {
      position: absolute; }
      #content .whats_new .ib .sq.sq1 {
        top: 10px;
        left: 30px; }
      #content .whats_new .ib .sq.sq2 {
        top: 200px;
        right: 100px; }
      #content .whats_new .ib .sq.sq3 {
        top: 280px;
        left: -150px; }
      #content .whats_new .ib .sq.sq4 {
        top: 660px;
        right: 0; }
  #content .news_content {
    width: 794px;
    max-width: 100%;
    margin: 48px auto; }
    #content .news_content .tabs {
      align-items: center;
      display: flex;
      padding: 12px 0; }
      #content .news_content .tabs span {
        margin-right: 16px;
        font-size: 16px;
        display: flex;
        align-items: center;
        cursor: pointer; }
        #content .news_content .tabs span:before {
          content: "";
          width: 5px;
          height: 5px;
          background: #fff;
          margin-right: 7px; }
        #content .news_content .tabs span:hover:before, #content .news_content .tabs span.active:before {
          background: #E6001B; }
  #content .cat_list_tab {
    justify-content: center;
    display: flex;
    margin: 60px 0; }
    #content .cat_list_tab a {
      padding: 0 15px;
      text-decoration: underline;
      color: #E6001B;
      font-size: 16px; }
  #content .pagination {
    margin: 80px 0; }
    #content .pagination ul {
      display: flex;
      justify-content: center; }
      #content .pagination ul li {
        list-style: none; }
        #content .pagination ul li a, #content .pagination ul li span {
          font-size: 16px;
          background: #3f3f3f;
          font-family: "din-2014", sans-serif;
          display: flex;
          align-items: center;
          justify-content: center;
          width: 36px;
          height: 36px;
          border-radius: 50%;
          margin: 0 5px;
          line-height: 0.8;
          padding: 10px 10px 10px;
          color: #fff;
          transition: 0.4s ease; }
          #content .pagination ul li a:hover, #content .pagination ul li span:hover {
            background: #E6001B; }
          #content .pagination ul li a.current, #content .pagination ul li span.current {
            font-weight: 500;
            background: #E6001B;
            color: #fff; }
  #content .news_list.sub {
    margin: 60px 0; }
  #content .news_list .box {
    display: none; }
    #content .news_list .box.active {
      display: block; }
    #content .news_list .box .row {
      border-bottom: 1px solid #C3C3C3;
      padding: 20px 0;
      align-items: center;
      display: flex;
      position: relative; }
      #content .news_list .box .row:nth-of-type(1) {
        border-top: 1px solid #C3C3C3; }
      #content .news_list .box .row:hover p {
        font-weight: bold; }
      #content .news_list .box .row:hover em {
        background: #E6001B;
        right: 0; }
      #content .news_list .box .row em {
        position: absolute;
        height: 20px;
        width: 20px;
        background: #C3C3C3;
        transition: 0.4s ease;
        top: calc(50% - 10px);
        right: 16px;
        display: flex;
        align-items: center;
        justify-content: center; }
        #content .news_list .box .row em:before {
          content: "";
          font-family: "material icons";
          color: #fff;
          font-size: 16px; }
      #content .news_list .box .row .date {
        font-size: 16px;
        margin-right: 10px; }
      #content .news_list .box .row .cat {
        font-size: 15px;
        color: #8e8e8e;
        border: 1px solid #8e8e8e;
        border-radius: 20px;
        padding: 4px 14px 2px;
        margin-right: 25px;
        transition: 0.4s ease;
        min-width: 127px;
        line-height: 1.3;
        text-align: center; }
        #content .news_list .box .row .cat:hover {
          color: #E6001B;
          border-color: #E6001B; }
      #content .news_list .box .row p {
        margin: 0;
        font-size: 16px;
        padding-right: 25px;
        line-height: 1.5;
        transition: 0.4s ease; }
  #content .aboutus .ib .sq {
    position: absolute; }
    #content .aboutus .ib .sq.sq1 {
      top: -30px;
      left: 40px; }
    #content .aboutus .ib .sq.sq2 {
      left: -160px;
      top: 700px; }
    #content .aboutus .ib .sq.sq3 {
      z-index: 3;
      right: 60px;
      top: 851px; }
  #content .aboutus .ib .au_block {
    position: relative;
    width: 100vw;
    margin-left: calc(0px - calc(50vw - 50%));
    height: 490px; }
    #content .aboutus .ib .au_block.a1 {
      margin-bottom: 200px; }
    #content .aboutus .ib .au_block .imgs {
      position: relative;
      width: 100%;
      display: flex;
      height: 100%; }
      #content .aboutus .ib .au_block .imgs.i2 {
        justify-content: end;
        flex-direction: row-reverse; }
        #content .aboutus .ib .au_block .imgs.i2 .img.i1 {
          width: calc(50vw + 86px);
          clip-path: polygon(100px 0, 100% 0, 100% 100%, 0% 100%); }
        #content .aboutus .ib .au_block .imgs.i2 .txt {
          width: 427px;
          padding: 0;
          background: #fff;
          top: 0;
          margin-right: 30px; }
          #content .aboutus .ib .au_block .imgs.i2 .txt p {
            margin-top: 30px; }
      #content .aboutus .ib .au_block .imgs .img {
        height: 100%;
        display: block;
        position: relative; }
        #content .aboutus .ib .au_block .imgs .img.cover:before {
          content: "";
          height: 100%;
          width: 100%;
          background: linear-gradient(90deg, #282828, rgba(0, 0, 0, 0));
          mix-blend-mode: multiply;
          opacity: 0.5;
          top: auto;
          left: 0;
          position: absolute; }
        #content .aboutus .ib .au_block .imgs .img img {
          object-fit: cover;
          width: 100%;
          height: 100%; }
        #content .aboutus .ib .au_block .imgs .img.i1 {
          width: calc(50vw - 260px);
          background: #ddd;
          clip-path: polygon(0 0, 100% 0, calc(100% - 100px) 100%, 0% 100%); }
        #content .aboutus .ib .au_block .imgs .img.i2 {
          width: 480px;
          clip-path: polygon(100px 0, 100% 0, 100% 100%, 0% 100%);
          background: #ddd;
          position: relative;
          top: 86px;
          margin-left: -111px; }
      #content .aboutus .ib .au_block .imgs .txt {
        width: 500px;
        height: 100%;
        padding: 56px;
        background: #f4f4f4;
        position: relative;
        top: 86px; }
        #content .aboutus .ib .au_block .imgs .txt h3 {
          margin-top: 0; }
        #content .aboutus .ib .au_block .imgs .txt p {
          margin-top: 60px; }
        #content .aboutus .ib .au_block .imgs .txt a.btn {
          margin: 40px 0; }
  #content .animated-circle {
    transition: stroke-dashoffset 0.6s ease; }
  #content .animated-circle:hover {
    stroke-dashoffset: 0; }
  #content .tac {
    text-align: center !important; }
  #content .top_target {
    background: url(../img/top_target.jpg);
    background-size: cover;
    width: 100%;
    height: 470px;
    margin: 40px 0px 100px; }
    #content .top_target .ib {
      padding: 110px 0;
      height: 100%;
      display: flex;
      justify-content: space-between;
      width: 880px;
      max-width: 100%; }
      #content .top_target .ib svg {
        position: absolute;
        top: -34px;
        left: -35px;
        z-index: 3; }
      #content .top_target .ib a {
        width: 250px;
        height: 100%;
        border-radius: 50%;
        border: 1px;
        position: relative;
        padding: 20px;
        font-size: 18px;
        color: #fff;
        text-align: center;
        font-weight: bold;
        border: 1px solid #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: 0.4s ease; }
        #content .top_target .ib a:hover {
          background: #fff;
          color: #212121; }
          #content .top_target .ib a:hover:before {
            backdrop-filter: blur(0px); }
        #content .top_target .ib a span {
          position: relative;
          z-index: 2; }
        #content .top_target .ib a:after {
          content: url(../img/h3_after.svg);
          position: absolute;
          bottom: 40px;
          left: calc(50% - 13px); }
        #content .top_target .ib a:before {
          content: "";
          backdrop-filter: blur(12px);
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          display: block;
          background: rgba(255, 255, 255, 0.1);
          border-radius: 50%; }
  #content .our_products .ib {
    padding-bottom: 50px; }
    #content .our_products .ib .op1 {
      position: absolute;
      top: 120px;
      left: -100px; }
    #content .our_products .ib .t_list {
      display: flex;
      justify-content: space-between;
      margin-top: 44px; }
      #content .our_products .ib .t_list a {
        width: 320px;
        height: 250px;
        position: relative;
        align-items: center;
        justify-content: center;
        display: flex;
        overflow: hidden; }
        #content .our_products .ib .t_list a:hover img.slide {
          left: 0; }
        #content .our_products .ib .t_list a img {
          object-fit: cover;
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0; }
          #content .our_products .ib .t_list a img.slide {
            z-index: 3;
            left: -100%;
            transition: 0.4s ease; }
        #content .our_products .ib .t_list a p {
          position: relative;
          z-index: 4;
          font-size: 18px;
          margin: 0;
          color: #fff;
          font-weight: bold; }
  #content .our_products .product_inner {
    background: #f4f4f4;
    padding: 64px 44px 44px;
    margin: 100px 0 0; }
    #content .our_products .product_inner h3 {
      margin-top: 0;
      margin-bottom: 60px; }
    #content .our_products .product_inner .row {
      display: flex;
      justify-content: space-between; }
      #content .our_products .product_inner .row form {
        width: 710px;
        height: 60px;
        position: relative; }
        #content .our_products .product_inner .row form:before {
          content: url(../img/glass_r.svg);
          position: absolute;
          left: 20px;
          top: 20px;
          transform: scale(1.3);
          z-index: 4;
          display: block; }
        #content .our_products .product_inner .row form button {
          position: absolute;
          width: 72px;
          height: 40px;
          justify-content: center;
          align-items: center;
          font-size: 14px;
          color: #fff;
          font-weight: bold;
          display: flex;
          cursor: pointer;
          right: 12px;
          top: calc(50% - 20px);
          background: #E6001B;
          z-index: 2;
          border: none; }
        #content .our_products .product_inner .row form input {
          width: 100%;
          background: #fff;
          height: 100%;
          padding: 16px;
          position: relative;
          display: block;
          border: none;
          padding-left: 55px;
          border: 1px solid #333; }
          #content .our_products .product_inner .row form input::placeholder {
            font-size: 16px;
            color: #888; }
  #content .product_scroll {
    height: 240px;
    margin-bottom: -40px;
    background: url(../img/p_scroll.jpg) 50% 50% repeat-x;
    background-size: auto 120px;
    animation: p_scroll 33s linear forwards infinite; }
    #content .product_scroll.rec {
      background: url(../img/rec_scroll.jpg) 50% 50% repeat-x;
      background-size: auto 180px;
      animation: rec_scroll 33s linear forwards infinite;
      margin-top: -30px;
      margin-bottom: 50px; }
@keyframes p_scroll {
  0% {
    background-position: 0 50%; }
  100% {
    background-position: -2497px 50%; } }
@keyframes rec_scroll {
  0% {
    background-position: 0 50%; }
  100% {
    background-position: -1800px 50%; } }
  #content a.ar {
    align-items: center;
    display: flex;
    font-size: 16px; }
    #content a.ar:after {
      content: url(../img/ar1.svg);
      display: block;
      position: relative;
      margin-left: 4px;
      top: -3px; }
  #content .column_list {
    justify-content: space-between;
    display: flex;
    margin: 60px 0; }
    #content .column_list.small {
      justify-content: flex-start; }
      #content .column_list.small .box {
        width: 32%;
        margin-right: 2%; }
        #content .column_list.small .box .img img {
          margin: 0; }
        #content .column_list.small .box:nth-of-type(3n) {
          margin-right: 0; }
    #content .column_list.sub {
      flex-wrap: wrap; }
      #content .column_list.sub .box {
        background: #f1f1f1;
        margin-bottom: 40px; }
        #content .column_list.sub .box .txt {
          min-height: 203px;
          background: #f1f1f1 !important; }
        #content .column_list.sub .box h3 {
          border: none; }
    #content .column_list.ex .box .img {
      aspect-ratio: 1/0.75; }
    #content .column_list.ex .box .txt {
      background: #fff; }
      #content .column_list.ex .box .txt .cat a {
        background: #282828;
        border-radius: 0; }
    #content .column_list .box {
      width: 350px;
      background: #fff;
      position: relative; }
      #content .column_list .box:after, #content .column_list .box:before {
        transition: 0.4s ease;
        content: "";
        height: 1px;
        width: 100%;
        background: #aaa;
        position: absolute;
        bottom: 0;
        left: 0; }
      #content .column_list .box:after {
        z-index: 2;
        width: 100px;
        background: #E6001B; }
      #content .column_list .box:hover:after {
        width: 100%;
        height: 2px; }
      #content .column_list .box:hover .img img {
        transform: scale(1.05); }
      #content .column_list .box .img {
        overflow: hidden;
        width: 100%;
        height: auto;
        aspect-ratio: 1/1; }
        #content .column_list .box .img img {
          object-fit: cover;
          width: 100%;
          height: 100%;
          transition: 0.4s ease; }
      #content .column_list .box .txt {
        background: #f1f1f1;
        padding: 22px;
        margin-top: -6px;
        position: relative;
        overflow: hidden;
        min-height: 188px; }
        #content .column_list .box .txt a.ar {
          float: right; }
        #content .column_list .box .txt .cat {
          display: flex;
          align-items: center; }
          #content .column_list .box .txt .cat a {
            transition: 0.4s ease;
            padding: 3px 18px;
            font-size: 12px;
            background: #999;
            color: #fff;
            border-radius: 20px;
            margin-right: 10px; }
            #content .column_list .box .txt .cat a:hover {
              background: #E6001B; }
        #content .column_list .box .txt .date {
          font-size: 16px;
          font-weight: bold;
          margin: 15px 0 12px;
          font-family: "din-2014", sans-serif;
          display: flex; }
          #content .column_list .box .txt .date span {
            margin-right: 16px;
            display: flex;
            align-items: center; }
            #content .column_list .box .txt .date span:before {
              content: "";
              font-family: "material icons";
              margin-right: 4px;
              font-weight: normal; }
            #content .column_list .box .txt .date span.update:before {
              font-size: 120%;
              content: ""; }
        #content .column_list .box .txt h3 {
          font-size: 16px;
          margin: 12px 0;
          font-weight: normal; }
          #content .column_list .box .txt h3:after {
            display: none; }
  #content .examples {
    background: #f1f1f1; }
    #content .examples .ib {
      padding-bottom: 120px; }
    #content .examples .ia1 {
      position: absolute;
      top: 0;
      left: -50px; }

/*************************************
 *
 *subpage
 *
 *************************************** */
/*************************************
 *
 *footer
 *
 ************************************** */
footer {
  background: #282828; }
  footer .ib {
    padding: 80px 0 30px;
    display: flex;
    overflow: hidden;
    justify-content: space-between; }
    footer .ib p.copy {
      font-size: 10px;
      color: #fff;
      float: right; }
    footer .ib .l, footer .ib .r {
      width: 50%; }
      footer .ib .l .logo, footer .ib .r .logo {
        width: 240px; }
      footer .ib .l h3, footer .ib .r h3 {
        font-size: 16px;
        color: #fff; }
      footer .ib .l p, footer .ib .r p {
        font-size: 16px;
        color: #fff;
        line-height: 1.8; }
      footer .ib .l nav:nth-of-type(2) a, footer .ib .r nav:nth-of-type(2) a {
        font-size: 16px;
        font-weight: normal; }
      footer .ib .l nav a, footer .ib .r nav a {
        width: 100%;
        display: block;
        font-size: 16px;
        font-weight: bold;
        color: #fff;
        padding-bottom: 20px; }
    footer .ib .r {
      flex-wrap: wrap;
      display: flex;
      justify-content: space-between; }
      footer .ib .r p.copy {
        width: 100%;
        font-size: 10px;
        color: #fff;
        text-align: right;
        margin-top: 80px; }
      footer .ib .r .sns {
        width: 172px; }
        footer .ib .r .sns p {
          font-weight: bold;
          margin-top: 44px; }
        footer .ib .r .sns a.a {
          width: 100%;
          padding: 12px;
          display: flex;
          align-items: center;
          justify-content: center;
          font-size: 16px;
          color: #fff;
          font-weight: bold;
          background: #E6001B;
          transition: 0.4s ease; }
          footer .ib .r .sns a.a:hover {
            transform: translateY(-10px); }
          footer .ib .r .sns a.a img {
            margin-right: 8px; }
        footer .ib .r .sns .buttons {
          width: 100%;
          display: flex;
          justify-content: space-between;
          align-items: center; }

/*# sourceMappingURL=style.css.map */
